/Jpom

简而轻的低侵入式在线构建、自动部署、日常运维、项目监控软件

Primary LanguageJavaMIT LicenseMIT

logo

简而轻的低侵入式在线构建、自动部署、日常运维、项目监控软件

gitee star github star license jdk

travis codacy jpom66 请备注jpom

👉 https://jpom.io/ | https://demo.jpom.io/👈

备用地址:https://jpom-site.keepbx.cn/ | https://jpom.keepbx.cn/

📚 您为什么需要 Jpom

项目部署运维时,通用的方法是登录服务器,上传新的项目包,备份现有版本,执行相应命令。如果管理多个项目则重复操作上述步骤。不同项目亦存在不同的命令处理。项目运行状态无法掌握等.

在中小团队中或者没有专业运维的公司(开发兼运维工作),暂时不便引入复杂的 CI/CD 工具时使用 Jpom 轻量化、低侵入的过度

👴 使用Jpom前

  1. 登录服务器(专业软件:RDP、SSH等)
  2. 不同项目有不同管理命令(不易记、易混淆)
  3. 查看项目运行状态需要再次使用命令
  4. 服务器密码分发混乱(安全性低)
  5. 集群项目需要挨个操作项目步骤

🎁 使用Jpom后

  1. 使用浏览器登录方便快捷管理项目
  2. 方便的用户管理
    1. 用户操作监控,监控指定用户指定操作以邮件形式通知
    2. 多用户管理,用户项目权限独立(上传、删除权限可控制),完善的操作日志,使用工作空间隔离权限
    3. 账号可以开启 MFA 两步验证提高账号安全性
  3. 界面形式实时查看项目运行状态、控制台日志、管理项目文件
    1. 在线修改项目文本文件
  4. docker 容器管理、docker swarm 集群管理
  5. 在线 SSH 终端,让您在没有 Xshell、FianlShell 等软件也能轻松管理服务器
    1. 运维登录 Jpom 系统后不需要知道服务器密码
    2. 能指定 ssh 禁止执行命令,避免执行高风险命令, 并且能自动执行命令日志
    3. 设置文件目录,在线查看管理对应项目文件及配置文件
    4. SSH 命令模版在线执行脚本还能定时执行
    5. 在线修改文本文件
    6. 轻量的实现了简单的"堡垒机"功能
  6. 使用项目分发一键搞定集群项目多机部署
  7. 在线构建不用手动更新升级项目
    1. 支持拉取 GIT、SVN 仓库
    2. 支持容器构建(docker)
    3. 支持 ssh 方式发布
    4. 支持定时构建
    5. 支持 webhook 形式触发构建
  8. 支持在线编辑 nginx 配置文件并自动 reload等操作
    1. 管理 nginx 状态,管理 ssl 证书
  9. 项目状态监控异常自动报警、自动尝试重启
    1. 支持邮件+钉钉群+微信群通知,主动感知项目运行状况
  10. 节点脚本模版+定时执行,拓展更多可能
  11. 重要路径白名单模式,杜绝用户误操作系统文件

🔔️ 特别提醒

  1. 在 Windows 服务器中可能有部分功能因为系统特性造成兼容性问题,建议在实际使用中充分测试。Linux 目前兼容良好
  2. 服务端和插件端请安装到不同目录中,切勿安装到同一目录中
  3. 卸载 Jpom 插件端或者服务端,先停止对应服务,删除对应的程序文件、日志文件夹、数据目录文件夹即可
  4. 本地构建依赖的是系统环境,如果需要 maven 或者 node 需要服务端所在的服务器中有对应插件,如果已经启动服务端再安装的对应环境需要通过命令行重启服务端后才生效。
  5. 在Ubuntu/Debian服务器作为插件端可能会添加失败,请在当前用户的根目录创建 .bash_profile 文件
  6. 升级 2.7.x 后不建议降级操作,会涉及到数据不兼容到情况

升级前必看:CHANGELOG.md

📥 一键安装(Linux)(推荐)

服务端

