• 本地git仓库推送到服务器自建的git仓库实现目录文件同步教程


    1. 首先,先在服务器上安装git,如果有git的话就不用走这一步了

    yum安装git

    [root@iZuf6fazwjb6lb3z82smzoZ ~]# cd src/

    [root@iZuf6fazwjb6lb3z82smzoZ src]# wget http://dl.fedoraproject.org/pub/epel/5/x86_64/epel-release-5-4.noarch.rpm

    [root@iZuf6fazwjb6lb3z82smzoZ src]# rpm -ivh epel-release-5-4.noarch.rpm

    Preparing...                ########################################### [100%]

        package epel-release-5-4.noarch is already installed

    [root@iZuf6fazwjb6lb3z82smzoZ ~]# yum list

    [root@iZuf6fazwjb6lb3z82smzoZ ~]# yum install -y git

    1. 创建一个用户来运行git服务
    2. .           

    [root@iZuf6fazwjb6lb3z82smzoZ ~]# adduser git //创建用户git

    [root@iZuf6fazwjb6lb3z82smzoZ ~]# passwd git //设置用户git的密码

     

    1. 需要在你本地创建一个key公钥证书,说白了就是在本地弄个标识好让服务器知道是你推送过来
      打开本地git客户端界面
    2. .           

    $ ssh-keygen -t rsa //生成key证书公钥私钥 一路回车就ok了

    $ cat .ssh/id_rsa.pub //打开公钥

     

    类似图上这种 然后复制一下

    在服务器操作命令

    [root@iZuf6fazwjb6lb3z82smzoZ /]# su git       //切换git用户

    [git@iZuf6fazwjb6lb3z82smzoZ /]$ cd home       //进去home(git用户的公钥存放)

    [git@iZuf6fazwjb6lb3z82smzoZ home]$ cd git     //打开git文件夹

    [git@iZuf6fazwjb6lb3z82smzoZ ~]$ cd .ssh       //打开公钥文件夹

    [git@iZuf6fazwjb6lb3z82smzoZ .ssh]$ touch authorized_keys   //创建公钥文件

    [git@iZuf6fazwjb6lb3z82smzoZ .ssh]$ vim authorized_keys     //将刚才复制的那一串公钥粘贴进去

    如果没有.ssh文件 需要你在上一步生成秘钥和公钥

    这样的话,如果是多人需要用到这个用户的话,就需要每个人把自己电脑上的公钥给管理员,然后管理员在服务器进行添加就可以,这样下次登录就不需要密码验证了,直接验证你电脑上的公钥即可.

    后边会写到钩子自动同步更新,所以这里生成这个公钥,同样在服务器上也要生成一个然后放进.ssh里边的authorized_keys里边就好

     

     

    [git@iZuf6fazwjb6lb3z82smzoZ ~]$ chomd 700 .ssh

    [git@iZuf6fazwjb6lb3z82smzoZ ~]$ cd .ssh

    [git@iZuf6fazwjb6lb3z82smzoZ .ssh]$ chmod 600 authorized_keys

    按照上边给予权限即可!
    4.这一步特别重要,很多网友都会忽略,导致服务器上公钥没作用!
    记得切换root用户,git没权限!

    打开文件/etc/ssh/sshd_config

    RSAAuthentication yes            #开启RSA认证功能

    PubkeyAuthentication yes      #开启公匙认证

    StricModes no                          #据说不改会强制要求登录用户和文件拥有者用户相同

    找到以上三个然后把注释去掉就ok
    5.接下来,在服务器上初始化一个git仓库

    [git@iZuf6fazwjb6lb3z82smzoZ svnrepos]$ su root                                //切换root用户, 因为git没有任何权限

    Password:

    [root@iZuf6fazwjb6lb3z82smzoZ svnrepos]# git init --bare hello.git             //在该目录初始化一个仓库,仓库名叫hello.git

    Initialized empty Git repository in /data/wwwroot/default/svnrepos/hello.git/  //你仓库的地址,记好了后边要要用到[root@iZuf6fazwjb6lb3z82smzoZ svnrepos]# cd hello.git/

    [root@iZuf6fazwjb6lb3z82smzoZ hello.git]# ls

    branches  config  description  HEAD  hooks  info  objects  refs

    5.完事后会创建一个裸仓库,这个仓库没有工作区,因为只是纯粹用来共享而已,所以不让用户直接登录到服务器上去改工作区,并且服务器上的Git仓库通常都以.git结尾。然后,把git用户的权限设置为

    [root@iZuf6fazwjb6lb3z82smzoZ svnrepos]# chown -R git.git hello.git

    [root@iZuf6fazwjb6lb3z82smzoZ svnrepos]# ls -l

    total 4

    drwxr-xr-x 7 git git 4096 Apr 13 10:39 hello.git

    [root@iZuf6fazwjb6lb3z82smzoZ svnrepos]#

    6.权限给成功后,可以看出hello.git这个仓库git也有权限操作了.

    这时候可以在本地创建个仓库了

    HK04@HK04-PC MINGW64 /d (master)

    $ cd hello

    HK04@HK04-PC MINGW64 /d/hello (master)

    $ git add 1.txt

    HK04@HK04-PC MINGW64 /d/hello (master)

    $ git commit -m "1.txt"

    [master (root-commit) 8d3e977] 1.txt

     1 file changed, 1 insertion(+)

     create mode 100644 hello/1.txt

    好了,现在创建了一个1.txt文件.接下来,推送到服务器上的仓库

    $ git remote add origin git@ip:/data/wwwroot/default/svnrepos/hello.git  //本地连接远程库

    连接ok后可以通过 git remote -v 来查看 如果不对可以用 git remote rm origin 来删除
    接下来推送到服务器的仓库

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

    ok 如果推送成功后 现在服务器仓库就有刚才所添加的文件了
    但是.如果报错的话! 贴个类似的错误


    如果是报这个错误,是因为你本地刚才创建的那个key公钥已经被匹配或者是没有该目录git用户没有权限.
    可以把本地公钥删除了重新再生成或者是服务器仓库git用户的权限就可以!!

    1. 接下来,在服务器上将仓库的文件给克隆下来!

    [git@iZuf6fazwjb6lb3z82smzoZ svnrepos]$ git clone git@106.15.44.166:/data/wwwroot/default/svnrepos/hello.git //克隆服务器仓库数据

    克隆后,我们要用git 的钩子写个自动执行程序.

    [git@iZuf6fazwjb6lb3z82smzoZ svnrepos]$ cd hello.git

    [git@iZuf6fazwjb6lb3z82smzoZ hello.git]$ cd hooks

    [git@iZuf6fazwjb6lb3z82smzoZ hooks]$touch post-receive          //创建自动执行文件

    [git@iZuf6fazwjb6lb3z82smzoZ hooks]$chmod -R 777 post-receive   //给个权限

    [git@iZuf6fazwjb6lb3z82smzoZ hooks]$vim post-receive

    1. 打开后 写入下边这些自动执行命令

    #!/bin/sh 

    export LANG=zh_CN.UTF-8

    cd /data/wwwroot/default/svnrepos/hello      //这个是你每次要同步的文件夹

    unset GIT_DIR                                //这个很重要! 很多同学没有写这个就同步不了,因为git执行自动脚本的时候有执行一些自定义变量,所以我们在这里unset一下

    git pull origin ceshi                        //这个当然就是更新了 因为我创建了个ceshi的分支,这个可以更改为你们要同步的分支

  • 相关阅读:
    [leetcode-135-Candy]
    [leetcode-151-Reverse Words in a String]
    [leetcode-139-Word Break]
    [leetcode-129-Sum Root to Leaf Numbers]
    [leetcode-143-Reorder List]
    [leetcode-141-Linked List Cycle]
    oracle 环境变量(中文显示乱码)
    Oracle 自增长id
    Spring.net 事件的注入
    Spirng.net 替换任意方法
  • 原文地址:https://www.cnblogs.com/chinaifae/p/9993326.html
Copyright © 2020-2023  润新知