- 前言
参加过两次公司生产环境的版本更新,最近一次让我萌生了开发一个自动化部署平台的念头。虽然网上也有不少的自动化部署软件,但还是想自己动手写一个。一来是为了让平台更适应当前的实际情况,也利于以后自己对平台通用性的扩展;二来是为了锻炼自己,给自己的空闲时间找点事情做,不至于虚度时光。
以下是整理出的初稿,想到的点比较简单,后面会持续完善。
如果本文有幸被您看到,望能指点一二。
不管是积极的还是消极的,请留下您的看法。
- 背景
程序开发好之后免不了部署。刚开始还好,手动打包、上传、部署,也不需要多长时间。但是随着规模的扩大,版本更新的频繁,以上看似简单的操作会变得越来越繁琐,耗时也会程直线上升。 手动部署的所有操作还不可重用,即每次操作都需要从头开始,浪费时间不说,不可靠和易出错也是显而易见的不足。
因此,能有一套程序帮我们做这个事情势在必行。
自动化部署平台的初衷是最大化的简化部署的步骤,做到“自动化”。而人工只需要做一些简单的配置即可。
- 初步设计
部署内容:
1. Java WEB部署
2. Java进程部署
部署来源:
1. 从版本服务器进行部署
2. 程序包上传部署
部署实现方式:
1. linux下
拟采用java+shell脚本实现
2. windows下
拟采用java+bat批处理脚本实现
- 功能整理
本自动化部署平台需包含一下功能
最终目的:最大化实现只要是通过本平台进行部署的工程,都能通过平台管理其完整的生命过程。其中包括项目的创建,更新,删除,以及项目运行期间的各种日志的抓取和展示。达到部分运维的效果。
a. 从版本服务器(svn/git)上获取最新代码
b. 自动打包(jar、war)
c. 支持程序包(jar、war)的上传
d. 支持工程内部配置文件的修改
e. 根据配置或者脚本自动部署
f. 支持通过平台对部署的工程进行试运行,启用,停止等功能
g. 部署过程中的日志显示
h. 部署完后运行中的日志显示
i. 设置权限系统,不同角色的用户登录平台拥有不同的操作权限
a) 开发人员:
b) 运维人员:
c) 管理人员:
d) 测试人员:
j. 支持数据库的操作(备份/更新/创建/删除)