【Jpom】一款简而轻的低侵入式Java运维、监控软件

https://cdn.jsdelivr.net/gh/jiangzeyin/Jpom-site/images/jpom_logo.png

您为什么需要 Jpom

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

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

使用Jpom前

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

使用Jpom后

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

特别提醒

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

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

2.6.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

启动成功后,服务端的端口为 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

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

容器化安装

注意:容器化安装方式需要先安装docker

docker pull jpomdocker/jpom
docker volume create jpom-server-vol
docker run -d -p 2122:2122 --name jpom-server -v /etc/localtime:/etc/localtime:ro -v jpom-server-vol:/usr/local/jpom-server 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 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文件

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

演示项目

https://jpom.keepbx.cn

账号:demo
密码:jpom123

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

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

构建案例仓库代码

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

常见问题、操作说明

https://jpom.io/docs/

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

名词解释

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

  1. 微信公众号:CodeGzh

  2. 码云: issues

你可能感兴趣的:(【Jpom】一款简而轻的低侵入式Java运维、监控软件)