安装的路径位于执行命令目录(数据、日志存放目录默认位于安装路径,如需要修改参考配置文件:extConfig.yml

⚠️ 特别提醒:一键安装的时候注意执行命令不可在同一目录下,即Server端和Agent端不可安装在同一目录下

如果需要修改数据、日志存储路径请参照 extConfig.yml 文件中 jpom.path 配置属性

yum install -y wget && \
	wget -O install.sh https://dromara.gitee.io/jpom/docs/install.sh && \
	bash install.sh Server

# 备用地址
yum install -y wget && \
	wget -O install.sh https://cdn.jsdelivr.net/gh/dromara/Jpom/docs/install.sh && \
	bash install.sh Server

支持自动安装jdk环境
yum install -y wget && \
	wget -O install.sh https://dromara.gitee.io/jpom/docs/install.sh && \
	bash install.sh Server jdk

# 支持自动安装jdk和maven环境
yum install -y wget && \
	wget -O install.sh https://dromara.gitee.io/jpom/docs/install.sh && \
	bash install.sh Server jdk+mvn

# ubuntu
apt install -y wget && \
	wget -O install.sh https://dromara.gitee.io/jpom/docs/install.sh && \
	bash install.sh Server jdk

启动成功后,服务端的端口为 2122 访问管理页面 例如http://127.0.0.1:2122/

如无法访问,检查下是否开启了防火墙systemctl status firewalld,如状态显示为绿色Active: active (running)可临时关闭防火墙systemctl stop firewalld,然后重启防火墙firewall-cmd --reload(建议仅测试环境下使用,生产环境下慎用建议使用规则放行)

如关闭防火墙后仍无法访问,并且使用的是云服务器,还需要到云服务器管理后台中检查安全组规则(关闭防火墙)

⚠️ 注意: linux 系统中防火墙可能存在多种:Firewall、Iptables,再检查防火墙配置时候需要都检查一下

插件端

如果服务端也需要被管理,在服务端上也需要安装插件端(同一个服务器中可以安装服务端和插件端)

⚠️ 特别提醒:一键安装的时候注意执行命令不可在同一目录下,即Server端和Agent端不可安装在同一目录下

安装的路径位于执行命令目录(数据、日志存放目录默认位于安装路径,如需要修改参考配置文件:extConfig.yml

yum install -y wget && \
	wget -O install.sh https://dromara.gitee.io/jpom/docs/install.sh && \
	bash install.sh Agent

# 备用地址
yum install -y wget && \
	wget -O install.sh https://cdn.jsdelivr.net/gh/dromara/Jpom/docs/install.sh && \
	bash install.sh Agent

# 支持自动安装jdk环境
yum install -y wget && \
	wget -O install.sh https://dromara.gitee.io/jpom/docs/install.sh && \
	bash install.sh Agent jdk

# ubuntu
apt install -y wget && \
	wget -O install.sh https://dromara.gitee.io/jpom/docs/install.sh && \
	bash install.sh Agent jdk

启动成功后,插件端的端口为 2123

容器化安装

⚠️ 注意:容器化安装方式需要先安装docker,点击跳转docker安装文档

docker pull jpomdocker/jpom
docker run -d -p 2122:2122 \
	--name jpom-server \
	-v /etc/localtime:/etc/localtime:ro \
	-v /home/jpom-server/log:/usr/local/jpom-server/log \
	-v /home/jpom-server/data:/usr/local/jpom-server/data \
	jpomdocker/jpom

容器化安装仅提供服务端版。由于容器和宿主机环境隔离,而导致插件端的很多功能无法正常使用,因此对插件端容器化意义不大。

安装docker、配置镜像、自动启动、查找安装后所在目录等可参考文档https://jpom.io/docs/

下载安装

帮助文档

  1. 下载安装包 https://gitee.com/dromara/Jpom/attach_files
  2. 解压文件
  3. 安装插件端( 流程说明
    1. agent-x.x.x-release 目录为插件端的全部安装文件
    2. 上传到对应服务器
    3. 命令运行(Agent.sh、Agent.bat)出现乱码或者无法正常执行,请优先检查编码格式、换行符是否匹配
    4. 默认运行端口:2123
  4. 安装服务端( 流程说明
    1. server-x.x.x-release 目录为服务端的全部安装文件
    2. 上传到对应服务器
    3. 命令运行(Server.sh、Server.bat)出现乱码或者无法正常执行,请优先检查编码格式、换行符是否匹配
    4. 默认运行端口:2122 访问管理页面 例如http://127.0.0.1:2122/

编译安装

帮助文档

  1. 访问 Jpom 的码云主页,拉取最新完整代码(建议使用master分支)
  2. 切换到web-vue目录 执行npm install (vue环境需要提前搭建和安装依赖包详情可以查看web-vue目录下README.md)
  3. 执行npm run build进行vue项目打包(vue环境需要提前搭建和安装依赖包详情可以查看web-vue目录下README.md)
  4. 切换到项目根目录执行:mvn clean package
  5. 安装插件端( 流程说明
    1. 查看插件端安装包 modules/agent/target/agent-x.x.x-release
    2. 打包上传服务器运行
    3. 命令运行(Agent.sh、Agent.bat)出现乱码或者无法正常执行,请优先检查编码格式、换行符是否匹配
    4. 默认运行端口:2123
  6. 安装服务端( 流程说明
    1. 查看插件端安装包 modules/server/target/server-x.x.x-release
    2. 打包上传服务器运行
    3. 命令运行(Server.sh、Server.bat)出现乱码或者无法正常执行,请优先检查编码格式、换行符是否匹配
    4. 默认运行端口:2122 访问管理页面 例如http://127.0.0.1:2122/

也可以使用 script/release.bat script/release.sh 快速打包

一键启动 docker-compose

  • 无需安装任何环境,自动编译构建

需要注意修改 .env 文件中的 token 值

git clone https://gitee.com/dromara/Jpom.git
cd Jpom
docker-compose up

编译运行

  1. 访问 Jpom 的码云主页,拉取最新完整代码(建议使用master分支、如果想体验新功能请使用dev分支)
  2. 运行插件端
    1. 运行io.jpom.JpomAgentApplication
    2. 注意控制台打印的默认账号密码信息
    3. 默认运行端口:2123
  3. 运行服务端
    1. 运行io.jpom.JpomServerApplication
    2. 默认运行端口:2122
  4. 构建vue页面 切换到web-vue目录(前提需要本地开发环境有node、npm环境)
  5. 安装项目vue依赖 控制台执行 npm install
  6. 启动开发模式 控制台执行 npm run serve
  7. 根据控制台输出的地址访问前端页面 例如http://127.0.0.1:3000/

管理命令

  1. windows 中 Agent.bat 、Server.bat
# 服务端
Server.bat     启动管理面板(按照面板提示输入操作)

# 插件端
Agent.bat     启动管理面板(按照面板提示输入操作)

windows 中执行启动后需要根据日志取跟进启动的状态、如果出现乱码请检查或者修改编码格式,windows 中 bat 编码格式推荐为 GB2312

  1. linux 中 Agent.sh 、Server.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 2. 服务端示例:extConfig.yml

💻 演示项目

https://demo.jpom.io

https://jpom.keepbx.cn (备用)

账号:demo
密码:jpom123

演示系统有部分功能做了限制,完整功能请自行部署体验

如果出现登录不上,请联系我们,联系方式在最底部

构建案例仓库代码

  1. Jboot 案例代码
  2. SpringBoot 案例代码(ClassPath)
  3. SpringBoot 案例代码(Jar)
  4. node vue 案例代码(antdv)
  5. python 案例代码

nodejs 编译指定目录:

    yarn --cwd xxxx/ install
    yarn --cwd xxxx/ build

maven 编译指定目录:

    mvn -f xxxx/pom.xml clean package

📝 常见问题、操作说明

https://jpom.io/docs/

https://jpom.io/docs/#/FQA/FQA

名词解释

实践案例

里面有部分图片加载可能比较慢

  1. 本地构建 + SSH 发布 java 项目
  2. 本地构建 + 项目发布 node 项目
  3. 本地构建 + SSH 发布 node 项目
  4. 本地构建 + 自定义管理 python 项目
  5. 自定义管理 java 项目
  6. 管理编译安装的 nginx
  7. 管理 docker
  8. 容器构建 + 项目发布 java 项目

🛠️ 整体架构

jpom-func-arch

🐞 交流讨论 、提供bug反馈或建议

  1. 微信群二维码(添加小助手:备注Jpom 进群)
  2. 微信赞赏 赞赏记录
  3. 码云赞赏: 在码云仓库项目首页下方捐赠、打赏
  4. 微信公众号:CodeGzh 查看一些基础教程
  5. 码云: issues
  6. 邀请您一起贡献教程文档 文档仓库地址

wx-qrcode-praise.png

🔔 精品项目推荐

项目名称 项目地址 项目介绍
SpringBoot_v2 https://gitee.com/bdj/SpringBoot_v2 基于springboot的一款纯净脚手架
TLog GVP 项目 https://gitee.com/dromara/TLog 一个轻量级的分布式日志标记追踪神器,10分钟即可接入,自动对日志打标签完成微服务的链路追踪
Sa-Token https://gitee.com/dromara/sa-token 这可能是史上功能最全的 Java 权限认证框架!
Erupt https://gitee.com/erupt/erupt 零前端代码,纯注解开发 admin 管理后台