本文将介绍基于 Ubuntu 搭建一个简单的 Git 服务器,在做这件事之前,可以先了解一些 Linux 的常用远程操作,关于这部分内容可以参考这篇文章。
环境准备
我准备了三台机器:一台用做 Git 的服务器,另外两台用作客户机。这三台机器都是安装在虚拟机上的:
这三台机器的 IP 地址分别为 192.168.47.136、192.168.47.137 和 192.168.47.138。
首先,需要确保三台机器都安装并开启了 SSH 服务,并且三台机器上都安装了 Git。如果还没有安装的话,可以通过以下命令进行安装:
sudo apt-get install openssh-client openssh-server git
创建 git 用户
在你准备做服务器的那台机器上创建一个名为 git
的用户:
sudo adduser git
然后,切换到该用户,在用户主目录下创建一个 .ssh
目录,并在 .ssh
目录中创建一个 authorized_keys
文件以备用:
su git
mkdir .ssh
touch .ssh/authorized_keys
收集公钥
Git 服务器上的准备工作做好后,在另外两台作为客户机的机器上分别创建密钥文件,并将公钥传输到上面在 Git 服务器上建立的 .ssh
目录中:
ssh-keygen -t rsa -C "xxx" -f "xxx_rsa"
scp ./xxx_rsa.pub git@192.168.47.137:/home/git/.ssh
接下来,在 Git 服务器上,进入 .ssh
目录,将收到的公钥文件内容追加到 authorized_keys
文件中。
cat xxx_rsa.puh >> authorized_keys
初始化代码仓库
在 Git 服务器上,进入用户主目录,创建一个 srv
目录(目录名和路径都可以自由选择),并初始化一个空的代码仓库:
mkdir srv
cd srv
sudo git init --bare test.git
sudo chown -R git:git test.git
顺便提一下,上面这一步你可能会遇到类似 git 不在 sudoers 文件中。此事将被报告。
这样的错误,出现这种情况,需要修改 /etc/sudoers
文件,增加相应的 git
用户配置:
# User privilege specification
root ALL=(ALL:ALL) ALL
git ALL=(ALL:ALL) ALL
禁用 git 用户使用 shell 登录
为了提高版本仓库的安全性,我们在收集好所有成员的公钥文件后,就需要关闭 git
用户的 shell 登录功能。需要对 /etc/passwd
进行一些修改,找到下面这一行代码:
git:x:1001:1001:,,,:/home/git:/bin/bash
将其修改为:
git:x:1001:1001:,,,:/home/git:/bin/git-shell
到此,我们就搭建好一个简易的 Git 服务器了。
多人协作
搭建好 Git 服务器后,就可以进行多人协作开发了,开发模式和传统的 Git 并无二致,首先是从版本库克隆代码。在其中一台客户机上,使用以下命令:
git clone git@192.168.47.137:/home/git/srv/test.git
然后进入 test
目录,添加一个文件并提交到版本库:
cd test
echo "Hello Git" >> test.txt
git add .
git commit -m "First Commit"
git push -u origin master
在另一台客户机上,从版本库克隆 test.git
项目,看下有没有什么变化。至于 Git 操作,不是本文的重点,这里就不再进行演示了。
总结
在 Linux 上搭建 Git 服务器比较简单,几条命令就能搞定。如果你还想使用类似 Github 的图形化管理系统,可以试试 Gitlab 等工具,选择面较多。
参考资料:
搭建Git服务器
完。