为了实现公司开发平台、个人电脑Windows平台、个人电脑Linux平台、国外买的云服务器、即将咬购买的阿里云的云服务器之间的代码同步和快速部署,进行了一些简单的技术选型,首先考虑的是rsync,发现安装非常麻烦,然后考虑了一个商业软件,安装亦不顺,最终决定还是走最成熟的代码仓库平台,svn和git都是不错的选择,但是考虑到两点,抛弃了svn:
- svn在每个目录下都有.svn文件夹,内容太多,复制过程中、grep过程中都可能带来麻烦
- svn要起后台服务,十分不便
于是乎,git成了不二选择:
- git的每个repo都只有一个.git文件夹,不污染源码
- git可以不启后端服务(但是用户必须使用ssh模式连接git“服务器”)
下面记录创建git服务器的过程:
选择root服务器
首先选择一个root服务器,它必须满足2个要求:
1. 不停机 2. 所有平台都能连接。于是只能用国外的云服务器作为root服务器了。因为公司开发平台只能连接外网,外网却连不上它,个人电脑不满足不停机的要求。
创建repository(在root服务器上)
登录root服务器,用root帐号创建一个用户raywill,
su raywill
cd /home/raywill
mkdir repository
cd /home/raywill/repository/
git config --global user.name "raywill"
git config --global user.email “hustos@qq.com"
从此以后所有源码的root都在/home/root/repository目录下了。
创建第一个项目(在root服务器上)
一个repository下面可以有多个git项目,git命令的操作目标是单个的项目。例如淘宝有oceanbase和tair两个项目,他们可能的目录结构为:
/home/raywill/repository/oceanbase
/home/raywill/repository/tair
下面创建我们的第一个项目yiker
git init --bare yiker
执行该命令成功后/home/raywill/repository/下生成了一个yiker目录,该目录里面只有一个.git文件夹。
签出项目并增加一个文件(在个人电脑上)
签出项目
cd ~
git clone raywill@174.140.1.1:/home/raywill/repository/yiker/ yiker_clone
cd yiker_clone/
ls
新建文件
echo "hello git" > README.txt
cd yiker_clone/
ls
新建文件
echo "hello git" > README.txt
将修改提交到本地仓库
git add *
git commit
将本地仓库的修改同步到root服务器
git add *
git commit
将本地仓库的修改同步到root服务器
git push origin master
整个过程中遇到三个问题,都一一解决,这些问题都是git带出来的,但都不是git的问题:
1. ssh 174.140.1.1连接极慢的问题
> 很多时候ssh连接慢是由于反向域名解析导致的,不过我遇到的不是这个。用DEBUG模式开启ssh,可以看到慢在哪一步:
ssh -v 174.140.1.1
可以看到ssh连接会尝试用很多种认真方式连接ssh服务器(root服务器),我的卡在了
debug1: Next authentication method: gssapi-with-mic
这一步上。解决方法是编辑root服务器上的ssh配置文件:
vi /etc/ssh/ssh_conf
找到
GSSAPIAuthentication yes
改为
GSSAPIAuthentication no
保存。OK了,连接很快!
找到
GSSAPIAuthentication yes
改为
GSSAPIAuthentication no
保存。OK了,连接很快!
详细可以参考:
ssh 连接慢解决办法
2. 不支持免密码提交git push的问题
git支持四种传输协议:Local, SSH, Git, HTTP。Local就是本地玩玩,没啥实际用途,Git、HTTP通常都是只读模式,而且都需要起server deamon,剩下只有SSH模式了,比较靠谱,很好使。因为采用了SSH模式,也就可以利用SSH带来的一系列便利了,例如免密码登录。具体方法见我的博客:
Linux主机间建立信任关系
这次却奇怪了,按照流程操作却依然不行,最后baidu一番才知道,是文件的权限导致的,具体参考
Linux添加信任关系失败这篇文章。
3. SSHD无法启动的问题
因为搞ssh翻墙,另外手动启动了一个sshd(原来的sshd没有被覆盖,新的sshd在/usr/local/bin/sshd,配置文件中也配置了22端口),导致/etc/init.d/sshd restart失败。
解决办法:新的sshd只监听翻墙端口,老的sshd只监听22端口。
4. 其它问题
误添加文件到git,commit之前可以执行:
git rm -r --cached .
.gitignore
这句的意思是,跟踪platfrom目录下的所有文件,但是忽略所有文件夹,因为有个/在最后>面。
platform/*/
data/*/
~