git服务器搭建
Posted zhangyq-yard
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了git服务器搭建相关的知识,希望对你有一定的参考价值。
1. 创建git用户
useradd git
passwd git
2. 建立一个ssh的访问控制文件,这个文件默认不存在的,需要自己手动添加,路径为 /home/git/.ssh/authorized_keys
这个文件的路径是在ssh服务器配置中指定的(/etc/ssh/sshd_config), 这个授权文件保存的是需要访问git服务器的客户端ssh key值。通过命令ssh-keygen -t rsa 即可生成.ssh目录及文件id_rsa和id_rsa.pub,将客户端id_rsa.pub文件中的内容拷贝到authorized_keys文件中即可。
3. 在服务器上建立一个git库目录 如 /home/git/gitSrv , 在目录中初始化一个空库
git init --bare sample.git --bare表明只用版本记录文件,没有工作区,没有实际保存的可读源文件。(裸仓库)
裸仓库没有工作区,因为服务器上的Git仓库纯粹是为了共享,所以不让用户直接登录到服务器上去改工作区,并且服务器上的Git仓库通常都以.git结尾。然后将这个文件的归属设置为git用户(如果已经是git用户的就不再操作了)
chown -R git:git sampl.git
4. 将git用户的登录默认shell改成git-shell,使用管理员权限编辑/etc/passwd
将git:x:1001:1001:,,,:/home/git:/bin/bash 改为:git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell
备注:
1. 生成ssh密钥: ssh-keygen -t rsa 建议使用默认的文件路径和无密码(直接两次回车)
2. 生成的密钥传到git服务器上,可以使用scp命令
scp localFile [email protected]:remoteDIrPath/remoteFileName 传递某个文件到远端
scp [email protected]:remotePath localPath 从远端下载某个文件到本地
scp localDir -r [email protected]:remoteDIrPath 传递整个目录到远端
3. ssh服务重启命令:
centos7下 systemctl restart sshd.service
4. cat 向某个文件末尾追加信息并且主动换行。添加多个用户的rsa key值得时候可以使用 cat a.txt >> b.txt 向b后添加a的内容
5. 当配置完后使用ssh无法连接服务器,检查/etc/ssh/sshd_config文件下的如下配置项
RSAAuthentication yes
PubkeyAuthentication yes
PasswordAuthentication yes
6. git status中文乱序解决: git config --global core.quotepath false
7. 如果团队过大,每个人 的权限都要放到authorized_keys中就有点麻烦了,这个时候使用gitolite来管理每个人的ssh公钥,
并可以指定一些列的访问权限。
https://github.com/sitaramc/gitolite
参考:
https://www.liaoxuefeng.com/wiki/896043488029600/899998870925664
https://blog.csdn.net/y472360651/article/details/82263545
https://www.cnblogs.com/zhoug2020/p/5789041.html
https://blog.csdn.net/u010597189/article/details/81284642
以上是关于git服务器搭建的主要内容,如果未能解决你的问题,请参考以下文章