Linux 下搭建Git 服务器详细步骤

时间:2021-12-31 15:42:52

参考:

https://www.cnblogs.com/dee0912/p/5815267.html#_label0

https://blog.csdn.net/carfge/article/details/79691360

https://www.cnblogs.com/fly_dragon/p/8718614.html

1、环境准备

服务器:CentOS 7.3 + git (1.8.3.1)

客户端:win10 + git (2.17.0.windows.1)

2、服务器安装git

yum install -y git

  

3、创建git用户,管理 git服务

[root@localhost home]# useradd git
[root@localhost home]# passwd git

4、服务器创建git 仓库

设置/home/git/repository-git 为git 服务器仓库,然后把 git 仓库的 owner 修改为 git 用户。

[root@localhost git]# mkdir repository-git
[root@localhost git]# git init --bare repository-git/
Initialized empty Git repository in /home/git/repository-gt/
[root@localhost git]# chown -R git:git repository-git/

5、客户端安装git

下载 Git for Windows,地址:https://git-for-windows.github.io/

安装完之后,可以使用 Git Bash 作为命令行客户端。

5.1、选择一个目录 F:\project\sell 作为本地仓库,右键进入Git Bash 命令行模式

初始化本地仓库:git init 

5.2、尝试克隆一个服务器的空仓库到本地仓库

git clone git@192.168.116.129:/home/git/repository-gt

第一次连接到目标 Git 服务器时会得到一个提示:

The authenticity of host '192.168.116.129(192.168.116.129)' can't be established.
RSA key fingerprint is SHA256:Ve6WV/SCA059EqoUOzbFoZdfmMh3B259nigfmvdadqQ.
Are you sure you want to continue connecting (yes/no)?

选择 yes:

Warning: Permanently added '192.168.116.129' (RSA) to the list of known hosts.

此时 C:\Users\用户名\.ssh 下会多出一个文件 known_hosts,以后在这台电脑上再次连接目标 Git 服务器时不会再提示上面的语句。

6、客户端创建公钥和私钥

客户端git 第一次连接 服务器端的git仓库时,需要创建公钥和私钥,并将公钥发给服务器保存起来,才能正常访问。

$ ssh-keygen -t rsa -C "xxxx100@163.com",邮箱随便输入即可。

 

此时 C:\Users\用户名\.ssh 下会多出两个文件 id_rsa 和 id_rsa.pub

id_rsa 是私钥

id_rsa.pub 是公钥

7、服务器 git 打开RSA 认证

进入 /etc/ssh 目录,编辑sshd_config,查看以下三个配置是否被注释,如被注释,取消掉注释:

RSAAuthentication yes
PubkeyAuthentication yes
AuthorizedKeysFile .ssh/authorized_keys

  

保存并重启sshd服务:

  servcie sshd restart

由 AuthorizedKeysFile 得知公钥的存放路径是 .ssh/authorized_keys,实际上是 $Home/.ssh/authorized_keys,由于管理 git 服务的用户是 git,所以实际存放公钥的路径是 /home/git/.ssh/authorized_keys

在 /home/git/ 下创建目录 .ssh

[root@localhost git]# pwd
/home/git
[root@localhost git]# mkdir .ssh
[root@localhost git]# ls -a
. .. .bash_logout .bash_profile .bashrc .gnome2 .mozilla .ssh

然后把 .ssh 文件夹的 owner 修改为 git

Linux 下搭建Git 服务器详细步骤
[root@localhost git]# chown -R git:git .ssh
[root@localhost git]# ll -a
总用量 32
drwx------. 5 git git 4096 8月 28 20:04 .
drwxr-xr-x. 8 root root 4096 8月 28 19:32 ..
-rw-r--r--. 1 git git 18 10月 16 2014 .bash_logout
-rw-r--r--. 1 git git 176 10月 16 2014 .bash_profile
-rw-r--r--. 1 git git 124 10月 16 2014 .bashrc
drwxr-xr-x. 2 git git 4096 11月 12 2010 .gnome2
drwxr-xr-x. 4 git git 4096 5月 8 12:22 .mozilla
drwxr-xr-x. 2 git git 4096 8月 28 20:08 .ssh
Linux 下搭建Git 服务器详细步骤

设置权限,此步骤不能省略,而且权限值也不要改,不然会报错。

$ chmod 700 /home/git/.ssh/

$ chmod 600 /home/git/.ssh/authorized_keys

将客户端公钥导入服务器端 /home/git/.ssh/authorized_keys 文件

打开 C:\Users\user\.ssh 下 id_rsa.pub,将里面所有的内容拷贝到/home/git/.ssh/authorized_keys文件里。

8、客户端与服务器仓库关联起来

git remote add origin git@192.168.116.129:/home/git/repository-git

