共计 1504 个字符,预计需要花费 4 分钟才能阅读完成。
Ubuntu14.04 Git 1.9.1 Gitolite
sudo apt-get install openssh-server
sudo apt-get install git-core
(其他人也用这个账户登录,根据公钥识别身份或许相应权限,任意客户端使用 gituser@gitserverip 进行登录)
sudo adduser --system --shell /bin/bash --group git | |
修改 git 密码 | |
sudo passwd git |
注:本例中的 git 可以换成其他任意数字字母。
(后面可以更改,用哪个客户端的都没关系)
ssh-keygen -t rsa
该命令会在用户主目录下创建 .ssh 目录,并在其中创建两个文件:
id_rsa 私钥文件。是基于 RSA 算法创建。该私钥文件要妥善保管,不要泄漏。
id_rsa.pub 公钥文件。和 id_rsa 文件是一对儿,该文件作为公钥文件,可以公开。用户需要将此公钥文件上传到 Git 服务器上。(后文还有介绍)
通过任意方法把客户端的 id_rsa.pub 复制到 Git 服务器上
scp ~/.ssh/id_rsa.pub git@serverip:/tmp/admin.pub
sudo apt-get install gitolite
sudo su git
sudo gl-setup /tmp/admin.pub
中间会弹出配置文件,如果没有特殊需求,直接退出就好。
git clone git@serverip:gitolite-admin
克隆下来的 gitlite-admin 文件夹会在你的用户名文件夹下,下面有 keydir 和 conf 两个目录:
keydir 里是所有组成员的公钥,初始时只有一个用户公钥,即 amdin 用户的公钥 admin.pub。
conf 目录下的 gitolite.conf 文件为授权文件,用于配置用户和权限。
权限控制进阶用法 https://git-scm.com/book/zh/v1/ 服务器上的 -Git-Gitolite
例子:
@admin =admin zhangsan lisi wanger // 指定 admin zhangsan lisi wanger 为管理员组 | |
@guest =guest xiaoming // 指定 guset xiaoming 为来宾组 | |
@Project_repo =T1 T2 T3 T4 T5 T6 T7 T8 T9 // 指定 T1-T9 为 Project-repo 组 | |
repo @Project_repo // 创建 T1-T9 仓库 | |
RW+ =@admin // 管理组拥有 T1-T9 项目权限 | |
RW int$ =@guest // 来宾组仅能 push T1-T9 的 "int" 分支 |
修改好后使用下面的命令推送到服务器,先 cd 到 gitlite-admin 文件夹
git add . | |
git commit -m "这个是提交信息,用于表示这次提交的解释,可以随便写" | |
git push origin master |
让需要使用 Git 的用户在自己的 PC 上生成公钥,并发送给管理员。管理员把收到的公钥放到 gitlite-admin 文件夹下的 keydir 文件夹里,把名字改成有标识性的名称如 zhangsan.pub lisi.pub 等,并在 gitolite.conf 文件里添加 zhangsan lisi 的访问权限
