大前端

使用 Linux 搭建 Git 服务器

2017-12-06  本文已影响45人  柏丘君

本文将介绍基于 Ubuntu 搭建一个简单的 Git 服务器,在做这件事之前,可以先了解一些 Linux 的常用远程操作,关于这部分内容可以参考这篇文章

环境准备

我准备了三台机器:一台用做 Git 的服务器,另外两台用作客户机。这三台机器都是安装在虚拟机上的:


1-准备虚拟机.png

这三台机器的 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服务器

完。

上一篇下一篇

猜你喜欢

热点阅读