Mac搭建Git服务器(Git+Gitlite)

背景

        工作需要,要把代码由SVN改为Git管理,公司有自己的Git服务器,但是抱着学习的态度,还是决定自己搭一台玩玩。度娘了一下,呵,还真不少,浏览了几篇度娘上靠前的几篇,挑了两篇觉得靠谱的,就开始有点小激动的按照教程动手了。也正是因此,掉进了万劫不复的坑。

        1天2天3天。。。一个多星期过去了,不管怎么尝试,权限管理就是不好使。偶然间,在一个填坑的过程中,看到有人说gitosis是比较老旧的权限管理工具,已经停止维护了。看到这里,一万个那什么从心中飘过。。(度娘出来的结果,基本上全都是git+gitosis的啊),不过还好,在给gitosis填坑的过程中,也学到了很多东西。

        二话不说,立马换掉gitosis,通过了解学习,知道有下面三种主流的Git服务管理工具(方案):

- Gitosis - 轻量级, 开源项目,使用SSH公钥认证,只能做到库级的权限控制。目前项目已经停止开发,不再维护。

- Gitolite - 轻量级,开源项目,使用SSH公钥认证,能做到分支级的权限控制。

- Git + Repo + Gerrit - 超级重量级,集版本控制,库管理和代码审核为一身。可管理大型及超大型项目。


    那么就毫无疑问的选择Gitolite了。

搭建

一,创建 git 账户

1,在服务器上创建git账户,系统偏好设置->用户与群组

添加git账户

这里最好选择为管理员身份。不是必须的,仅仅为了方便。

2,打开远程访问

注销,切换到git账户登录,系统偏好设置->共享,打开远程共享。(文件共享和远程管理可以不打开,因为我是用的一台Macmini,没有显示器键盘等配件,所以需要另一台电脑操控它)


二,安装gitolite

创建文件夹bin

$ cd ~

$ mkdir bin

从github克隆gitolite的源码

$ git clone https://github.com/sitaramc/gitolite.git

安装gitolite(home代表你的git账户所在的目录,我的电脑是Users,所以这里对应的就是/Users/git/bin/,本文后面的指令里有用到home的地方也同理)

$ ./gitolite/install -to /home/git/bin/

至此gitolite的安装完成,可以查看bin目录里的内容。


bin目录

三,回管理员主机(自己机器)上生成密钥对

1,配置git用户名和邮箱,这是因为git提交都需要这两个信息,在命令行输入:

git config --global user.name "Your Name"

git config --global user.email "email@example.com"

2,生成密钥对,在命令行输入:

ssh-keygen -t rsa -C "youremail@example.com"

然后一路回车,使用默认值即可,无需设置密码。生成的秘钥对在.ssh文件夹下(需显示隐藏文件才能看到.ssh)


密钥对存放目录

.pub结尾的就是你的公钥,就是要把它放到服务器上,达到免密码登录验证的目的。

四,配置gitolite管理员

把刚才得到的公钥拷贝到服务器桌面(随便一个你能找到的位置就可以)。怎么拷贝,U盘,邮件,QQ随你便。改一下公钥名字,为你的邮箱名字youremail@example.com.pub。

为gitolite配置管理员,命令行输入

$ /home/git/bin/gitolite setup -pk /home/git/Desktop/youremail@example.com.pub

配置SSH

修改sshd配置文件(/etc/ssh/sshd_config),找到以下内容,并去掉注释符”#“(非root用户没有权限直接修改此文件,拷贝一份出来,改好再考进去替换掉原来的就可以了)

RSAAuthentication yes

PubkeyAuthentication yes

AuthorizedKeysFile  /home/git/.ssh/authorized_keys

重启ssh服务

service sshd restart

很奇怪的是我的机器找不到service指令,所以用以下指令手动重启了下

1.启动sshd服务:

sudo launchctl load -w /System/Library/LaunchDaemons/ssh.plist

2.停止sshd服务:

sudo launchctl unload -w /System/Library/LaunchDaemons/ssh.plist

3查看是否启动:

sudo launchctl list | grep ssh

如果看到下面的输出表示成功启动了:

--------------

- 0 com.openssh.sshd

至此,整个服务器就搭建完毕了。

剩下Gitolite权限管理的相关知识和怎么操作网上就比较多,也比较靠谱了,大家自行百度吧。这里就不在详解了。

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

推荐阅读更多精彩内容