将本地项目推送到远程仓库:

git add -A

git commit -m 'First push.'

git push -u origin master

git push -u origin master 如果报错,则表明本地仓库与远程仓库冲突,需要先拉取远程仓库到本地:

git pull --rebase origin master

现在我们有这样的两个分支,test和master,提交如下:

       D---E test
/
A---B---C---F--- master

在master执行git merge test,然后会得到如下结果:

       D--------E
/ \
A---B---C---F----G--- test, master

在master执行git rebase test,然后得到如下结果:

A---B---D---E---C‘---F‘---   test, master

merge 操作会生成一个新的节点,之前的提交分开显示。
而rebase操作不会生成新的节点,是将两个分支融合成一个线性的提交。

9、另起一个客户端仓库拉取远程仓库测试

首先初始化本地仓库,其次将本地仓库与远程仓库进行关联,之后再拉取远程仓库的项目。

jinwe@DESKTOP-V4BF121 MINGW64 /e/project/sell2
$ git init
Initialized empty Git repository in E:/project/sell2/.git/ jinwe@DESKTOP-V4BF121 MINGW64 /e/project/sell2 (master)
$ git remote add origin git@192.168.116.129:/home/git/repository-git jinwe@DESKTOP-V4BF121 MINGW64 /e/project/sell2 (master)
$ git fetch origin master
git@192.168.116.129's password:
remote: Counting objects: , done.
remote: Compressing objects: % (/), done.
remote: Total (delta ), reused (delta )
Unpacking objects: % (/), done.
From 192.168.116.129:/home/git/repository-git
* branch master -> FETCH_HEAD
* [new branch] master -> origin/master

在本地建立分支并切换到该分支,将远程分支的内容拉取到本地。

jinwe@DESKTOP-V4BF121 MINGW64 /e/project/sell2 (master)
$ git checkout -b master origin/master
Already on 'master'
Branch 'master' set up to track remote branch 'master' from 'origin'. jinwe@DESKTOP-V4BF121 MINGW64 /e/project/sell2 (master)
$ git pull origin master
git@192.168.116.129's password:
remote: Counting objects: , done.
remote: Compressing objects: % (/), done.
remote: Total (delta ), reused (delta )
Unpacking objects: % (/), done.
From 192.168.116.129:/home/git/repository-git
* branch master -> FETCH_HEAD
9a87e03..83b12cd master -> origin/master
Updating 9a87e03..83b12cd
Fast-forward
src/test/java/com/latiny/sell/LoggerTest.java | -
file changed, deletion(-)

最后,回到本地文件夹E:\project\sell2 查看,已拉取远程分支到本地啦!

10、额外知识

客户端在使用ssh方式连接时,报错。查看了下ssh使用的注意事项,记录下来。

查看状态:

service sshd status

service sshd restart

service sshd stop

ssh服务的网络连接情况:

netstat -ntlp

netstat -ntlp|grep sshd

查看本地仓库管理的远程仓库

git remote -v

修改远程仓库的关联

比如,之前你关联的远程仓库使用的协议是 http ,你想将关联的远程仓库的 url 改为 ssh 协议的。

修改关联的远程仓库的方法,主要有三种。

第一种:使用 git remote set-url 命令,更新远程仓库的 url

git remote set-url origin <newurl>

第二种:先删除之前关联的远程仓库,再来添加新的远程仓库关联

# 删除关联的远程仓库
git remote rm <name>(远程分支)
# 添加新的远程仓库关联
git remote add <name> <url>
远程仓库的名称推荐使用默认的名称 origin 。

第三种:直接修改项目目录下的 .git 目录中的 config 配置文件。

11、常见的git 命令

git init  //初始化本地git仓库

git add<file>  //添加文件

git add *.html  //添加一类文件

git add .  //添加所有文件

git status //查看状态

git commit //提交

git commit -m ''提交并注释 (这样就可以不用进入到编辑页面了)

git push  //从远程仓库考取数据

git clone  //从远程仓库拷贝数据

git config --global user.name'张宜成'  配置用户名

git config -- global user.email 'chengchengzhang123@qq.com' 配置邮箱

git rm --cached 文件名  //从add工作区中删除

git branch 分支名 (创建分支)

git checkout 分支名 (切换到你的分支中)

git checkout master(切换到主分支)

git merge 分支名(在master主分支下使用 将分支合并到主分支)

git remote 查看连接

git remote add origin 链接  (创建链接)

git remote remove 名称(删除remote)

git clone 将服务器端的项目克隆岛本地仓库

touch .gitignore 忽略需要上传的文件(将要忽略的文件放到该文件夹)

touch.gitignore 忽略文件(/文件名)

README.md文档 git对项目进行描述

$ git push origin master //推送到远程仓库

abc