心血来潮,想自己搭建一个git开发环境, 奈何linux小白, git小白, 只好搜索网上资源,整理到一起。
完成之后,发现自己的知识贫乏至极, 继续努力学习才是王道。
我的真机安装的是Windows 8专业版。
在vmware上安装了centos6.3-64位, 作为服务器, 选用的live cd版本,ISO文件相比binDVD版本小一点。
1.服务器部分:
1.1 更换yum源
cd /etc/yum.repos.d 进入yum源配置目录
mv CentOS-Base.repo CentOS-Base.repo.bk 备份系统自带的yum源
wget http://mirrors.163.com/.help/CentOS-Base-163.repo 下载163网易的yum源
mv CentOS-Base-163.repo CentOS-Base.repo 覆盖系统自带yum源
yum makecache 使配置立即生效
1.2 安装git
yum install -y git
安装完毕后, 运行检查版本的命令: git --version, 若出现
git version 1.7.1 GIT
安装完毕。
可惜git版本够老, 对yum如何去获取最新版本的软件,完全不懂。
虽然对版本差异不懂, 但还是希望可以使用现在最新的2.0.0版本。
于是遵从网上的方法饶了点弯路。
1). 从githubclone下来git的源码: git clone https://github.com/git/git
2). 安装git前准备(安装需依赖的包):
yum install curl -y
yum install curl-devel -y
yum install zlib-devel -y
yum install openssl -y
yum install perl -y
yum install cpio -y
yum install expat-devl -y
yum install gettext-devl -y
yum installperl-devel.i686 -y
yum install -y libpcap.x86_64
yum install -y libpcap-devel.x86_64
yum install -y perl-devel.x86_64
3). 编译安装
autoconfig
./configure
make
make install
4). 安装完毕后, 运行检查版本的命令: git --version, 若出现
git version 2.0.0 GIT
git安装完毕
1,3 搭建简易git服务器
1). 关闭selinuxvi /etc/selinux/config
修改SELINUX=Enabled为SELINUX=Disabled
2). 创建git裸版本库
cd /repo/ repo文件夹下放各种各样的项目的git版本库
git init bare my.git 建立一个全新得版本仓库,注意这里不是工作目录,我理解的是这里保存的是当前project的全局信息。
3). 版本库用户管理
groupadd git 增加名为git的组,专门为git服务
useradd -pxxx -g git gitowner 增加一个普通用户名为gitowner,这个用户可以不是开发者一员。
chown -R gitowner /repo/ 递归地把/repo/目录下所有文件的属主改为gitowner(参数-R 代表递归目录下所有文件或目录)
chgrp -R git /repo/ 递归地把/repo/目录下所有文件的属组改为git
chmod 770 -R /repo 仅允许git组内成员对repo文件夹进行操作
4). 生成密钥对
$ cd ~
$ ssh-keygen -t rsa
$ chmod 700 ~/.ssh
$ cat id_rsa.pub >> ~/.ssh/authorized_keys
$ chmod 600 ~/.ssh/authorized_keys
5). centos打开SSH连接(以下方式有些不安全=。=, 继续研究中)
vi /etc/ssh/sshd_config 打开ssh配置文件
RSAAuthentication yes 开启RSS验证
PubkeyAuthentication yes 开启公钥验证???
AuthorizedKeysFile .ssh/authorized_keys 这个文件就是我们之前生成ssh key的地方
找到#Port 22, 去掉‘#’注释, 指定SSH连接的端口号,安全方面不建议使用默认22端口why?
Protocol 2,1 允许SSH1和SSH2连接,建议设置成 Protocal 2
vi /etc/ssh/hosts.allow
在最后面添加一行:sshd: All, 应该是允许所有连接的意思。
以上配置完毕后,输入以下命令启动或重启ssh服务
/etc/init.d/sshd start/restart
6). centos关闭防火墙(可选)
方法一:完全关闭防火墙。
使用setup命令启动文字模式配置实用程序,在”选择一种工具”中选择”防火墙配置”,然后选择”运行工具”按钮,出现防火墙配置界面,将”安全级别”设为”禁用”,然后选择”确定”即可。
方法二:关闭防火墙对80,22端口的保护
#/sbin/iptables -I INPUT -p tcp –dport 80 -j ACCEPT
#/sbin/iptables -I INPUT -p tcp –dport 22 -j ACCEPT
#/etc/rc.d/init.d/iptables save
#/etc/init.d/iptables restart 重启防火墙
2.Windows客户端部分:
2.1 先安装git for windows,再安装totorisegit.
2.2 将服务器上~/.ssh/id_rsa私钥文件复制到客户端
2.3 启动puttygen, load刚才从服务器上复制的id_rsa私钥文件, 如下:
生成完毕后, 点击Save private key保存转换格式后的私钥,如下图。
在
tortoisegit
设置程序中配置远程主机
2.4 在totorisegit中配置远程主机2.5 在本地建立版本库后,可以尝试用pull命令拉取文件。