git仓库服务器配置;
两种方式:
方式一:使用git协议,创建的git仓库服务器,只能下载,不能上传;
方式二:使用http或https协议,安装httpd1.6.6以上版本就支持上传和下载等丰富的功能了;
本次实验物理机win7,虚拟机是两台centos7:
本地git仓库,node1:172.18.11.111
远程git仓库,noed2:172.18.11.112
方式图一:使用git协议创建git远程仓库:
在node2:
安装git-daemon
]# yum -y install git-daemon
初始化一个裸仓库:名称为myproject.git
]# cd /var/lib/git/
]# git init --bare myproject.git
]# ls /var/lib/git/myproject.git/
在node1:
克隆远程仓库:
]# git clone git://172.18.11.112/myproject.git
查看git查看配置等信息:
以上就完成远程git仓库的创建和本地下载远程仓库了;使用的git协议,不支持推送上传,要想实现推送要使用http协议;
注意:
git协议创建的服务器有缺陷:
第一,不支持推送;
第二,不支持认证;
第三,端口很特殊,tcp/9418
方式二:使用http协议进行创建git远程仓库:
要基于http协议实现git远程仓库,只有安装一个http服务即可。
在node2:
安装git-daemon
]# yum -y install git-daemon
]# yum -y install httpd
对于http协议的git仓库,要求http协议必须启动三个模块:
第一,支持路径别名;
第二,环境变量设定;
第三,cgi机制;
因为,基于http协议实际是使用poll脚本完成智能设定的;
查看三个模块:确保如下三个模块启用
创建裸仓库目录并授权:
]# mkdir /var/www/git
]# cd /var/www/git
]# git init --bare testproject.git
]# chown -R apache:apache /var/www/git
确保该目录属主属组为apache用户,否则会没有写操作权限;
]# vim /etc/httpd/conf/httpd.conf
#DocumentRoot "/var/www/html"
为提供git仓库基于http协议实现,创建新的配置文件:
]# vim /etc/httpd/conf.d/git.conf
]# httpd -t
]# systemctl start httpd.service
]# ss -tnl 查看80端口监听;
回到node1节点,克隆这个基于http协议的远程git仓库:
]# git clone http://172.18.11.112/git/testproject.git
]# cd testproject/
此时下载仓库到本地了,如果在这个远程跟踪分支上进行更改内容:
]# echo "new line" > README
]# git add README
]# git commit -m "v0.1"
提交后再上传到远程服务器:
]# git push origin master
输入授权的用户名和密码即可完成上传了:
以上就是基于http协议创建git远程仓库的整个过程,当然配置好http协议的仓库,再配置https协议的git仓库,无非就是多了一个步骤配置CA证书等工作;
使用这种方式进行认证非常不安全,可以做htsps协议方式进行;
把账号密码放在文件里,也不很妥当,放在互联网上的公共仓库时,还可以基于mysql认证,把账号、密码放在mysql数据库表里;
以上这些自己管理起来都非常麻烦,就出现了互联网上专门做代码托管的服务站点。
原文地址:http://linsj.blog.51cto.com/5440766/1790778