stcaac 发表于 2018-1-13 11:22:25

git服务器搭建post-receive 钩子部署服务端代码

  一、git服务器搭建(服务器用户:root)
  安装git
  

$ apt-get install git  

  创建git用户
  

$ adduser git  $ passwd git//修改git用户密码
  

  创建git仓库
  

$ cd /home  $ mkdir git
  $ mkdir ./git/.ssh
  $ touch
./git/.ssh/authorized_keys  $ cd /home/git
  $ git init --bare test.git    //初始化仓库
  $ chown -R git:git ../git
  

  

  使用git用户生成git密钥(把客户端的公钥(id_rsa.pb文件内容)添加到authorized_keys文件,git push操作就不需要每次都输入密码了)
  

$ sudo -u git ssh-keygen -t rsa -C “test@qq.com”   //生成密钥  $ cd /home/git/.ssh

  $ cat>  

  创建web目录
  

$ cd /home  $ git clone ssh://git@127.0.0.1/home/git/test.git   //因为我的web服务器与git服务器是同一台主机所以使用127.0.0.1,如果不是放在同一台主机的请使用公网ip
  $ chown -R git:git test    //test目录拥有设为git(如果test有其他的拥有者,可以把git加入其目录拥有者的组)
  

  1. 编写自动更新钩子
  

$ cd /home/git/test.git/hooks/  $ vim post-receive
  

  

// /home/git/test.git/hooks/post-receive文件路径  #!/bin/sh
  
cd /home/test/
  
unset GIT_DIR    //清空git的工作目录,git才可以进入/home/test/工作目录(没有使用该代码,报错:remote: fatal: Not a git repository: '.')
  
git config --list
  
git pull origin master
  

  给钩子文件添加执行权限
  

$ cd /home/git/test.git/hooks/  $ chmod +x post-recevie//给钩子文件添加执行权限
  

  二、以上步骤完成git服务器就已经搭建好了,下面来讲一下客户端的使用操作
  首先生成客户端密钥,且把公钥复制到authorized_keys文件里
  

$ ssh-keygen -t rsa -C “test@qq.com”   //生成密钥  
$ cat /userdir/.ssh/id_rsa.pub    // 把显示的内容复制到服务端的authorized_keys文件里
  

  然后把git仓库拷贝下来
  

$ git clone ssh://git@123.456.78.9/home/git/test.git  

  测试操作(git push完成后git自动对web目录做git pull操作)
  

$ cd test  
$ git pull origin master
  

$ touch test.txt  
$ git add .
  
$ git commit
-m'test'  
$ git push origin master
  
页: [1]
查看完整版本: git服务器搭建post-receive 钩子部署服务端代码