项目有版本控制的需求,所以要在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 | id 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 | cd /path/to/ |
客户端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账户的密码,然后会看到:
此时,C:\Users\用户名.ssh 下会多出一个文件 known_hosts,以后在这台电脑上再次连接目标 Git 服务器时不会再提示上面的语句。除了使用输入密码的方式,还可以采用 SSH 公钥来对客户端进行验证。
客户端clone远程仓库(ssh连接)
客户端创建SSH公钥和私钥
由于我之前在搭建个人博客已经生成过一次公私钥对,可以使用之前生成的公私钥,也可以另外再生成。这里我们再生成一次公私钥:
1 | cd ~/.ssh |
为了和之前生成的id_rsa.pub和id_rsa区分,当看到提示:Enter file in which to save the key(/c/Users/Administrator/.ssh/id_rsa):时,输入test。即设置公私钥对文件名,亦可以设置别的命名方式。接着的提示没有需求,输入空格即可,最后会看到:
此时,列举当前目录的所有文件,发现成功生成了test和test.pub文件。
在服务器端配置公钥
首先,登录服务器端git账号,输入密码后,创建存放客户端test.pub的目录:
1 | su git |
接着,复制test.pub里的公钥到服务器端的authorized_keys文件中,完成后把.ssh目录的owner修改为git:
1 | sudo vim ~/.ssh/authorized_keys |
客户端设置
在客户端~/.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 | git add test.txt |
如果遇到warning: LF will be replaced by CRLF in test.txt问题,输入下列命令即可。
1 | git config core.autocrlf false |
- 从缓存区提交修改(新增)到版本库
1 | git commit -m 'add test.txt' |
- 将最终修改提交到远程主机
1 | git push -u origin master |
删除文件修改
前提:保证远程服务器存在test.txt文件
- 删除版本库文件
1 | git rm test.txt |
- 从缓存区提交修改(新增)到版本库
1 | git commit -m 'rm test.txt' |
- 将最终修改提交到远程主机
1 | git push -u origin master |
参考资料
1.centos 搭建git服务器和客户端
2.在Linux 下搭建 Git 服务器
3.centos 配置git服务器,写的超棒
4.搭建私有git服务器进行版本控制
5.已存在的项目使用git进行管理
6.Git Commit和Push的区别