python web部署_Walle - 自动化代码项目部署平台

对于一个代码项目,传统的部署方式,是在服务器安装环境,然后上传代码,进行编译和配置,最终进行启动,完成上线。然而,这种朴素的代码发布方式早已不适用了,对于多用户、多语言、多项目、多环境的项目部署场景,手动部署显然是不现实的,自然而然就诞生了许多的自动化部署平台,如 Jenkins、Travis CI 等。Walle,同样是一个自动化的代码发布平台,它更加轻量、更加人性化、配置更加自由、更符合国人需求,是代码部署的一个不错选择。

f333be92a50a9bea6310324823d3ebd6.png

Walle部署平台

简介

Walle,是 meolu 在 Github 上开源的代码项目自动化部署平台,项目位于 https://github.com/meolu/walle-web,同时维护有 Gitee 镜像 https://gitee.com/wushuiyong/walle-web,目前版本为 v2.0.1。

869154d196cf8483aafef2e8f1cfd399.png

Walle平台

Walle 支持各种 web 代码发布,包括 PHP、Java、Python 和 Go 等,可以通过 Web 后台一键完成回滚。Walle 可自由配置,更人性化、高颜值、支持 Git、多用户、多语言、多项目、多环境同时部署的开源上线部署系统。

Walle 提供了类 Gitlab 的 RESTful API、类 Gitlab 的权限模型;提供了空间管理,可以实现独立的空间资源,包括环境管理、用户组、项目和服务器等;支持灰度发布;在项目管理中,支持部署、发布的前置和后置钩子,支持自定义的全局变量;命令行界面使用 Websocket 实现,提供实时的命令行展示;提供了完善的通知机制,包括邮件和钉钉等。

225725272a01550baeb9ed5f8e17e6c4.png

Walle特性

安装

Walle 需要 Linux 系统,Python 3.5+ 和 Python 2.7+,和 MySQL 5.6.5 以上,并且需要把所有的目标主机加入到宿主机的 SSH 免密登录。安装首先下载项目代码:

git clone https://github.com/meolu/walle-web.git

然后修改服务器的 Nginx 配置:

server {    server_name  admin.walle-web.io; # 域名设置        location / {        try_files $uri $uri/ /index.html;        add_header access-control-allow-origin *;        root /walle-web/fe; # 前端代码已集成到walle-web,即walle-web/fe的绝对路径    }      location ^~ /api/ {        ...    }    location ^~ /socket.io/ {        ...    }}

并在 hosts 添加域名:

127.0.0.1  admin.walle-web.io # 与nginx配置一致

进入 Walle 代码中,对 Walle 配置进行所需的修改:

vi walle/config/settings_prod.py

对于数据库,需要新建数据库,并进行数据迁移:

mysql  -hxx -uxx -p -e'CREATE SCHEMA walle'sh admin.sh migration

完成了以上工作后,就可以进行启动:

sh admin.sh start

此时,Walle 就已经完成配置了,可以访问 http://admin.walle-web.io,初始登录账号如下:

超管:super@walle-web.io  Walle123所有者:owner@walle-web.io  Walle123负责人:master@walle-web.io  Walle123开发者:developer@walle-web.io  Walle123访客:reporter@walle-web.io  Walle123

Walle 也提供了 Docker 的安装方式,可以更为方便地进行部署。

669a446d712fb695b4831ef57f75ab0f.png

Walle项目仓库

示例

Walle 平台包括:宿主机、目标机群和操作用户,其中宿主机是 Walle 所在的机器,是代码托管与远程目标集群的纽带。

d2a3988788a7f8404cdf1332923820c1.png

Walle架构

Walle 的组件和功能包括:服务器管理、用户中心、Dashboard、部署中心、项目中心、OpenAPI、CI/CD 和 CAS 等:

305d7452d80fad303b0692129fd4cbbc.png

Walle功能

Walle 的权限角色分为:SUPER 超管、OWNER 所有者、MASTER 负责人、DEVELOPER 开发者,和 REPORTER 访客,可操作的资源包括空间、项目、上线单、环境和用户等。

a721a9a9a286a948a9095816edab7612.png

Walle权限资源

对于代码项目上线,主要流程在宿主机进行完成:

2733bbc50b46680f7ce1ba1f0b36f46b.png

上线流程

Walle 提供了项目管理的界面:

e64a225d89e98739bae1a60b61af2ffb.png

项目管理

对于单个项目,可以进行配置,设置包括名称、环境、Git 仓库、分支,和目标集群等:

2f7272d6657885bf8a21ac23f6571992.png

项目配置

还可以进行目标集群上的路径、仓库、版本保留数,以及部署排除文件、全局变量等。Walle 提供了4个任务,作为上线部署的核心配置:

  • Deploy前置任务:在宿主机未检出代码前的前置任务,常为安装依赖、配置环境变量等;
  • Deploy后置任务:在宿主机检出代码后的后置任务,常为编译、清除文件
  • Release前置任务:在目标服务器同步代码到版本库后,服务切换的前置任务,常为停服、摘机器等
  • Release后置任务:在目标服务器新版本服务切换后的后置任务,常为启动服务、启动节点

通过这4个任务的命令行命令,完成项目上线流程的实际工作。此外,还可以配置上线通知的方式,支持使用钉钉 hook 完成通知:

96897b5d507891683a9f150f4e23260d.png

项目管理 任务配置

Walle 提供了部署管理,可以进行环境的选择,可以在预设的测试、预发布和生产环境中,选择不同的配置模板完成快速上线:

a5bc90735c036a06ee12633966aea89e.png

部署管理

选择环境后,就可以创建上线单,选取分支、版本和服务器进行上线单的提交:

91675a6cb7f1230b42d78e87c3d88082.png

上线单创建

创建完成,并通过审核后,点击[开始],就可以开始进行目标集群的自动上线,按顺序执行:Deploy前置任务、Deploy、Deploy后置任务、Release前置任务、Release和 Release后置任务,并显示当前阶段和命令行输出:

63fa8d46c04b4d004e83acabda39f0bb.png

部署上线

可以管理现有的上线单:

088f39050cec55024aa8a082cc47aa15.png

上线单列表

总结

Walle 作为一个自动化代码发布平台,相对于其他项目更为轻量,且提供了更为直接和方便的管理后台,可以通过简单的图形化配置,完成代码项目在服务器上的部署上线、环境管理、版本回滚等,比较适合较为简单场景下的部署的自动化,适合运维不足的开发团队的使用。Walle 使用 Python 开发,比较容易进行二次开发,可以进行功能的裁剪和添加,以适应自身的使用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值