搭建自己的Git服务器

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,之后不需要)

 







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值