Jpom/README.md
2021-12-02 18:38:10 +08:00

13 KiB
Raw Blame History

logo

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

license jdk travis codacy jpom66 请备注jpom gitee star github

https://jpom.io/ | https://jpom-site.keepbx.cn/ | https://jpom.keepbx.cn/

你为什么需要 Jpom

Java 项目在实际部署运维,通用的方法是登录服务器上传新的项目包,执行相应命令管理,如果管理多个项目则重复操作上述步骤

此方法不足的是:

  1. 需要每次登录服务器(专业软件)
  2. 多个项目有多个管理命令(不易记、易混淆)
  3. 查看项目运行状态需要再次使用命令
  4. 同时面对多个运维都需要知道服务器密码(安全性低)
  5. 集群项目需要挨个操作项目步骤

在使用Jpom后

  1. 使用浏览器登录方便快捷管理项目
  2. 界面形式实时查看项目运行状态以及控制台日志
  3. 运维有对应的账号密码不需要知道服务器密码(并且有操作日志)
  4. 集群项目使用项目分发一键搞定多机部署
  5. 项目状态监控异常自动报警
  6. 在线构建不用手动上传项目包

项目主要功能及特点

  1. 创建、修改、删除项目、Jar包管理
  2. 实时查看控制台日志、备份日志、删除日志、导出日志
  3. 在线构建项目发布项目一键搞定
  4. 多节点管理、多节点自动分发
  5. 在线 SSH 终端,并且有终端日志和禁用命令
  6. 实时监控项目状态异常自动报警
  7. cpu、ram 监控、(已经取消该功能) 导出堆栈信息、查看项目进程端口、服务器状态监控
  8. 多用户管理,用户项目权限独立(上传、删除权限可控制),完善的操作日志
  9. 系统路径白名单模式,杜绝用户误操作系统文件
  10. 在线管理 Nginx 配置文件、ssl 证书文件
  11. Tomcat状态、文件、war包在线实时管理 (不再长期维护)

特别提醒:

  1. 在 Windows 服务器中可能有部分功能因为系统特性造成兼容性问题建议在实际使用中充分测试。Linux 目前兼容良好
  2. 服务端和插件端请安装到不同目录中,切勿安装到同一目录中
  3. 卸载 Jpom 插件端或者服务端,先停止对应服务,删除对应的程序文件、日志文件夹、数据目录文件夹即可
  4. 构建依赖的是系统环境,如果需要 maven 或者 node 需要服务端所在的服务器中有对应插件,如果已经启动服务端再安装的对应环境需要通过命令行重启服务端后才生效。

升级 2.7.x 后不建议降级操作,会涉及到数据不兼容到情况

2.6.x "稳定版" 分支

版本更新日志

CHANGELOG.md

一键安装Linux推荐

插件端

如果服务端也需要被管理,在服务端上也需要安装插件端

安装的路径位于执行命令目录(数据、日志存放目录默认位于安装路径,如需要修改参考配置文件: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

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

服务端

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

如果需要修改数据、日志存储路径请参照 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

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

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

如无法访问,检查下是否开启了防火墙systemctl status firewalld,如状态显示为绿色Active: active (running)可临时关闭防火墙systemctl stop firewalld,然后重启防火墙firewall-cmd --reload(建议仅测试环境下使用,生产环境下慎用) 如关闭防火墙后仍无法访问,并且使用的是云服务器,还需要到云服务器管理后台中关闭防火墙

下载安装

帮助文档

  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 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 快速打包

编译运行

  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 serve
  7. 根据控制台输出的地址访问前端页面 例如http://127.0.0.1:3000/

管理命令

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

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

windows 中执行启动后需要根据日志取跟进启动的状态

  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文件

  1. 插件端示例:extConfig.yml
  2. 服务端示例:extConfig.yml

演示项目

https://jpom.keepbx.cn

账号demo
密码demo123

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

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

  1. Jboot案例代码
  2. SpringBoot案例代码(ClassPath)
  3. SpringBoot案例代码(Jar)

常见问题、操作说明

https://jpom-site.keepbx.cn/docs/

https://jpom-site.keepbx.cn/docs/#/FQA/FQA

Jpom 插件开发

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

  1. 微信群二维码添加小助手备注Jpom 进群)

Alt text

  1. 微信公众号:CodeGzh 查看一些基础教程

  2. 码云: issues

  3. 码云赞赏: 在码云仓库项目首页下方捐赠、打赏

  4. 微信赞赏 赞赏记录

微信赞赏

精品项目推荐

项目名称 项目地址 项目介绍
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 管理后台

giteye

Giteye chart