JpomJava 项目在线管理
Jpom是一款简而轻的低侵入式在线构建、自动部署、日常运维、项目监控软件。
日常开发中,您是否有以下痛点?
- 团队中没有专业的运维,开发还要做运维的活,需要自己手动构建、部署项目。
- 不同的项目有不同的构建、部署命令。
- 有开发、测试、生产等多环境打包的需求。
- 需要同时监控多个项目的运行状态。
- 需要下载 SSH 工具远程连接服务器。
- 需要下载 FTP 工具传输文件到服务器。
- 多台服务器时,在不同电脑之间账号密码同步不方便。
- 想使用一些自动化工具,但是对服务器性能太高,搭建太麻烦。
- 对自动化工具有个性化的需求,想自己修改项目,但是市面上的工具太复杂了。
如果是分布式的项目,以上步骤则更加繁琐。
让 Jpom 来帮你解决这些痛点吧!然而,这些只是 Jpom 解决的最基础的功能。
使用 Jpom 后
- 方便的用户管理
- 用户操作监控,监控指定用户指定操作以邮件形式通知
- 多用户管理,用户项目权限独立(上传、删除权限可控制),完善的操作日志,使用工作空间隔离权限
- 账号可以开启 MFA 两步验证提高账号安全性
- 界面形式实时查看项目运行状态、控制台日志、管理项目文件
- 在线修改项目文本文件
- Docker 容器管理、Docker swarm 集群管理(Docker ui)
- 在线 SSH 终端,让您在没有 Xshell、FinalShell 等软件也能轻松管理服务器
- 登录 Jpom 系统后不需要知道服务器密码
- 能指定 SSH 禁止执行的命令,避免执行高风险命令,并且能自动执行命令日志
- 设置文件目录,在线查看管理对应项目文件及配置文件
- SSH 命令模版在线执行脚本还能定时执行
- 在线修改文本文件
- 轻量的实现了简单的"堡垒机"功能
- 使用项目分发一键搞定集群项目多机部署
- 在线构建不用手动更新升级项目
- 支持拉取 GIT、SVN 仓库
- 支持容器构建(docker)
- 支持 SSH 方式发布
- 支持定时构建
- 支持 WebHook 形式触发构建
- 支持在线编辑 nginx 配置文件并自动 reload 等操作
- 管理 nginx 状态,管理 SSL 证书
- 项目状态监控异常自动报警、自动尝试重启
- 支持邮件 + 钉钉群 + 微信群通知,主动感知项目运行状况
- 节点脚本模版+定时执行或者触发器,拓展更多功能
- 重要路径白名单模式,杜绝用户误操作系统文件
特别提醒
- 在 Windows 服务器中可能有部分功能因为系统特性造成兼容性问题,建议在实际使用中充分测试。Linux 目前兼容性良好
- 服务端和插件端请安装到不同目录中,切勿安装到同一目录中
- 卸载 Jpom 插件端或者服务端,先停止对应服务,然后删除对应的程序文件、日志文件夹、数据目录文件夹即可
- 本地构建依赖的是系统环境,如果构建命令需要使用 maven 或者 node 需要在构建项目的服务器安装好对应的环境。如果已经启动服务端再安装的对应环境需要通过命令行重启服务端后环境才会生效。
- 在 Ubuntu/Debian 服务器作为插件端可能会添加失败,请在当前用户的根目录创建 .bash_profile 文件
- 升级 2.7.x 后不建议降级操作,会涉及到数据不兼容的情况
- 由于目前 2.x.x 版本插件端和服务端主要采用 http 协议通讯,插件端和服务端网络要求互通,在使用的时候请注意。
- Jpom 3.0 版本已经开始规划更新了,尽请期待新版本的诞生吧
版本更新日志
升级前必看:CHANGELOG.md
安装 Jpom
Jpom 支持多种安装方式,满足不同用户的个性化需求,您只需要选择一种方式安装即可。
方式一:(推荐) 一键安装(Linux)
一键安装服务端
注意:安装的目录位于执行命令的目录!
⚠️ 特别提醒:一键安装的时候注意执行命令不可在同一目录下,即 Server 端和 Agent 端不可安装在同一目录下!
如果需要修改服务端数据、日志存储的路径请修改
extConfig.yml
文件中jpom.path
配置属性。
# 仅安装服务端 yum install -y wget && \ wget -O install.sh https://jpom.top/docs/install.sh && \ bash install.sh Server # 安装服务端和 jdk 环境 yum install -y wget && \ wget -O install.sh https://jpom.top/docs/install.sh && \ bash install.sh Server jdk # 安装服务端和 jdk、maven 环境 yum install -y wget && \ wget -O install.sh https://jpom.top/docs/install.sh && \ bash install.sh Server jdk+mvn # ubuntu apt install -y wget && \ wget -O install.sh https://jpom.top/docs/install.sh && \ bash install.sh Server jdk
启动成功后,服务端的端口为 2122
,可通过 http://127.0.0.1:2122/
访问管理页面(如果不是本机访问,需要把 127.0.0.1 换成你安装的服务器 IP 地址)。
如无法访问管理系统,执行命令
systemctl status firewalld
检查下是否开启了防火墙 ,如状态栏看到绿色显示Active: active (running)
需要放行2122
端口。# 放行管理系统的 2122 端口 firewall-cmd --add-port=2122/tcp --permanent # 重启防火墙才会生效 firewall-cmd --reload如果在操作系统上放行了端口仍无法访问,并且你使用的是云服务器,请到云服务器后台中检查安全组规则是否放行 2122 端口。
注意: Linux 系统中有多种防火墙:Firewall、Iptables、SELinux 等,再检查防火墙配置时候需要都检查一下。
一键安装插件端
如果安装服务端的服务器也需要被管理,在服务端上也需要安装插件端(同一个服务器中可以同时安装服务端和插件端)
特别提醒:一键安装的时候注意执行命令不可在同一目录下,即 Server 端和 Agent 端不可安装在同一目录下!
如果需要修改插件端数据、日志存储的路径请修改
extConfig.yml
文件中jpom.path
配置属性。
# 仅安装插件端 yum install -y wget && \ wget -O install.sh https://jpom.top/docs/install.sh && \ bash install.sh Agent # 安装插件端和 jdk 环境 yum install -y wget && \ wget -O install.sh https://jpom.top/docs/install.sh && \ bash install.sh Agent jdk # ubuntu apt install -y wget && \ wget -O install.sh https://jpom.top/docs/install.sh && \ bash install.sh Agent jdk
启动成功后,插件端的端口为 2123
,插件端提供给服务端使用。
方式二:容器化安装
注意:容器化安装方式需要先安装 docker,点击跳转docker安装文档
使用挂载方式存储相关数据(在部分环境可能出现兼容性问题)
docker pull jpomdocker/jpom mkdir -p /home/jpom-server/log mkdir -p /home/jpom-server/data docker run -d -p 2122:2122 \ --name jpom-server \ -v /home/jpom-server/log:/usr/local/jpom-server/log \ -v /home/jpom-server/data:/usr/local/jpom-server/data \ jpomdocker/jpom
使用容器卷方式存储相关数据
docker pull jpomdocker/jpom docker volume create jpom-server-data docker volume create jpom-server-log docker run -d -p 2122:2122 \ --name jpom-server \ -v jpom-server-data:/usr/local/jpom-server/data \ -v jpom-server-log:/usr/local/jpom-server/log \ jpomdocker/jpom
容器化安装仅提供服务端版。由于容器和宿主机环境隔离,而导致插件端的很多功能无法正常使用,因此对插件端容器化意义不大。
安装docker、配置镜像、自动启动、查找安装后所在目录等可参考文档 https://jpom.top/pages/b63dc5/
方式三:下载安装
- 下载安装包 https://jpom.top/pages/all-downloads/
- 解压文件
- 安装插件端
- agent-x.x.x-release 目录为插件端的全部安装文件
- 上传到对应服务器(整个目录)
- 启动插件端,Windows 环境用 bat 脚本,Linux 环境用 sh 脚本。(如果出现乱码或者无法正常执行,请检查编码格式、换行符是否匹配。)
- 插件端默认运行端口:
2123
- 安装服务端
- server-x.x.x-release 目录为服务端的全部安装文件
- 上传到对应服务器(整个目录)
- 启动服务端,Windows 环境用 bat 脚本,Linux 环境用 sh 脚本。(如果出现乱码或者无法正常执行,请检查编码格式、换行符是否匹配。)
- 服务端默认运行端口:
2122
,访问管理页面:http://127.0.0.1:2122/
(非本机访问把 127.0.0.1 换成你的服务器 IP 地址)
方式四:编译安装
- 访问 Jpom 的码云主页,拉取最新完整代码(建议使用 master 分支)
- 切换到
web-vue
目录,执行npm install
(vue 环境需要提前搭建和安装依赖包详情可以查看 web-vue 目录下 README.md) - 执行
npm run build
进行 vue 项目打包 - 切换到项目根目录执行:
mvn clean package
- 安装插件端
- 查看插件端安装包 modules/agent/target/agent-x.x.x-release
- 打包上传服务器运行(整个目录)
- 启动插件端,Windows 环境用 bat 脚本,Linux 环境用 sh 脚本。(如果出现乱码或者无法正常执行,请检查编码格式、换行符是否匹配。)
- 默认运行端口:
2123
- 安装服务端
- 查看插件端安装包 modules/server/target/server-x.x.x-release
- 打包上传服务器运行(整个目录)
- 启动服务端,Windows 环境用 bat 脚本,Linux 环境用 sh 脚本。(如果出现乱码或者无法正常执行,请检查编码格式、换行符是否匹配。)
- 服务端默认运行端口:
2122
,访问管理页面:http://127.0.0.1:2122/
(非本机访问把 127.0.0.1 换成你的服务器 IP 地址)
也可以使用
script/release.bat
或script/release.sh
快速打包。
方式五:一键启动 docker-compose
- 无需安装任何环境,自动编译构建
需要注意修改
.env
文件中的 token 值
yum install -y git git clone https://gitee.com/dromara/Jpom.git cd Jpom docker-compose up
方式六:编译运行
- 访问 Jpom 的码云主页,拉取最新完整代码(建议使用 master 分支,如果想体验新功能可以使用 dev 分支)
- 运行插件端
- 运行
io.jpom.JpomAgentApplication
- 留意控制台打印的默认账号密码信息
- 插件端默认运行端口:
2123
- 运行
- 运行服务端
- 运行
io.jpom.JpomServerApplication
- 服务端默认运行端口:
2122
- 运行
- 构建 vue 页面,切换到
web-vue
目录(前提需要本地开发环境有 node、npm 环境) - 安装项目 vue 依赖,控制台执行
npm install
- 启动开发模式,控制台执行
npm run serve
- 根据控制台输出的地址访问前端页面:
http://127.0.0.1:3000/
(非本机访问把 127.0.0.1 换成你的服务器 IP 地址)
管理 Jpom 命令
- Windows 系统使用 bat 脚本文件。
# 服务端管理脚本,按照面板提示输入操作 Server.bat # 插件端管理脚本,按照面板提示输入操作 Agent.bat
Windows 系统中执行启动后需要根据日志去跟进启动的状态,如果出现乱码请检查或者修改编码格式,Windows 系统中 bat 编码格式推荐为
GB2312
- Linux 系统中使用 sh 脚本文件。
# 服务端 Server.sh start 启动Jpom服务端 Server.sh stop 停止Jpom服务端 Server.sh restart 重启Jpom服务端 Server.sh status 查看Jpom服务端运行状态 Server.sh create 创建Jpom服务端的应用服务(jpom-server) # 插件端 Agent.sh start 启动Jpom插件端 Agent.sh stop 停止Jpom插件端 Agent.sh restart 重启Jpom插件端 Agent.sh status 查看Jpom插件端运行状态 Agent.sh create 创建Jpom插件端的应用服务(jpom-agent)
Linux 服务方式管理
这里安装服务仅供参考,实际中可以根据需求自定义配置
在使用
Server.sh create
/Agent.sh create
成功后service jpom-server {status | start | stop}
service jpom-agent {status | start | stop}
Jpom 的参数配置
在项目运行的根路径下的 extConfig.yml
文件
- 插件端示例:
extConfig.yml
- 服务端示例:
extConfig.yml
演示项目
账号:demo 密码:jpom123
演示系统有部分功能做了限制,完整功能请自行部署体验
如果出现登录不上,请联系我们,联系方式在最底部
构建案例仓库代码
nodejs 编译指定目录:
yarn --cwd xxxx/ install yarn --cwd xxxx/ build
maven 编译指定目录:
mvn -f xxxx/pom.xml clean package