美文网首页
ubuntu 16.04搭建git服务器,无ssh密码

ubuntu 16.04搭建git服务器,无ssh密码

作者: emoji2022 | 来源:发表于2017-06-11 14:14 被阅读0次

    小编最近博客刚刚上线,由于每次调整都是将本地代码 scp 上传到服务器,过程很不方便。突然想起git版本控制。便搭建git服务器的花了一上午时间,过程很不容易,在此记录,防止下次需要。

    在此参考:廖雪峰老师关于git的教程,由于环境的不同,教程步骤给我带来了很多疑惑点,最后在各路大神的文章中,慢慢得到解决。在此就不一一列举。


    1.安装git:
    sudo apt-get git
    
    2.在服务器上创建一个用户,在此我命名为 git:
    sudo adduser git
    
    3.创建ssh证书文件:
    sudo mkdir /home/git/.ssh
    sudo touch /home/git/.ssh/authorized_keys
    
    4.收集所有需要登录的用户的公钥,就是他们自己的id_rsa.pub文件,把所有公钥导入到/home/git/.ssh/authorized_keys文件里,一行一个。
    5.修改authorized_keys文件的权限:
    sudo chmod 644 /home/git/.ssh/authorized_keys
    

    说明:
      1.修改权限后,客户端 clone、pull 就不需要ssh密码了。
      2.至于权限修改为 644 ,网上有很多说法,有人使用 600。其中道理说不清,请自行调整。

    6.禁止shell登录:

    出于安全考虑,第二步创建的git用户不允许登录shell,这可以通过编辑/etc/passwd文件完成:

    sudo vim /etc/passwd
    // 找到如下行
    git:x:1001:1001:,,,:/home/git:/bin/bash
    // 修改为
    git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell
    

    这样,git用户可以正常通过ssh使用git,但无法登录shell,因为我们为git用户指定的git-shell每次一登录就自动退出。

    7.初始化Git仓库:

    先选定一个目录作为Git仓库,假定是/srv/sample.git,在/srv目录下输入命令:

    sudo git init --bare sample.git 
    

    Git就会创建一个裸仓库,裸仓库没有工作区,因为服务器上的Git仓库纯粹是为了共享,所以不让用户直接登录到服务器上去改工作区,并且服务器上的Git仓库通常都以.git结尾。( 最后半句话的意思是,sample.git 是一个以 .git 结尾的文件夹 。)

    8.修改 sample.git 文件的所有者:
    sudo chown -R git:git sample.git
    
    这样就完成了这个git服务器的搭建。注意:以上所有的操作都是在服务器上完成。

    客户端克隆远程仓库:
     git clone git@server:/srv/sample.git      // server是服务器的ip地址
    

    至于git操作语法,参考廖雪峰老师的教程

    相关文章

      网友评论

          本文标题:ubuntu 16.04搭建git服务器,无ssh密码

          本文链接:https://www.haomeiwen.com/subject/pgyhqxtx.html