webhook开发环境部署

来源:互联网 发布:python做网页 编辑:程序博客网 时间:2024/06/06 00:56

webhook 高大上的开发环境部署

IP 作用 10.0.113.131 程序猿的电脑 始终在这里写代码 然后 push到git上
    . * . * . *
线上测试环境 保证webhooks能访问到 它始终从git上pull下来

部署公钥 –程序员电脑及测试环境都需要部署公钥

yum -y install  git         #如果没有安装git,执行此步骤
ssh-keygen -t rsa -b 4096 -C "915790916@qq.com"     #此处邮箱不固定,以下可能需要再改,直到能用就行cat id_coding_rsa.pub       #复制此文件内容到coding.net 项目 ->设置 ->部署公钥-------------------------------------------------------------------vi /root/.ssh/config        #编辑新文件写入以下内容Host git.coding.netUser 915790916@qq.com       #此处邮箱与上面填写的邮箱对应PreferredAuthentications publickeyIdentityFile ~/.ssh/id_rsa     #公钥文件存放路径-------------------------------------------------------------------ssh -T git@git.coding.net   #检测设置,出现 successfully 即可  

git相关操作

cd /data/wwwgit clone  地址               #将远程仓库克隆到本地git status                  #查看在哪个分支下面    git branch my               #新建my分支git branch develop          #新建develop分支git branch online           #新建online分支git branch                  #查看所有的分支      git add .                   #加入到本地仓库  git commit -a -m 'init'     #提交到版本库,在没有commit之前,在任何分支下 写的东西 属于所有的分支  也就是所有的分支都能看到        git checkout develop        git merge my            #切换到develop分支,并与my分支合并git push origin develop 

在程序猿电脑上 写一个脚本 自动切换分支并提交代码

vim auto_git.sh
#!/bin/bash  cd /data/www/91edu.com/91edu.com    #找到 有.git的目录  git checkout mygit add .git commit -a -m 'init1'git checkout developgit merge my git push origin develop git checkout my  
chmod +x auto_git.sh            #赋予脚本执行权限sh auto_git.sh  #执行脚本  

在coding.net 上配置webhooks

输入地址 http://hook.geniusbarst.cn/sync.php 保证权限正确 浏览器打开正常 才行

vi /sync.php                #每次有push的时候,就会调用这个文件

为了查看操作用户是谁,写入下面代码,看到用户之后把第二行放开,第三、四行注释

file_put_contents('date.log',date('Y-m-d h:i:s'),FILE_APPEND);          #追加方式写日志// exec('./sync.sh');               #实际工作时取消此行注释exec('whoami',$out);               #查看执行此操作的用户var_dump($out);

在浏览器中访问 http://www.geniusbarst.cn/sync.php显示 执行的用户 可能是 www apache nobody 以www为例子

vi /etc/passwd   将www用户 /sbin/nologin  改为  /bin/bash  su www      #切换为www用户重新执行上面部署公钥操作,注意存放目录不再是/root/.ssh,应该是www用户的目录,即/home/www/.ssh  一定要认真比对,确保每个细节都不出错     ssh -T git@git.coding.net    #出现 successfully 即可 ,如果不行 ,换个邮箱再来一次      chmod 600 config            #修改config权限为600cd /data/www/91edu git clone  地址          #fatal: could not create work tree dir 'test'.: Permission denied        这一步有可能会报上述错误,是因为当前用户在当前文件夹没有写权限,切换回root用户改变一下文件夹权限就好了

编写脚本,自动执行pull操作

vi sync.sh     
#!/bin/bash/usr/bin/git pull origin develop 2>>error.log       #自动pull操作并写日志

过程中最复杂的应该是www用户那一步,找到用户以后还要给予其权限,这一步过了就很简单了。

成功以后每次提交要手动执行一次auto_git.sh文件,下一篇会介绍一种更快捷的方式,通过sublime的快捷键实现push操作

原创粉丝点击