Linux搭建git服务器
1. 安装git
2. 新建git用户
为git仓库专门创建一个用户和用户目录,方便管理git仓库,可以省略
3. 创建git仓库
至此git远程仓库就建好了。
4. 本地clone
这样就clone了一个git仓库,之后就可以添加文件,进行后续的commit
push
等操作了。
5. 生成ssh公钥
由于每次pull,push等操作都需要输入密码,我们可以生成一个ssh公钥:
创建好后会在user/.ssh/下有一个id_rsa
和id_rsa.pub
,id_rsa.pub
就保存了我们的公钥,拷贝出来,粘贴在服务器的/home/git/.ssh/authorized_keys
文件下保存即可,没有这个文件则新建。后面pull和push就不需要输入密码了。
6. 支持http协议
目前我们搭建的git服务器只支持ssh协议,但是我们很多情况下需要使用http协议,比如:
我们可以使用nginx来配合git搭建http协议的git服务器(经过使用Apache搭建失败的痛苦经历后,转战nginx)。
安装nginx和fcgiwarp
配置nginx
编辑/etc/nginx/sites-enabled/default
创建nginx认证用户文件
可以使用htpasswd
命令来创建认证用户, 如果服务器上没有这个命令的话, 可以输入命令 apt-get install apache2-utils
来安装这个命令, 安装了这个命令之后, 就可以使用它来创建认证用户了, 比如要创建用户 user1, 输入命令如下:
然后根据提示输入密码就行了。
修改git仓库权限
通过http协议进行clone
,push
等操作等保证git仓库有对应的权限,使用git init
创建的仓库默认权限是drwxr-xr-x
需要给group组合other赋予读写权限:
重启nginx并测试
7. 遇到的问题
7.1 配置pub_key后clone还是需要输入密码
一开始搭建的时候出现这个问题,重新生成了一个公钥并拷贝到authorized_keys
文件下解决。后来鼓捣了半天http协议,结果git协议clone又需要输入密码了,这次重新生成的方法失效了。找了好多资料,折腾了大半天,才发现是/home/git
目录的权限问题,在linux中所有的用户目录权限默认是drwxr-xr-x
如果更改了用户目录权限就会引起很多问题,之前搞http擅自更改了权限才导致的这次折腾。参考:https://blog.csdn.net/jacky0922/article/details/17999271
注意:在authorized_keys添加另一个pub_key需要重起一行,否则会鉴权失败
参考:
https://gitee.com/progit/4-%E6%9C%8D%E5%8A%A1%E5%99%A8%E4%B8%8A%E7%9A%84-Git.html
https://blog.csdn.net/LMXQH/article/details/80792135
https://beginor.github.io/2016/03/12/http-git-server-on-nginx.html
Last updated