阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Ubuntu install and configuration Git server

15次阅读
没有评论

共计 1504 个字符,预计需要花费 4 分钟才能阅读完成。

环境

Ubuntu14.04 Git 1.9.1 Gitolite

安装 OpenSSH-Server
sudo apt-get install openssh-server
安装 Git 服务端
sudo apt-get install git-core
创建 git 管理账户

(其他人也用这个账户登录,根据公钥识别身份或许相应权限,任意客户端使用 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
安装 Gitolite
sudo apt-get install gitolite
切换至 git 管理账号
sudo su git
导入从客户端获取的 admin.pub 公钥
sudo gl-setup /tmp/admin.pub

中间会弹出配置文件,如果没有特殊需求,直接退出就好。

在客户端使用 git clone 克隆 gitlite-admin 库,并做相应权限修改
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
添加其他用户(权限参考 8)

让需要使用 Git 的用户在自己的 PC 上生成公钥,并发送给管理员。管理员把收到的公钥放到 gitlite-admin 文件夹下的 keydir 文件夹里,把名字改成有标识性的名称如 zhangsan.pub lisi.pub 等,并在 gitolite.conf 文件里添加 zhangsan lisi 的访问权限

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2025-02-07发表,共计1504字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中