webhook开发环境部署
来源:互联网 发布:python做网页 编辑:程序博客网 时间:2024/06/06 00:56
webhook 高大上的开发环境部署
- . * . * . *
部署公钥 –程序员电脑及测试环境都需要部署公钥
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操作
阅读全文
0 0
- webhook开发环境部署
- 打造jenkins+docker+nodejs项目的自动部署环境(webhook)
- webhook 挂钩自动部署
- git webhook 代码自动部署
- jenkins+gitlab+webhook自动部署
- Webhook 实践 —— 自动部署
- Line-bot Webhook 创建与部署
- php实现webhook自动部署代码
- PHP 结合 WebHook 实现代码自动部署
- gogs结合git-webhook自动部署
- php项目自动部署(利用webhook)
- Webhook 实践 —— 自动部署
- Grails环境部署开发
- java开发环境部署
- Android 开发环境部署
- PHP开发环境部署
- openstack开发部署环境
- Linux开发环境部署
- IntelliJ IDEA的安装和使用
- Native JsBridge源码解析 深入理解JsBridge
- UVAlive 3890&Poj3525 半平面交+二分 解题报告
- 机房收费系统(三)组合查询
- Sqoop
- webhook开发环境部署
- 使用 Netty 搭建消息中心
- 组合数取模(-)
- linux运行级别
- c# 获取当前运行程序文件,函数,行号
- [LintCode]53.翻转字符串
- jQuery源码学习笔记系列(一)
- hdu6153 A Secret CCPC1004 扩展KMP
- 开源软件项目常用版本号标识