AutoMaticDeployment---自动部署

项目简介

使用Github的webhooks进行代码的自动化部署

本项目是个人最近搞的一个小工具,自己最近在用hexo部署个人博客(地址:http://www.gongsir.club/blog
部署完成之后,ui感觉还不错,于是自己就写了几篇文章发布上去,但是就遇到一个问题:
我每次写完博客,然后hexo g -d之后,代码会自动提交到github上面(https://github.com/gongsir0630/blog.git
这时,通过 https://gongsir0630.github.io/blog 自然可以访问到,但是因为速度慢,我将网站部署在自己
的服务器上,使用nginx部署静态项目,这就意味着我每次需要去服务器重新从github拉取最新代码,以此更
新网站。那这样太繁琐了,我不想每次都去手动更新代码,于是借助github(gitee也提供了)的webhooks,
搭建了一个自动部署:
webhooks可以在每次收到push之后向一个指定的url发送一个post请求,此项目正是基于此产生的,通过post
请求触发服务器执行一个脚本(或者执行linux命令),自动从github拉取代码,并更新nginx,这样就可以实
现网站自动更新。

技术栈

  • Java编程
  • SpringBoot

使用说明

项目地址:https://gitee.com/gongsir0630/AutomaticDeployment

1、克隆代码到本地或者服务器,修改端口号,编译打包:
编辑src/main/resources下的application.properties文件,修改端口号,然后使用maven命令编译打包

1mvn clean install -Dmaven.test.skip=true

2、后台运行项目:

1nohup java -jar AutomaticDeployment.jar > AutomaticDeployment.out 2>&1 &

3、访问http://{your_website}:{port}/hello,显示“hello”表示部署成功

4、配置webhooks(以github为例):
在项目的settings页面,点击左侧webhook选项,点击new新建webhooks,填写url,并在url拼接需要执行
的shell脚本的位置:


mark

配置url:http://{your_website}:{port}/linux/exec?cmd={cmd}&secret={secret}

参数说明:

其中cmd表示需要执行的shell脚本的位置:/root/xxx/update.sh:

 1echo "========== 开始执行home.sh脚本 =========="
2echo "进入blog所在目录"
3cd /usr/local/nginx/html/blog
4## 拉取最新代码
5echo "从github拉取最新代码"
6git pull
7## 重启nginx
8echo "重启nginx"
9../../sbin/nginx -s reload
10## 打印提示语句
11echo "========== 网站更新完成 =========="

secret表示自定义密码,这里需要和代码一致(默认:gongsir0630),以此验证用户身份,
如需修改,请编辑src/main/java/club.gongsir.linux.controller.DemoController中exec方法的secret字符串:


mark

5、保存webhooks配置即可,这样当仓库的代码更新之后,就会自动发post请求以触发shell脚本的执行。

6、执行成功返回:


mark

后期更新

使用github的secret签名完成用户身份验证

联系我

个人主页(含联系方式):http://www.gongsir.club

使用webhooks进行代码的自动化部署的更多相关文章

  1. 使用 GitHub / GitLab 的 Webhooks 进行网站自动化部署

    老早就想写这个话题了,今天正好有机会研究了一下 git 的自动化部署.最终做到的效果就是,每当有新的 commit push 到 master 分支的时候,就自动在测试/生产服务器上进行 git pu ...

  2. 持续集成+自动化部署[代码流水线管理及Jenkins和gitlab集成]

    转载:https://www.abcdocker.com/abcdocker/2065 一.代码流水线管理 Pipeline名词顾名思义就是流水线的意思,因为公司可能会有很多项目.如果使用jenkin ...

  3. Gitlab配置webhooks实现自动化部署

    Gitlab 自动化部署 原理介绍 配置gitlab当push动作的时候,访问服务器上的一个链接比如www.shenke.group/hook.php hook.php里面写着一行代码,会让服务器gi ...

  4. 持续集成与自动化部署---代码流水线管理及Jenkins和gitlab集成

    1.代码流水线管理 Pipeline名词顾名思义就是流水线的意思,因为公司可能会有很多项目.如果使用jenkins构建完成后,开发构建项目需要一项一项点击,比较麻烦.所以出现pipeline名词. 代 ...

  5. 通过shell脚本实现代码自动化部署

    通过shell脚本实现代码自动化部署 一.传统部署方式及优缺点 1.传统部署方式 (1)纯手工scp (2)纯手工登录git pull.svn update (3)纯手工xftp往上拉 (4)开发给打 ...

  6. 持续集成之⑤:jenkins结合脚本实现代码自动化部署及一键回滚至上一版本

    持续集成之⑤:jenkins结合脚本实现代码自动化部署及一键回滚至上一版本 一:本文通过jenkins调用shell脚本的的方式完成从Git服务器获取代码.打包.部署到web服务器.将web服务器从负 ...

  7. AWS DevOps – 配合Jenkins和CodeDeploy实现代码自动化部署

    AWS DevOps – 配合Jenkins和CodeDeploy实现代码自动化部署 Amazon ElastiCache 连接至 Redis 节点 通过 AWS Command Line Inter ...

  8. Jenkins自动化部署代码

    通过jenkins自动化部署项目代码可以大幅度节省打包上传部署的时间,提高开发测试的工作效率 ========== 完美的分割线 =========== 1.Jenkins是什么 1)Jenkins是 ...

  9. jenkins结合脚本实现代码自动化部署及一键回滚至上一版本

    持续集成之⑤:jenkins结合脚本实现代码自动化部署及一键回滚至上一版本 一:本文通过jenkins调用shell脚本的的方式完成从Git服务器获取代码.打包.部署到web服务器.将web服务器从负 ...

随机推荐

  1. HTML标签学习总结(2)

    点我:HTLM标签学习总结(1) 11. 在网页制作过程过中,可以把一些独立的逻辑部分划分出来,放在一个<div>标签中,这个<div>标签的作用就相当于一个容器. 语法: & ...

  2. Win10+WSL2+Ubuntu 18.04(WSL下)+VS Code(Win10下)+TexLive 2019(Ubuntu下)安装和配置

    本人手头电脑是Win10 Home版全新安装的系统,由于不想在新系统盘里面安装TexLive导致固态硬盘不断扩大,所以,考虑安装Ubuntu做为WSL,然后把TexLive安装在Ubuntu,并通过V ...

  3. 造轮子系列(三): 一个简单快速的html虚拟语法树(AST)解析器

    前言 虚拟语法树(Abstract Syntax Tree, AST)是解释器/编译器进行语法分析的基础, 也是众多前端编译工具的基础工具, 比如webpack, postcss, less等. 对于 ...

  4. 关于Sprites的一些理解

    今天做测试,遇到一道选择题. 瞬间一脸懵逼,sprites是什么?通过对各选项的分析,大致明白了几点:1.它是css属性.2.它与图片有关.3.它是背景图片.然后就选了一个大概不靠谱的,成功的选错了. ...

  5. 天坑,CSS之定位Position(六分之五)

    Position定位 个人觉得position这个属性真的算是CSS的见面杀了.尤其是absolute,当年可是被虐的不轻.当然了,现在爱上了这个属性,谁用谁知道. position属性 positi ...

  6. 前端javascript知识(二)

    documen.write和 innerHTML的区别 document.write只能重绘整个页面 innerHTML可以重绘页面的一部分 浏览器检测通过什么? (1) navigator.user ...

  7. vue 点击跳转路由设置

    刚接触 知道有两种方法,一种是用路由,一种是原生js的 <a @click="handleClick"></a> methods:function(){ h ...

  8. 用反射机制和pandas,实现excel数据的读取以及参数化${arg}的赋值

    反射类:class GetData: index = pd.read_excel(file_name, sheet_name).loc[0, ['index']].values[0] email = ...

  9. 027.掌握Service-Ingress使用

    一 Ingress简介 1.1 Ingress 通常Service的表现形式为IP:Port,即工作在TCP/IP层. 对于基于HTTP的服务来说,不同的URL地址经常对应到不同的后端服务(RS)或者 ...

  10. vue的computed计算属性

    computed可定义一些函数,这些函数叫做[计算属性] 只要data里面的数据发生变化computed会同步改变 引用[计算属性]时不要加  () ,应当普通属性使用 例:console.log(t ...