前言

2018年第一篇文章,没啥技术含量,权当笔记

我们一般都会用git或者svn来管理我们的代码

每次代码更新后还要手动的去把服务器上的代码也更新一遍

项目小了还好 项目大了着实浪费时间

要是服务器上的代码也能像git那样增量更新就好了

今天就说说如何通过webhook的形式来让服务器自动拉取我们push的代码

原理

现在的Git服务器一般都会有个webhook服务

什么意思呢?

就是我们在执行了push、merge等一系列的操作的时候

Git服务器会发送一个请求到我们指定的URL

并且会把此次动作的相关数据也发送过去

这里我们使用开源中国的码云演示

在帮助文档中可以看到

当我们发生push之类的操作的时候

Git服务器会像我们指定的url发送以下数据

  1. {
  2. "before": "fb32ef5812dc132ece716a05c50c7531c6dc1b4d",
  3. "after": "ac63b9ba95191a1bf79d60bc262851a66c12cda1",
  4. "ref": "refs/heads/master",
  5. "user_id": 13,
  6. "user_name": "123",
  7. "user": {
  8. "name": "123",
  9. "username": "test123",
  10. "url": "https://gitee.com/oschina"
  11. },
  12. "repository": {
  13. "name": "webhook",
  14. "url": "http://git.oschina.net/oschina/webhook",
  15. "description": "",
  16. "homepage": "https://gitee.com/oschina/webhook"
  17. },
  18. "commits": [
  19. {
  20. "id": "ac63b9ba95191a1bf79d60bc262851a66c12cda1",
  21. "message": "1234 bug fix",
  22. "timestamp": "2016-12-09T17:28:02 08:00",
  23. "url": "https://gitee.com/oschina/webhook/commit/ac63b9ba95191a1bf79d60bc262851a66c12cda1",
  24. "author": {
  25. "name": "123",
  26. "email": "123@123.com",
  27. "time": "2016-12-09T17:28:02 08:00"
  28. }
  29. }
  30. ],
  31. "total_commits_count": 1,
  32. "commits_more_than_ten": false,
  33. "project": {
  34. "name": "webhook",
  35. "path": "webhook",
  36. "url": "https://gitee.com/oschina/webhook",
  37. "git_ssh_url": "git@gitee.com:oschina/webhook.git",
  38. "git_http_url": "https://gitee.com/oschina/webhook.git",
  39. "git_svn_url": "svn://gitee.com/oschina/webhook",
  40. "namespace": "oschina",
  41. "name_with_namespace": "oschina/webhook",
  42. "path_with_namespace": "oschina/webhook",
  43. "default_branch": "master"
  44. },
  45. "hook_name": "push_hooks",
  46. "password": "pwd"
  47. }

于是乎,我们就可以拿这些数据来做做文章了

准备

  • 一个git仓库
  • 安装了web服务器与git支持的服务器

步骤

服务器篇

1.首先我们需要为www用户创建一个ssh密钥

切换到www用户下并生成一个rsa密钥

  1. su - www
  2. ssh-keygen -t rsa

密钥一般生成在 /var/www/.ssh/ 这个路径下

文件名为 id_rsa

  1. 创建一个可供Git服务器通知的页面

网站的建立这里不再敷述

文件内容如下

  1. <?php
  2. //git webhook 自动部署脚本
  3. //项目存放物理路径
  4. $path = "你的项目部署路径";
  5. $requestBody = file_get_contents("php://input");
  6. if (empty($requestBody)) {
  7. die('send fail');
  8. }
  9. $content = json_decode($requestBody, true);
  10. //若是主分支且提交数大于0
  11. if ($content['ref']=='refs/heads/master' && $content['total_commits_count']>0) {
  12. $res = shell_exec("cd {$path} && git pull 2>&1");//以www用户运行
  13. $res_log = '-------------------------'.PHP_EOL;
  14. $res_log .= $content['user_name'] . ' 在' . date('Y-m-d H:i:s') . '向' . $content['repository']['name'] . '项目的' . $content['ref'] . '分支push了' . $content['total_commits_count'] . '个commit:' . PHP_EOL;
  15. $res_log .= $res.PHP_EOL;
  16. file_put_contents("git-webhook.txt", $res_log, FILE_APPEND);//追加写入
  17. }
  18. echo '很棒:'.date('y-m-d H:i:s');

以上代码相信都可以看懂

Git发送过来的数据相当丰富

我们可以用这些数据来做些过滤来决定是否需要更新服务器上的本地代码

代码库篇

  1. 创建代码仓库

创建方法这里不在敷述

2. 添加ssh密钥

在项目管理中把上面步骤第一步中得到的ssh密钥添加到仓库的部署密钥中

这样我们的web服务器就有了拉取代码的权限

3.添加hook路径

同样在项目管理中添加webhook链接

这里可以添加一个密码,我偷懒这里没加

需要加的话可以在hook文件中添加一个验证

可以防止被恶意访问

联合

最后我们需要在我们的部署目录先把git初始化一次

  1. su - www
  2. git clone git仓库地址 项目部署地址

然后我们往git仓库中提交一次代码更新

稍等一下

如果一切正常的话我们的项目目录就会自动拉取你刚才提交的代码了


在hook路径中也有log记录

不需要的话可以把代码注释掉

