GitHub是一个免费托管开源代码的远程仓库。但是对于某些视源代码如生命的商业公司来说,既不想公开源代码,又舍不得给GitHub交保护费,那就只能自己搭建一台Git服务器作为私有仓库使用。
下面将要介绍在Ubuntu下搭建Git服务器的过程,假设用户名为hesonglin:
(1) 首先安装Git:
sudo apt-get install git
(2) 创建一个git用户,用来运行git服务,如下图所示:
sudo adduser git
(3) 创建证书登录:
收集所有需要登录的用户的公钥,就是他们自己的id_rsa.pub文件,把所有公钥导入到/home/git/.ssh/authorized_keys文件里,一行一个。此处的具体操作为:
① 确认已经连接上互联网,然后输入命令:
sudo apt-get install ssh
② 配置为可以免密码登录本机。首先查看在用户下是否存在.ssh文件夹(注意ssh文件夹前面有“.”,这是一个隐藏文件夹),输入命令:
ls -a /home/hesoglin
一般来说,安装SSH时会自动在当前用户下创建这个隐藏的文件夹,如果没有,可以手动创建一个。接下来输入命令:
ssh-keygen -t rsa -P ‘’ -f ~/.ssh/id_rsa
解释一下,ssh-keygen代表生成密钥;-t(注意区分大小写)表示指定生成的密钥类型;rsa是rsa密钥认证的意思,即密钥类型;-P用于提供密语;-f指定生成的密钥文件。在Ubuntu中,~代表当前用户文件夹,即此处的/home/hesonglin。
这个命令会在.ssh文件夹下创建id_rsa及id_rsa.pub两个文件,这是SSH的一对私钥和公钥,类似于钥匙和锁,把id_rsa.pub追加到授权的key中去。输入以下命令:
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
这条命令的功能是把公钥追加到用于认证的公钥文件中,这里的authorized_keys是 用于认证的公钥文件。
至此,免密码登陆本机已配置完毕。
(4)初始化Git仓库
先选定一个目录作为Git仓库,假定是/srv/sample.git,在/srv目录下输入命令:
sudo git init --bare sample.git
Git就会创建一个裸仓库,裸仓库没有工作区,因为服务器上的Git仓库纯粹是为了共享,所以不让用户直接登录到服务器上去改工作区,并且服务器上的Git仓库通常都以.git结尾。然后,把owner改为git:
sudo chown -R git:git sample.git
(5)禁用shell登录:
出于安全考虑,第二步创建的git用户不允许登录shell,这可以通过编辑/etc/passwd文件完成。找到类似下面的一行:
git:x:1001:1001:,,,:/home/git:/bin/bash
改为:
git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell
这样,git用户可以正常通过ssh使用git,但无法登录shell,因为我们为git用户指定的git-shell每次一登录就自动退出。
(6)克隆远程仓库
现在,可以通过git clone命令克隆远程仓库了,在各自的电脑上运行:
git clone git@server:/srv/sample.git
Cloning into 'sample'...
warning: You appear to have cloned an empty repository.
最后,进行推送即可。可以按照如下的命令进行测试是否能实现在终端中对Git的操作:
首先,在主目录(本文章中为/home/hesonglin)中建立一个文件夹(本例中为localGit),作为本地的git仓库,使用命令:
sudo mkdir localGit(记得要给该文件夹赋予相应的操作权限:sudo chmod 777 ./localGit)。
然后,进入新建的目录localGit中,使用命令:git init,将该文件夹初始化为本地的一个git仓库。在该目录中随意新建一个文件readme(可以使用命令:touch readme),然后使用命令:
git add readme
git commit -m “add a new file named readme”
此时,先不急着推送,先添加远程仓库的路径,另外,还需要将本地仓库的分支与远程分支关联起来,使用如下两条命令:
git remote add git@server_ip:/server/path/remote.git
git branch --set-upstream master origin/master
此时,即可将本地仓库中所做的变化提交到远程的服务器仓库中,使用如下命令:
git push -u origin master(只是第一次提交需要-u,之后不需要)