Jpom/README.md
2021-07-28 15:51:29 +00:00

268 lines
12 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<p align="center">
<a href="https://jpom.io/" target="_blank">
<img src="https://cdn.jsdelivr.net/gh/jiangzeyin/Jpom-site/images/jpom_logo.png" width="400" alt="logo">
</a>
</p>
<p align="center">
<strong>简而轻的低侵入式在线构建、自动部署、日常运维、项目监控软件</strong>
</p>
<p align="center">
<a target="_blank" href="https://gitee.com/dromara/Jpom">
<img src='https://img.shields.io/github/license/dromara/Jpom.svg?style=flat' alt='license'/>
</a>
<a target="_blank" href="https://gitee.com/dromara/Jpom">
<img src='https://img.shields.io/badge/JDK-1.8.0_40+-green.svg' alt='jdk'/>
</a>
<a target="_blank" href="https://travis-ci.org/dromara/Jpom">
<img src='https://travis-ci.org/dromara/Jpom.svg?branch=master' alt='travis'/>
</a>
<a target="_blank" href="https://www.codacy.com/gh/dromara/Jpom/dashboard?utm_source=github.com&amp;utm_medium=referral&amp;utm_content=dromara/Jpom&amp;utm_campaign=Badge_Grade">
<img src="https://app.codacy.com/project/badge/Grade/843b953f1446449c9a075e44ea778336" alt="codacy"/>
</a>
<img src='https://img.shields.io/badge/%E5%BE%AE%E4%BF%A1%E7%BE%A4(%E8%AF%B7%E5%A4%87%E6%B3%A8%3AJpom)-jpom66-yellowgreen.svg' alt='jpom66 请备注jpom'/>
<a target="_blank" href="https://gitee.com/dromara/Jpom">
<img src='https://gitee.com/dromara/Jpom/badge/star.svg?theme=gvp' alt='gitee star'/>
</a>
<a target="_blank" href="https://github.com/dromara/Jpom">
<img src='https://img.shields.io/badge/Github-Github-red.svg' alt='github'/>
</a>
</p>
<p align="center">
<a href="https://jpom.io/">https://jpom.io/</a> | <a href="https://jpom-site.keepbx.cn/">https://jpom-site.keepbx.cn/</a> | <a href="https://jpom.keepbx.cn/">https://jpom.keepbx.cn/</a>
</p>
#### 你为什么需要[Jpom](https://gitee.com/dromara/Jpom)
> Java 项目在实际部署运维,通用的方法是登录服务器上传新的项目包,执行相应命令管理,如果管理多个项目则重复操作上述步骤
> 此方法不足的是:
> 1. 需要每次登录服务器(专业软件)
> 2. 多个项目有多个管理命令(不易记、易混淆)
> 3. 查看项目运行状态需要再次使用命令
> 4. 同时面对多个运维都需要知道服务器密码(安全性低)
> 5. 集群项目需要挨个操作项目步骤
> 在使用Jpom后
> 1. 使用浏览器登录方便快捷管理项目
> 2. 界面形式实时查看项目运行状态以及控制台日志
> 3. 运维有对应的账号密码不需要知道服务器密码(并且有操作日志)
> 4. 集群项目使用项目分发一键搞定多机部署
> 5. 项目状态监控异常自动报警
> 6. 在线构建不用手动上传项目包
#### 项目主要功能及特点
1. 创建、修改、删除项目、Jar包管理
2. 实时查看控制台日志、备份日志、删除日志、导出日志
3. cpu、ram 监控、导出堆栈信息、查看项目进程端口、服务器状态监控
4. 多节点管理、多节点自动分发
5. 实时监控项目状态异常自动报警
6. 在线构建项目发布项目一键搞定
7. 多用户管理,用户项目权限独立(上传、删除权限可控制),完善的操作日志
8. 系统路径白名单模式,杜绝用户误操作系统文件
9. 在线管理Nginx配置、ssl证书文件
10. Tomcat状态、文件、war包在线实时管理
> 特别提醒:
> 1. 在Windows服务器中可能有部分功能因为系统特性造成兼容性问题建议在实际使用中充分测试。Linux目前兼容良好
> 2. 服务端和插件端请安装到不同目录中,切勿安装到同一目录中
> 3. 卸载Jpom插件端或者服务端先停止对应服务删除对应的程序文件、日志文件夹、数据目录文件夹即可
> 4. 构建依赖的是系统环境如果需要maven或者node需要服务端所在的服务器中有对应插件如果已经启动服务端再安装的对应环境需要通过命令行重启服务端后才生效。
#### 版本更新日志
[CHANGELOG.md](https://gitee.com/dromara/Jpom/blob/master/CHANGELOG.md)
### 一键安装linux
#### 插件端
> 安装的路径位于执行命令目录(数据、日志存放目录默认位于安装路径,如需要修改参考配置文件:[`extConfig.yml`](https://gitee.com/dromara/Jpom/blob/master/modules/agent/src/main/resources/bin/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
```
#### 服务端
> 安装的路径位于执行命令目录(数据、日志存放目录默认位于安装路径,如需要修改参考配置文件:[`extConfig.yml`](https://gitee.com/dromara/Jpom/blob/master/modules/server/src/main/resources/bin/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
```
> 特别提醒一键安装的时候注意执行命令不可在同一目录下即Server端和Agent端不可安装在同一目录下
### 下载安装
> [帮助文档](https://jpom-site.keepbx.cn/docs/#/安装使用/开始安装)
1. 下载安装包 [https://gitee.com/dromara/Jpom/attach_files](https://gitee.com/dromara/Jpom/attach_files)
2. 解压文件
3. 安装插件端( [流程说明](https://jpom-site.keepbx.cn/docs/#/安装使用/开始安装?id=安装插件端)
1. agent-x.x.x-release 目录为插件端的全部安装文件
2. 上传到对应服务器
3. 命令运行Agent.sh、Agent.bat
4. 安装服务端( [流程说明](https://jpom-site.keepbx.cn/docs/#/安装使用/开始安装?id=安装服务端)
1. server-x.x.x-release 目录为服务端的全部安装文件
2. 上传到对应服务器
3. 命令运行Server.sh、Server.bat
### 编译安装
> [帮助文档](https://jpom-site.keepbx.cn/docs/#/安装使用/开始安装)
1. 访问 [Jpom](https://gitee.com/dromara/Jpom) 的码云主页,拉取最新完整代码(建议使用master分支)
2. 切换到`web-vue`目录 执行`yarn build`进行vue项目打包(vue环境需要提前搭建和安装依赖包详情可以查看web-vue目录下README.md)
3. 进入项目目录执行:`mvn clean package`
4. 安装插件端( [流程说明](https://jpom-site.keepbx.cn/docs/#/安装使用/开始安装?id=安装插件端)
1. 查看插件端安装包 modules/agent/target/agent-x.x.x-release
2. 打包上传服务器运行
3. 命令运行Agent.sh、Agent.bat
5. 安装服务端( [流程说明](https://jpom-site.keepbx.cn/docs/#/安装使用/开始安装?id=安装服务端)
1. 查看插件端安装包 modules/server/target/server-x.x.x-release
2. 打包上传服务器运行
3. 命令运行Server.sh、Server.bat
### 编译运行
1. 访问 [Jpom](https://gitee.com/dromara/Jpom) 的码云主页,拉取最新完整代码(建议使用master分支、如果想体验新功能请使用dev分支)
2. 运行插件端
1. 运行`io.jpom.JpomAgentApplication`
2. 注意控制台打印的默认账号密码信息
3. 默认运行端口:`2123`
3. 运行服务端
1. 运行`io.jpom.JpomServerApplication`
2. 默认运行端口:`2122`
4. 构建vue页面 切换到`web-vue`目录前提需要本地开发环境有node、yarn环境
5. 安装项目vue依赖 控制台执行 `yarn install`
6. 启动开发模式 控制台执行 `yarn serve`
7. 根据控制台输出的地址访问前端页面 例如`http://localhost:3000/`
### 管理命令
1. windows中Agent.bat 、Server.bat
```
# 服务端
Server.bat 启动管理面板(按照面板提示输入操作)
# 插件端
Agent.bat 启动管理面板(按照面板提示输入操作)
```
2. 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`](https://gitee.com/dromara/Jpom/blob/master/modules/agent/src/main/resources/bin/extConfig.yml)
2. 服务端示例:[`extConfig.yml`](https://gitee.com/dromara/Jpom/blob/master/modules/server/src/main/resources/bin/extConfig.yml)
### 演示项目
[https://jpom.keepbx.cn](https://jpom.keepbx.cn)
```
账号demo
密码demo123
```
> 演示系统有部分功能做了限制,完整功能请自行部署体验
> 如果出现登录不上,请联系我们,联系方式在最底部
1. [Jboot案例代码](https://gitee.com/keepbx/Jpom-demo-case/tree/master/jboot-test)
2. [SpringBoot案例代码(ClassPath)](https://gitee.com/keepbx/Jpom-demo-case/tree/master/springboot-test)
3. [SpringBoot案例代码(Jar)](https://gitee.com/keepbx/Jpom-demo-case/tree/master/springboot-test-jar)
### 常见问题、操作说明
[https://jpom-site.keepbx.cn/docs/](https://jpom-site.keepbx.cn/docs/)
[https://jpom-site.keepbx.cn/docs/#/FQA/FQA](https://jpom-site.keepbx.cn/docs/#/FQA/FQA)
[Jpom 插件开发](https://gitee.com/keepbx/Jpom-Plugin)
### 交流讨论 、提供bug反馈或建议
1. 微信群二维码添加小助手备注Jpom 进群)
![Alt text](https://cdn.jsdelivr.net/gh/jiangzeyin/Jpom-site/images/wx_qrcode.jpg)
2. 微信公众号:[CodeGzh](https://cdn.jsdelivr.net/gh/jiangzeyin/Jpom-site/docs/images/CodeGzh-QrCode.jpg) 查看一些基础教程
3. 码云: [issues](https://gitee.com/dromara/Jpom/issues)
4. [码云赞赏: 在码云仓库项目首页下方捐赠、打赏](https://gitee.com/dromara/Jpom)
5. 微信赞赏
![微信赞赏](https://cdn.jsdelivr.net/gh/jiangzeyin/Jpom-site/images/wx_praise_small.png)
### 精品项目推荐
|项目名称 | 项目地址 | 项目介绍 |
|---|---|---|
| SpringBoot_v2 | [https://gitee.com/bdj/SpringBoot_v2](https://gitee.com/bdj/SpringBoot_v2) | 基于springboot的一款纯净脚手架|
| TLog GVP 项目 | [https://gitee.com/dromara/TLog](https://gitee.com/dromara/TLog) | 一个轻量级的分布式日志标记追踪神器10分钟即可接入自动对日志打标签完成微服务的链路追踪 |
| Sa-Token | [https://gitee.com/dromara/sa-token](https://gitee.com/dromara/sa-token) | 这可能是史上功能最全的 Java 权限认证框架! |
| Erupt | [https://gitee.com/erupt/erupt](https://gitee.com/erupt/erupt) | 零前端代码,纯注解开发 admin 管理后台 |
### giteye
[![Giteye chart](https://chart.giteye.net/gitee/dromara/Jpom/N4VGB7ZB.png)](https://giteye.net/chart/N4VGB7ZB)