php与Git下基于webhook的自动化部署的更多相关文章

  1. 基于 Jenkins Pipeline 自动化部署

    最近在公司推行Docker Swarm集群的过程中,需要用到Jenkins来做自动化部署,Jenkins实现自动化部署有很多种方案,可以直接在jenkins页面写Job,把一些操作和脚本都通过页面设置 ...

  2. [转]基于AWS的自动化部署实践

    作者 徐桂林 发布于 2014年1月22日 -------------------------------------------------------------------- 1. 背景 在过去 ...

  3. 使用Git实现Laravel项目的自动化部署

    简介 不知道大家一开始是怎么使用 git 进行开发的,反正我个人是先将代码提交到 github 仓库,然后用 SSH 登录到服务器,然后进行克隆或者版本更新.听起来就很麻烦,当然实际操作中也很麻烦,那 ...

  4. 基于AWS的自动化部署实践

    过年前,我给InfoQ写了篇文章详细介绍我们团队在过去4年基于AWS的自动化部署实践.文章包括了:为什么选择AWS.AWS上自动化部署的优势和挑战.我们的解决方案,以及和AWS DevOps方案(Op ...

  5. Jenkins+Maven+Git搭建持续集成和自动化部署的配置手记

    前言    持续集成这个概念已经成为软件开发的主流,可以更频繁的进行测试,尽早发现问题并提示.自动化部署就更不用说了,可以加快部署速度,并可以有效减少人为操作的失误.之前一直没有把这个做起来,最近的新 ...

  6. Jenkins学习总结(3)——Jenkins+Maven+Git搭建持续集成和自动化部署的

    前言 持续集成这个概念已经成为软件开发的主流,可以更频繁的进行测试,尽早发现问题并提示.自动化部署就更不用说了,可以加快部署速度,并可以有效减少人为操作的失误.之前一直没有把这个做起来,最近的新项目正 ...

  7. [自动化]基于kolla-ceph的自动化部署ceph集群

    kolla-ceph来源: 项目中的部分代码来自于kolla和kolla-ansible kolla-ceph的介绍: 1.镜像的构建很方便, 基于容器的方式部署,创建.删除方便 2.kolla-ce ...

  8. [自动化]基于kolla的自动化部署ceph集群

    kolla-ceph来源: 项目中的部分代码来自于kolla和kolla-ansible kolla-ceph的介绍: 1.镜像的构建很方便, 基于容器的方式部署,创建.删除方便 2.kolla-ce ...

  9. git 远程服务器创建项目自动化部署、克隆推送免密码

    1.用git用户 在git目录下 创建裸仓库 git init --bare project_01.git 2.在裸仓库的 hooks目录下创建 post-receive 文件775 3.post-r ...

随机推荐

  1. T&F 圆桌:儿童智能玩具离我们还有多远?

    “女人和孩子的钱是最好挣的”,这句经典的名句被很多商家奉为信条,这在现实生活中也得到了很好的印证. 各种步行街.商业街.Mall 干的做多的事情就是:围绕着女人和孩子打造创造消费点.步行街.商业街上各 ...

  2. POJ 3744 Scout YYF I 概率dp+矩阵快速幂

    题目链接: http://poj.org/problem?id=3744 Scout YYF I Time Limit: 1000MSMemory Limit: 65536K 问题描述 YYF is ...

  3. python learning Network Programming.py

    Socket # 用一个 Socke t表示"打开了一个网络连接" # 打开一个 Socket 需要知道目标计算机的IP地址和端口号,再指定协议类型即可. # TCP # 主动发起 ...

  4. vue-cli 安装步骤(转载)

    参考资料:Vue2.0 新手完全填坑攻略—从环境搭建到发布 1.Node.js安装 https://nodejs.org/en/download/ 2.安装vue-cli npm install -g ...

  5. 通过分析java heap dump解决生产问题

    最近在生产环境遇到一个问题,正常情况下,ECS CPU始终保持在10%以下,内存也只占用40%左右,但是连续2天出现了CPU占用100%的情况,然后系统卡住.看阿里云的ECS监控,能看到CPU飙到了1 ...

  6. [转帖] sqlserver CAL 授权模式下 只能够有20个core的使用问题

    http://www.cnblogs.com/diabloxl/p/3623640.html?utm_source=tuicool&utm_medium=referral 公司这边性能组老师进 ...

  7. SQLSERVER STANDARD 版本不支持内存数据库

    1. 自己负责的一个环境 安装了 SQLSERVER2014 的 标准版 发现有问题. 恢复了一个带内存数据库的性能测试库之后报错. 报错信息很不明了,但是 查了半天发现必须升级企业版才可以... 还 ...

  8. C++中sizeof操作符与strlen函数

    sizeof操作符: sizeof是一个操作符,返回一条表达式或一个类型名字所占的字节数.返回值一个常量表达式,类型为size_t. size_t sizeof(type) size_t sizeof ...

  9. 从解决一个java.lang.NoSuchMethodError想到的

    今天在发布系统部署一个web app的时候,发现应用服务器(tomcat 7.0.26)不能正常启动,于是远程登陆到服务器上查看应用服务器的启动日志,在tomcat_home的logs/localho ...

  10. Memcache介绍与应用场景

    一:概念介绍         Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像.视频.文件以及数据库检索的结果 ...