Linux搭建git仓库

环境:
cat etc/redhat-release 
CentOS Linux release 7.8.2003 (Core)

首先检查机器有没有安装yum,命令:yum list 测试下,没有安装先安装yum

安装git

#yum install -y git

安装完后,查看 Git 版本

# git --version
 git version 1.8.3.1

创建 git 用户

# cd /home                                  #进入/home/目录

# id git                                 #查看git用户是否存在

      id: git: no such user                                       #提示git用户不存在

# useradd git                            #创建git用户

 passwd git                             #为git用户创建密码

Changing password for user git.

New password:                                               #设置密码

BAD PASSWORD: The password is shorter than 8 characters

Retype new password:                                        #确认密码

passwd: all authentication tokens updated successfully.

服务器端创建 Git 仓库

[root@ceontOS ~]#mkdir -p home/git/test1109.git   #在git用户目录下创建仓库目录git,并且创建test1109.git项目测试目录

注:git  test1109.git是自建目录  test1109.git为仓库名

[root@ceontOS home]# ls      #查看/home/目录下有哪些用户目录
root   git
[root@ceontOS home]# cd git   #进入git用户目录
[root@ceontOS git]# ls      #查看git用户目录下有哪些目录/文件
 test1109.git

[root@ceontOS git ]# git init --bare ./test1109.git   #这步很重要,初始化项目测试目录

Initialized empty Git repository in /home/git/test1109.git/

然后把 Git 仓库的 owner 所有者修改为 git

[root@ceontOS git]#  ll      #查看test1109.git项目文件夹的拥有者

drwxr-xr-x. 7 root root 119 Nov  9 18:31 test1109.git    #拥有者是root用户名

[root@ceontOS git]# chown -R git:git test1109.git/    #将拥有者改为git用户

[root@ceontOS git]# ll      #再次查看test1109.git项目文件夹的拥有者

drwxr-xr-x. 7 git git 119 Nov  9 18:31 test1109.git          #拥有者是git用户

设置完成

客户端 clone 远程仓库

先在本地Windows系统上创建一个存放git项目的文件夹,例如我的设置在:【D:\testGit1109】

在文件夹内使用git Bash  clone远程仓库

$ git clone  git@服务器公网IP地址:/home/git/test1109.git    

        #IP地址后面跟冒号,冒号后面是刚才初始化的项目文件夹的绝对路径

Linux搭建git仓库_第1张图片

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

客户端创建 SSH 公钥和私钥

通过git bash      输入命令ssh-keygen

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

id_rsa_git 是私钥

id_rsa_git.pub 是公钥

服务器端修改配置文件,打开 RSA 认证

进入 /etc/ssh 目录,编辑 sshd_config,打开以下三个配置的注释:

按如下设置这三个配置,如果注释掉了,则去掉前面的#号

RSAAuthentication yes        (有的版本较高可能没有此项,忽略)
PubkeyAuthentication yes
AuthorizedKeysFile .ssh/authorized_keys

保存并重启 sshd 服务:

systemctl restart sshd.service   #重启sshd服务

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

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

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

Linux搭建git仓库_第2张图片

 

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

回到客户端Git Bash 下,导入文件:

$ ssh git@服务器公网IP地址 'cat >> .ssh/authorized_keys' < ~/.ssh/id_rsa.pub

 回到服务器端,查看 .ssh 下是否存在 authorized_keys 文件:

重要:

修改 .ssh 目录的权限为 700

修改 .ssh/authorized_keys 文件的权限为 600

Linux搭建git仓库_第3张图片

 客户端再次 clone 远程仓库

禁止 git 用户 ssh 登录服务器

之前在服务器端创建的 git 用户不允许 ssh 登录服务器

编辑 /etc/passwd
[root@ceontOS ~]# sudo vi /etc/passwd  #编辑/etc/passwd文件

找到:

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

修改为:

git:x:1001:1001::/home/git:/bin/git-shell

此时 git 用户可以正常通过 ssh 使用 git,但无法通过 ssh 登录系统

git服务器仓库设置完成,初始化仓库开始

Windows下客户端操作

在客户端打开Git Bash,然后将目录切换到指定文件夹下面下。执行下面命令,将该文件夹设为本地仓库

git init   初始化 

接着再执行如下命令,将本地仓库连接到服务器上的仓库:

git remote add origin git@公网服务器ip:/home/git/test1109.git

你可能感兴趣的:(linux,git,centos)