WebHook 自动化部署和运维工具 git-webhook

Git WebHook

一个使用 Python Flask + SQLAchemy + Celery + Redis + React 开发的用于迅速搭建并使用 WebHook 进行自动化部署和运维系统,支持:Github / GitLab / GitOsc。

  • 技术栈简单,部署容易;
  • 代码简洁易懂,二次开发毫无压力;
  • 支持 Github / GitLab / GitOsc;
  • 使用 SSH 方式,支持多服务配置;

Online DEMO Website: http://webhook.hust.cc/,使用 gunicorn + gevent + ngxin 部署。

一、如何使用 ?

1.下载本项目代码:


  1. git clone git@github.com:NetEaseGame/git-webhook.git 

2.安装 Python 依赖


  1. pip install -r requirements.txt 

3.配置 config.py 拷贝一份 config_example.py 到同目录 config.py, 然后对应修改配置内容。主要需要配置三点:

  • DATABASE_URI: 数据库地址,理论上可以使用任何关系数据库;推荐使用 sqlite 和 mysql (经过测试);
  • CELERY REDIS: Redis URI 配置,主要用于 Celery 后台任务;
  • GITHUB: GitHub 登陆配置,可以到 OAuth applications 自行申请,登陆 Callback 地址为: your_domain/github/callback.

4.初始化数据库结构


  1. python scripts.py build_db 

5.运行应用


  1. python run_webhook.py 

运行之后,打开 http://127.0.0.1:18340 即可访问。使用 GitHub 账号登陆。

添加WebHook 在工具中添加 Git 项目,获得 WebHook URL,并填写到 Github / GitLab / OscGit 的 WebHook 配置中。

三、效果预览

  • 首页

  • WebHook列表

  • 服务器列表

  • WebHook 历史记录

四、部署

代码使用 Flask 框架开发,线上部署使用 gunicorn + gevent + nginx 已经是比较成熟的方案了,本应用当然也可以使用这种方式部署。

主要的服务器依赖环境:

  • 数据库环境(自行选择,推荐 mysql 和 sqlite);
  • Redis,利用 Celery 做后台任务;

五、贡献

项目使用 SSH 私钥的方式,直接登陆 Linux 服务器,执行部署或者运维的 Shell 命令,安全可靠,当然因为涉及到私钥,所以为了安全起见,建议在内网搭建使用(这些是我们的使用情景)。

后端开发使用:Python Flask + SQLAchemy + Celery + Redis,常规的技术栈;

前端开发使用 React + Webpack,并没有使用其他消息通信框架。

所以整体项目代码非常简单,大部分都能够修改和更新代码,并提交 Pull Request,目前系统 TODO 包括,我个人也将注意完善:

  • Celery 进程情况显示(当 Celery 进程没有执行的时候,在页面上提示,类似于 Sentry);
  • 系统状态和统计(任务队列实时情况,WebHook 执行的统计图表);
  • 发布为 pip 包,使得安装部署更加容易;
  • Document 使用文档 & 帮助文档;

本文作者:佚名

来源:51CTO

时间: 2024-12-31 02:28:42

WebHook 自动化部署和运维工具 git-webhook的相关文章

基于YARN与Docker实现分布式Web服务的自动化部署运维工具

问题描述 部署运维工具主要有以下需求:-面向服务实例LTS类业务组件,不考虑数据库.缓存等基础组件-实现对这些分布式服务进行自动化部署.启停与伸缩-要能够支持自动部署与固定部署混合-自动部署,不指定主机,不指定端口-服务实例分配允许指定主机范围-固定部署,指定主机与端口,匹配传统需求-服务实例服务注册与查询-服务日志存储日志收集需求-数据存储共享存储需求挂共享存储-其他需求,配置界面与监控界面各位大神有没有实现思路与案例? 解决方案

通过IBM平台加强自动化部署能力

引入 IBM 的自动化部署和发布工具,展示其设计理念和产品架构,以及对于持续交付的支持等.同时,通过产品安装和配置介绍,希望能对读者或企业进行持续交付的调研和尝试带来切实的指导. IBM Rational 几十年来一直致力于软件交付解决方案的研究,十分关注从需求收集.软件/系统建模.协作化开发.测试到上线的整个软件交付生命周期.在开发与测试领域,Rational 指导并支持了众多企业去实践业界的最佳实践,比如开发维度的每日构建.持续集成,测试维度的需求驱动测试等.随着市场和业务的变化,持续交付的

