CentOS7 安装git和gitosis

7 篇文章 0 订阅


1 链接

个人博客: alex-my.xyz

CSDN: blog.csdn.net/alex_my

2 环境说明

  • 服务器使用的阿里云, CentOS7.4
  • 本机使用的Mac
  • 服务器的ssh端口不是默认的22,而是8998(实际不是,不想告诉你),安全为主

    • 打开 /etc/ssh/sshd_config
    • 找到 Port 22
    • 将22修改为8998
    • 重启ssh服务: systemctl restart sshd.service
    • 在阿里云后台安全组添加8998
    • 在firewalld添加端口8998

      -- 添加
      firewall-cmd --zone=public --add-port=8998/tcp --permanent
      -- 重载
      firewall-cmd --reload
      -- 查看
      firewall-cmd --zone=public --list-ports
  • 多提一句,虽然我们修改了ssh端口,但还是可以用类似namp工具扫描出来,所以我把ICMP也屏蔽了

    echo 1 >/proc/sys/net/ipv4/icmp_echo_ignore_all
    • 如果要恢复,把数字修改为0就好
    • 重启就失效了,所以需要添加到开机启动中(rc.local或者systemd)
    • 试一试,还能ping的通服务器吗?
  • 我的机子实际IP地址也不是124.123.122.121, 随意填的

3 安装git

  • 卸载旧的git

    yum remove git
  • 安装依赖包

    yum install autoconf curl-devel expat-devel openssl-devel zlib-devel perl-devel
  • 下载源码包

  • 编译安装

    tar -zxvf git-2.9.5.tar.gz
    cd git-2.9.5
    ./configure
    make
    make install  # 需要root权限
  • 制作软链接到/usr/bin

    ln -s /usr/local/bin/git /usr/bin/git
  • 查看版本号

    git --version
    • 输出: git version 2.9.5
  • 删除安装包

    rm -rf git-2.9.5 git-2.9.5.tar.gz

4 新建用户git

  • 我们希望有专门的用户来管理git服务,而不是使用拥有最高权限的root用户
  • 新建用户git,用于运行服务(root用户执行)

    useradd git
  • 为新用户创建密钥等信息(git用户执行)

    su git  # 从root用户转为git
    cd ~    # 实际上为 /home/git
    mkdir .ssh
    chmod 700 .ssh
    cd .ssh
    ssh-keygen -t rsa
    • 会在/home/git/.ssh生成两个文件id_rsa,id_rsa.pub

5 安装gitosis

  • 这是一款非常好用的权限管理工具,具体说明自行搜索
  • 安装python以及python工具,一般默认自带2.7.5,可以照样再执行一遍

    yum install python python-setuptools
  • 下载安装gitosis

    git clone git://github.com/res0nat0r/gitosis.git
    cd gitosis
    python setup.py install
    • 最后输出 Finished processing dependencies for gitosis==0.2表示成功

