Hexo

搭建Git服务器

2018-08-02

项目有版本控制的需求,所以要在Linux下搭建Git服务器,那就开始吧~

安装Git

服务器端 CentOS7.5 + git(version 1.8.3.1)
客户端 Windows7 + git(version 2.18.0.windows.1)

一般,CentOS操作系统都会安装Git,可通过下列命令查看Git的版本信息。

1
git --version

如果嫌版本低,可以选择卸载重装。

创建git用户

服务器端查询git用户是否存在,如不存在则创建git用户,用来管理Git服务,并为git用户设置密码。另外,创建git用户和设置密码需要以root权限运行。

1
2
3
id git
adduser git
passwd git

禁止 git 用户 ssh 登录服务器

为了安全,在服务器端创建的git用户不允许ssh登录服务器,编辑/etc/passwd,找到:

git:x::::/home/git:/bin/bash

修改为

git:x::::/home/git:/bin/git-shell
此时 git 用户可以正常通过 ssh 使用 git,但无法通过 ssh 登录系统。

服务器端创建Git仓库

设置/path/to/test.git为Git仓库,/path/to/为自己设置的路径,创建仓库前确保路径已存在。

1
git init --bare /path/to/test.git

然后把Git仓库的owner修改为git。

1
2
cd /path/to/
chown -R git:git test.git/

客户端clone远程仓库(密码连接)

进入Git Bash命令行客户端,创建项目地址(假设设置在 d:/projects/)并进入。关于Git Bash的相关内容可查看使用Hexo-Vexo搭建个人博客的安装git节。

1
cd d:/projects/

然后从Linux Git服务器上clone项目:(...出填写服务器端的IP地址)

1
git clone git@*.*.*.*:/path/to/test.git

如果SSH用的不是默认的22端口,则需要使用以下的命令(假设SSH端口号是7700):

1
git clone ssh://git@*.*.*.*:7700/path/to/test.git

当第一次连接到目标Git服务器时会得到一个提示:Are you sure you want to continue connecting (yes/no)? ,输入yes,接着输入git账户的密码,然后会看到:

git clone远程项目

此时,C:\Users\用户名.ssh 下会多出一个文件 known_hosts,以后在这台电脑上再次连接目标 Git 服务器时不会再提示上面的语句。除了使用输入密码的方式,还可以采用 SSH 公钥来对客户端进行验证。

客户端clone远程仓库(ssh连接)

客户端创建SSH公钥和私钥

由于我之前在搭建个人博客已经生成过一次公私钥对,可以使用之前生成的公私钥,也可以另外再生成。这里我们再生成一次公私钥:

1
2
cd ~/.ssh
ssh-keygen -t rsa

为了和之前生成的id_rsa.pub和id_rsa区分,当看到提示:Enter file in which to save the key(/c/Users/Administrator/.ssh/id_rsa):时,输入test。即设置公私钥对文件名,亦可以设置别的命名方式。接着的提示没有需求,输入空格即可,最后会看到:

ssh 生成公私钥对

此时,列举当前目录的所有文件,发现成功生成了test和test.pub文件。

在服务器端配置公钥

首先,登录服务器端git账号,输入密码后,创建存放客户端test.pub的目录:

1
2
su git
mkdir ~/.ssh/

接着,复制test.pub里的公钥到服务器端的authorized_keys文件中,完成后把.ssh目录的owner修改为git:

1
2
sudo vim ~/.ssh/authorized_keys
chown -R git:git ~/.ssh/

客户端设置

在客户端~/.ssh目录下的配置文件config中加入如下内容。

host git-server 
    user git
    hostname 远程主机IP地址
    port 远程主机ssh连接端口 
    identityfile ~/.ssh/test(和前文公私钥对设置需保持一致)

然后只要将仓库地址中替换成新建的host别名,通过下述命令即可免密从Linux Git服务器上clone项目:

1
git clone git-server:/path/to/test.git

对远程仓库进行简单的操作

新增文件修改

前提:在cd d:/projects/test/目录下新建并编辑test.txt文件

  1. 新增文件到缓存区
1
git add test.txt

如果遇到warning: LF will be replaced by CRLF in test.txt问题,输入下列命令即可。

1
git config core.autocrlf false
  1. 从缓存区提交修改(新增)到版本库
1
git commit -m 'add test.txt'
  1. 将最终修改提交到远程主机
1
git push -u origin master

删除文件修改

前提:保证远程服务器存在test.txt文件

  1. 删除版本库文件
1
git rm test.txt
  1. 从缓存区提交修改(新增)到版本库
1
git commit -m 'rm test.txt'
  1. 将最终修改提交到远程主机
1
git push -u origin master

参考资料

1.centos 搭建git服务器和客户端
2.在Linux 下搭建 Git 服务器
3.centos 配置git服务器,写的超棒
4.搭建私有git服务器进行版本控制
5.已存在的项目使用git进行管理
6.Git Commit和Push的区别