参考:

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

[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

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

$ 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

Linux 下搭建Git 服务器详细步骤的更多相关文章

  1. 【转】在Linux下搭建Git服务器

    在 Linux 下搭建 Git 服务器 环境: 服务器 CentOS6.6 + git(version 1.7.1)客户端 Windows10 + git(version 2.8.4.windows. ...

  2. 在Linux下搭建Git服务器的方法是什么样?

    第一步 安装git:可以通过命令的方式快速安装,不同的linux的安装方法可能不一样,我的是采用的yum方法.ubuntu可以用apt-get命令.sudo yum install git 第二步 添 ...

  3. 在Linux下搭建Git服务器步骤

    环境: 服务器 CentOS6.6 + git(version 1.7.1) 客户端 Windows10 + git(version 2.8.4.windows.1)  ① 安装 Git Linux ...

  4. 在 Linux 下搭建 Git 服务器

    环境: 服务器 CentOS6.6 + git(version 1.7.1)客户端 Windows10 + git(version 2.8.4.windows.1) ① 安装 Git Linux 做为 ...

  5. 在 Linux 下搭建 Git 服务器(yum安装)

    服务端(linux): 1. 安装git [root@localhost ~]# yum -y install git 2. 增加一个git账户 为了管理的方便,在linux下面增添一个 " ...

  6. Linux下搭建Git服务器

    1.安装Git 见 Jenkins持续集成环境部署 第四节 2.创建Git用户和用户组 groupadd git useradd git -g git 3.创建证书切换到git用户创建证书 su gi ...

  7. kali linux 下搭建git服务器

    参考:http://www.cnblogs.com/dee0912/p/5815267.html https://www.liaoxuefeng.com/wiki/001373951630592960 ...

  8. 在Linux下搭建git服务器

    http://www.cnblogs.com/dee0912/p/5815267.html 步骤很详细,很受用

  9. Windows操作系统下搭建Git服务器和客户端。

    本文将介绍如何在Windows操作系统下搭建Git服务器和客户端.服务器端采用的是Bonobo Git Server,一款用ASP.NET MVC开发的Git源代码管理工具,界面简洁,基于Web方式配 ...

随机推荐

  1. 深入Java虚拟机之内存区域与内存溢出

    一.内存区域 Java虚拟机在执行Java程序的过程中会把他所管理的内存划分为若干个不同的数据区域.Java虚拟机规范将JVM所管理的内存分为以下几个运行时数据区:程序计数器.Java虚拟机栈.本地方 ...

  2. im_master_search_specification

    中文 http://accel-archives.intra-mart.jp/2014-winter/document/iap/public_zh_CN/im_master/im_master_sea ...

  3. Caffe测试单独的算子

    最近有一个需求是测试单独算子在CPU.Caffe使用的GPU.cuDNN上的性能,一个是使用caffe的time问题,还有一个是使用单独的test功能. time选项的使用,大家都比较熟悉,单独的te ...

  4. svn+jenkins自动部署

    需求:项目经理想要将原型图修改完后直接发布 前置条件: 已经有了svn服务器,并正常使用 已经有了jenkins服务器,之前搭建的gitlab+jenkins, 如需搭建jenkins,参考 http ...

  5. Delphi TIdTCPServer组件

    樊伟胜

  6. (六)buildroot使用详解

    为什么要使用buildroot? (文件系统搭建,强烈建议直接用buildroot,官网[http://buildroot.uclibc.org/]上有使用教程非常详细)文件系统通常要包含很多第三方软 ...

  7. getAttribute和getParameter的简单区别

    getAttribute表示从request范围取得设置的属性,必须要先setAttribute设置属性,才能通过getAttribute来取得,设置与取得的为Object对象类型 getParame ...

  8. eclipse集成springboot 插件(离线安装,含解决Cannot complete the install because one or more required items could)

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/li18310727696/article/details/81071002首先,确认eclipse的 ...

  9. 设置本地cookie 存session 保持长期有效

    <?php session_start(); // 启动Session $_SESSION['count']; // 注册Session变量Count isset($PHPSESSID)?ses ...

  10. 使用ViewPager实现导航

    1.使用PageAdapter适配器 2.使用FragmentPageAdapter适配器 监听事件: OnPageChangeListener 百度云:链接: http://pan.baidu.co ...