6 配置gitosis

  • 初始化gitosis

    gitosis-init < /home/git/.ssh/id_rsa.pub
    rm -rf /home/git/.ssh/id_rsa.pub # 安全起见,就删了吧
    chmod 755 /home/git/repositories/gitosis-admin.git/hooks/post-update 
  • 由于仓库默认就是/home/git/repositories,但是常常这个地方硬盘较小,因此我希望能指定到较大空间的硬盘去
  • 没有找到如何在gitosis-init的时候指定路径的方法,这边就采取妥协的方式: 使用软链接(root用户执行)

    exit # 退出git用户,返回到之前的root用户
    mv /home/git/repositories /data/git # 移动到/data目录下并重命名为git
    ln -s /data/git /home/git/repositories
    chown git:git /data/git
    chown git:git /home/git/repositories
  • 先把权限管理工程克隆下来(管理员/运维人员以后可以克隆到自己的电脑上,我这里直接放在了git用户这里)(git用户执行)

    su git
    cd ~
    git clone ssh://git@124.123.122.121:8998/gitosis-admin.git git-manage
    • 如果ssh端口是默认的22,可以使用git clone git@124.123.122.121:gitosis-admin.git git-manage
  • 在git-manage目录中有两个文件
    • gitosis.conf: 配置权限
    • keydir: 存放用户公钥
  • 将自己的密钥文件上传到keydir目录中,并命名,比如我自己电脑上的公钥命名为alex.pub

    
    # linux,mac等用scp命令,服务器ssh端口为8998
    
    scp -P 8998 id_rsa.pub root@124.123.122.121:/data
    • 登录服务器将id_rsa.pub移动到/home/git/git-manage/keydir中,并命名为alex.pub
  • 配置gitosis.conf文件(git用户执行)

    [gitosis]
    
    [group gitosis-admin]
    members = git@keylala
    writable = gitosis-admin
    
    [group dev]
    members = alex
    writable = js.keylala
    • 以上代码中,我们可以看见,只有git@keylala用户能够操作gitosis-admin项目,运维可以把自己的名称也加到这里
    • members指的是用户名称,这个用户名称必须与公钥文件的名称相同
    • members可以配置多个用户,用空格隔开就行
    • writable用于指定可以写的工程,比如后面我们会创建一个js.keylala.git工程
    • 以上的意思是,拥有alex.pub这个公钥对应私钥的用户可以操作js.keylala.git工程
    • 至于group dev什么的都是自己命名的,请随意
  • 按照以上改完之后,要记得,git-manage是导出的项目工程,我们要用命令推送回仓库中去(git用户执行)

    cd /home/git/git-manage
    git add .
    git commit -m "add new group"
    git push origin master
    • 新增文件时用git add .
    • 如果只是修改,可以不用git add .,而是用git commit -am "change"一次性搞定

7 使用

  • 创建项目(git用户执行)

    su git
    cd /data/git
    git init --bare js.keylala.git
    • 这个时候会有一个js.keylala.git文件夹生成
  • 在自己的电脑上访问

     git clone ssh://git@124.123.122.121:8998/js.keylala.git
    • 这样就下载到自己的机子上了
    • 如果服务器用的是默认的22端口,用以下命令

      git clone git@124.123.122.121:js.keylala.git
  • 在自己的电脑上修改并提交

    cd js.keylala
    touch readme.md
    git add .
    git commit -m "add new file"
    git push origin master
  • 提交之后,可以在另一个地方再克隆出来看看,是不是有readme.md这个文件了
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Git是非常著名的分布式版本控制系统。 Gitosis则是方便通过Git与ssh架设中央服务器的软件。这篇文章的安装流程写得很明了,但使用中还是遇到了些许问题,本文算是该流程的补充。如果打算通过Gitosis架设服务器通过本文或许可以少走不少弯路。 一、架设步骤 1. 下载并安装python setuptools sudo apt-get install python-setuptools 2. 下载并安装gitosis cd ~/src git clone git://eagain.net/gitosis.git cd gitosis python setup.py install 3. 添加用户git sudo adduser \ --system \ --shell /bin/sh \ --gecos 'git version control' \ --group \ --disabled-password \ --home /home/git \ git 4. 生成本机密钥 切换到个人机,如果已有~/.ssh/id_rsa.pub略过此步 ssh-keygen -t rsa 5. 上传密钥到服务器临时目录 scp ~/.ssh/id_rsa.pub 用户名@主机:/tmp 6. 初使化gitosis 切回到服务器 sudo -H -u git gitosis-init < /tmp/id_rsa.pub 7. 修改post-update权限 sudo chmod 755 /home/git/repositories/gitosis-admin.git/hooks/post-update 8. clone gitosis管理平台 git clone git@主机名:gitosis-admin.git cd gitosis-admin 9. 安装完成 通过修改gitosis-admin管理gitosis用户权限 添加公密到keydir,添加用户 修改完后commit,push到中服务器即可完成仓库权限的相关操作。 二、实例 目标:添加用户 john 和仓库 foo 到gitosis,并和管理员miao合作管理 1. 用户john添加并发送id_rsa.pub给miao john:~$ ssh-keygen -t rsa Generating public/private rsa key pair. Enter file in which to save the key (/home/john/.ssh/id_rsa): Created directory '/home/john/.ssh'. Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /home/john/.ssh/id_rsa. Your public key has been saved in /home/john/.ssh/id_rsa.pub. john:~$ cp /home/john/.ssh/id_rsa.pub /tmp

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值