从 Java 应用部署方式看 IT 思潮——从开发和运维到开发自运维

前些日子,我还在西溪园区上班的时候,如果不是忙得不可开交,我都会在午饭的时候尽可能选择一个离所在办公楼远一些的食堂吃饭.因为午餐和晚餐是一天的工作中难得的两个「放风」时间,如果碰到了有趣的话题还能在路上和同事交流一二. 有一次,同事问了我一个问题:「为什么 Spring Boot 应用倾向于打 fat jar 直接启动,而集团的应用倾向于打 war 包从应用容器启动?」当时我从 IT 主流思潮的角度给了一个解释,大意为 Spring Boot 是 DevOps 时代的产物,集团大多数应用是 De

上线:准备和部署软件包时开发和运维的角色

这篇文章里,我们会探讨开发团队.运维团队和其它相关方如何通过协作来准备一个"好"的部署软件包."好"的软件包能减少部署中出错的可能,并在需要自定义环境时提高部署的透明性. 此外,我们还会检视为何一个结构良好的部署包更易于转为自动化部署,提升生产率和可靠性,同时减少软件开发和维护生命周期中的错误和等待时间. 区分部署过程中的担忧:为什么 vs. 如何做 显而易见,部署包需要包含应用程序的所有组件.而不仅仅是你自己的二进制包--EARs,WARs之类--通常这些包由集成

自动化部署难驾驭?这篇文章分分钟拯救你的运维体系!

作者介绍 徐亮伟,江湖人称标杆徐,曾负责大规模集群架构自动化运维工作.擅长自动化运维,并且在分布式.Python自动化.云计算虚拟化等领域有较深入研究.个人博客:http://www.xuliangwei.com.   一.自动化部署代码实践   早期手动部署代码  纯手动scp上传代码. 纯手动登陆,git pull 或者svn update. 纯手动xftp上传代码. 开发发送压缩包,rz上传,解压部署代码.   缺点: 全程运维参与,占用大量时间. 如果节点多,上线速度慢. 人为失误多,目

Puppet这类降低运维难度、提高部署速度的工具越来越受到青睐

提供自动化运维管理平台的数据中心自动化初创企业Puppet Labs今天宣布获得了4000万美元的E轮融资. Puppet Labs 为企业和云提供系统管理及数据中心自动化软件.该公司的旗舰产品 Puppet 是一款开源的数据中心自动化及配置管理框架,可为系统管理员提供一个易用的平台进行透明.灵活的系统管理.有了这个平台,系统管理员进行虚拟化和云设施的安装.配置.管理将会变得更加容易.2012年,Puppet推出了自己的第一款商业版产品Puppet Enterprise.目前有超过18000家公

Linux集群和自动化维3.6 轻量级自动化运维工具Fabric介绍

3.6 轻量级自动化运维工具Fabric介绍 笔者公司目前的数据中心采用的是分布式部署方案,在全球多地都有数据中心.数据中心采用的是AWS EC2机器,在核心的数据中心里,EC2机器的数量比较多,基本上每个数据中心都在运行着几百台AWS EC2机器,而且业务繁忙的时候,会通过AWS AMI(Amazon系统映像)直接上线几十台相同业务的EC2机器,它们的机器类型.系统应用和配置文件基本上都是一模一样的,很多时候需要修改相同的配置文件和执行相同的操作,这个时候为了避免重复性的劳动就需要用到自动化运

Linux自动化运维工具之ansible(一)

运维自动化是运维发展的必然方向,同时也是一个运维工程师实现效率最大化的必然选择. 运维自动化的知识可以说是浩瀚如海,本文将选择其中一个工具ansible为大家介绍一下. 一.哪些工作需要批量部署 1.操作系统的安装 常见的有collber,red hat satelite(redhat)系统专用. 2.操作系统的配置 常见的有cfengine,puppet,chef,func.其中puppet最受欢迎 3.批量程序的部署 4.批量命令的运行查看状态信息 二.ansible介绍 ansible的架

自动化运维工具ansible的使用详细教程_服务器其它

一.ansible简介 1.ansible ansible是新出现的自动化运维工具,基于Python研发.糅合了众多老牌运维工具的优点实现了批量操作系统配置.批量程序的部署.批量运行命令等功能.仅需在管理工作站上安装ansible程序配置被管控主机的IP信息,被管控的主机无客户端.ansible应用程序存在于epel(第三方社区)源,依赖于很多python组件.主要包括: (1).连接插件connection plugins:负责和被监控端实现通信: (2).host inventory:指定操