Ubuntu上搭建git服务器

最近看到git的介绍,刚好自己又想在公司电脑和家里电脑之间同步一些文件,于是便开始学习git了。

不过要想实现多台电脑的同步就必须要有一个git服务器,虽然有github,但那是开源的,自己有些东西还是不适合公开。私有的仓库要需要收费,对于现阶段的我来说还是没有必要专门去租一个私有仓库的。

刚好想到自己之前那台联想笔记本一直放在家里没用,于是就想用其搭建一个git服务器。由于Windows对于git的兼容性并不好,所以首先将系统给换成了Ubuntu的,然后再在上面搭建git服务器。

在搭建的过程中遇到了好多坑,都是一个一个踩过来的,也幸亏网上有很多前辈记录的文章自己才能搭好。所以,我也将我搭建的过程记录下来,一方面,怕自己以后忘了;另一方面,如果能对后学者提供参考那就更好了。

一、安装git服务器所需软件

安装git-core

git-core是git版本控制核心软件,安装命令如下:

sudo apt-get install git-core

若安装提示失败,可能是因为系统软件库的检索文件太旧了,需要先更新一下,更新命令如下:

sudo apt-get update

安装openssh-server和openssh-client

openssh-server和openssh-client用于git通过ssh协议来在服务器与客户端之间传输文件,安装命令如下:

sudo apt-get install openssh-server openssh-client

安装python

由于安装gitosis需要用到Python的一些工具,所以需要先安装setup,安装命令如下:

sudo apt-get install python-setuptools

初始化服务器的git用户信息

安装gitosis之前需要初始化服务器的git用户信息,初始化命令如下:

git config --global user.name "penn"
git config --global nser.email "penn@example.com"

获取gitosis版本文件

这个就类似于我们下载安装包,命令如下:

git clone https://github.com/res0nat0r/gitosis.git  

安装gitosis

进入文件目录

cd gitosis/

安装gitosis

这里需要使用python命令安装目睹下的setup.py的python脚本进行安装,命令如下:

sudo python setup.py install

到这里整个安装步骤就完成了,下面是对git进行一些基本配置。

二、创建git管理员账户、配置git

创建管理员账户

创建一个账户(gitmanager)作为git服务器的管理员,可以管理其他用户的项目权限。命令为:

sudo useradd -m gitmanager
sudo passwd gitmanager

创建仓库存储点

在/home目录下创建一个项目仓库存储点,命令为:

sudo mkdir /home/gitrepository 

权限设置

设置只有git用户拥有所有权限,其他用户没有任何权限,命令为:

sudo chown gitmanager:gitmanager /home/gitrepository/  
sudo chmod 700 /home/gitrepository/

创建链接映射

由于gitosis默认状态下会将仓库放在用户的repositories目录下,例如gitmanager用户的仓库地址默认在
/home/gitmanager/repositories/目录下,这里我们需要创建一个链接映射。让他指向我们前面创建的专门用于存放项目的仓库目录/home/gitrepository。

命令如下:

sudo ln -s /home/gitrepository /home/gitmanager/repository

生成公钥

在管理机器(你主要使用的电脑)上生成一个ssh的公钥,命令如下:

ssh-keygen -t rsa

拷贝公钥文件到服务器

将公钥文件拷贝到服务器上,命令如下:

scp /home/penn/.ssh/id_rsa.pub gitmanager@192.168.0.23:/home/gitmanager/id_rse.pub

初始化gitosis

注意:初始化之前需要切换至gitmanager用户

su gitmanager
gitosis-init < home/gitmanager/id_rsa.pub(传到服务器的地址)

三、在服务器上创建项目仓库

创建仓库

使用gitmanager账户在服务器上创建一个目录(mytestproject.git)并初始化成git项目仓库。命令如下:

su gitmanager 
cd /home/gitrepository  
mkdir mytestproject.git  
git init --bare   
exit 

SSh验证

使用初始化 Gitosis 公钥的拥有者身份 SSH 进服务器,命令如下:

ssh gitmanager@192.168.0.23

克隆Gitosis的控制仓库到本地

命令为:

git clone gitmanager@192.168.0.23:/home/gitmanager/repositories/gitosis-admin.git

gitosis-admin目录结构

  • gitosis.conf

用来设置用户、仓库和权限的控制文件

  • keydir

保存所有具有访问权限用户公钥的地方每人一个

多人协助开发同一个版本

将他们每个人的公钥文件添加到keydir文件夹然后push到服务端。文件的命名将决定在gitosis.conf配置文件中的称呼。

添加协同成员示例

1.为 John,Josie 和 Jessica 添加公钥:

$ cp /tmp/id_rsa.john.pub keydir/john.pub
$ cp /tmp/id_rsa.josie.pub keydir/josie.pub
$ cp /tmp/id_rsa.jessica.pub keydir/jessica.pub

2.把他们都加进 ‘mobile’ 团队,让他们对iphone_project具有读写权限:

[group mobile]
writable = iphone_project
members = scott john josie jessica

权限控制

Gitosis 也具有简单的访问控制功能。如果想让 John 只有读权限,可以这样做:

[group mobile]
writable = iphone_project
members = scott josie jessica
[group mobile_ro]
readonly = iphone_project
members = john

现在 John 可以克隆和获取更新,但 Gitosis 不会允许他向项目推送任何内容。

四、常见问题

运行ssh git@192.168.0.23出错

重启电脑

ERROR:gitosis.serve.main:Repository read access denied

原因

gitosis.conf中的members与keydir中的用户名不一致,如gitosis中的members = foo@bar,但keydir中的公密名却叫foo.pub

解决方法

使keydir的名称与gitosis中members所指的名称一致。 改为members = foo 或 公密名称改为foo@bar.pub

lone时报does not appear to be a git repository

原因

clone时不能用绝对路径,只能写相对于gitmanager用户home的相对路径。

我用的路径是:git clone gitmanager@192.168.0.6:gitosis-admin.git

解决方案

将路径改为:相对gitmanager用户的路径:

git clone gitmanager@192.168.0.23:/home/gitmanager/repositories/gitosis-admin.git

五、参考资料

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容

  • gitosis: 把所有用户的公钥保存在 authorized_keys 文件的做法,只能凑和一阵子,当用户数量达...
    晓蜻蜓阅读 5,769评论 2 2
  • 本文为 Git教程的学习笔记,教程源自廖雪峰的博客。这是一个由浅入深,学完后能立刻上手的Git教程。另,附上另一本...
    七弦桐语阅读 6,241评论 5 47
  • 产品介绍: 从不同的APP中汇集最新内容,将散落在不同应用内的文章、图片和视频串联起来,在同一个页面当中摘录成册。...
    2c5994723157阅读 1,054评论 0 1
  • Text 7月|8月 Video 7月|8月 Rio 2016 8/1 | 8/2 | 8/3 | ...
    帝都搬运工阅读 437评论 0 0