使用 JAR 包部署 Java 应用(以 NginxWebUI 为例)

使用 JAR 包部署 Java 应用(以 NginxWebUI 为例)

项目地址https://gitee.com/cym1102/nginxWebUI
部署方式 :源码编译(Maven) + JAR 包运行
JDK 版本 :OpenJDK 11
数据库:默认使用嵌入式 SQLite,也支持配置 MySQL

本文演示如何在 Linux 系统中通过 java -jar 方式部署 NginxWebUI ------ 一款基于 Web 的 Nginx 可视化配置与管理工具。


一、环境准备

1. 安装 OpenJDK 11 和 Nginx

bash 复制代码
yum install java-11-openjdk nginx -y

验证 Java:

bash 复制代码
java -version
# 输出应包含 "openjdk version \"11"

2. 安装 Maven(用于编译源码)

bash 复制代码
# 假设已下载 apache-maven-3.9.11-bin.tar.gz 到当前目录
tar xf apache-maven-3.9.11-bin.tar.gz -C /usr/local/
ln -sv /usr/local/apache-maven-3.9.11 /usr/local/maven

# 配置环境变量
echo 'export MAVEN_HOME=/usr/local/maven' >> /etc/profile
echo 'export PATH=$PATH:$MAVEN_HOME/bin' >> /etc/profile
source /etc/profile

# 验证 Maven
mvn -v

二、获取源码并编译生成 JAR 包

bash 复制代码
cd /data
git clone https://gitee.com/cym1102/nginxWebUI.git
cd nginxWebUI

# 切换到指定稳定版本(推荐使用发布版本)
git checkout 4.2.4

# 编译打包(跳过测试以加快构建)
mvn clean package -DskipTests

✅ 成功后,可执行 JAR 文件位于:
/data/nginxWebUI/target/nginxWebUI-4.2.4.jar


三、启动应用(运行 JAR 包)

基础命令(使用默认 SQLite 数据库)

bash 复制代码
java -jar \
  -Dfile.encoding=UTF-8 \
  /data/nginxWebUI/target/nginxWebUI-4.2.4.jar \
  --server.port=8080 \
  --project.home=/home/nginxWebUI/

可选:连接 MySQL 数据库

bash 复制代码
java -jar -Dfile.encoding=UTF-8 /data/nginxWebUI/target/nginxWebUI-4.2.4.jar \
  --server.port=8080 \
  --project.home=/home/nginxWebUI/ \
  --spring.database.type=mysql \
  --spring.datasource.url=jdbc:mysql://127.0.0.1:3306/nginxwebui?useSSL=false&serverTimezone=UTC \
  --spring.datasource.username=root \
  --spring.datasource.password=your_password

⚠️ 若使用 MySQL,请提前创建数据库 nginxwebui 并确保字符集为 utf8mb4


四、参数说明

参数 说明
--server.port Web 服务监听端口,默认 8080
--project.home 工作目录,存放 SQLite 数据库、SSL 证书、日志等,默认 /home/nginxWebUI/
--spring.database.type 数据库类型,可选 mysql 或留空(默认 SQLite)
--spring.datasource.url MySQL 连接 URL
--spring.datasource.username MySQL 用户名
--spring.datasource.password MySQL 密码

五、(推荐)配置为系统服务(systemd)

创建服务文件:

bash 复制代码
cat > /etc/systemd/system/nginxwebui.service <<EOF
[Unit]
Description=NginxWebUI - Web-based Nginx Manager
After=network.target

[Service]
Type=simple
User=root
WorkingDirectory=/data/nginxWebUI
ExecStart=/usr/bin/java -jar -Dfile.encoding=UTF-8 /data/nginxWebUI/target/nginxWebUI-4.2.4.jar --server.port=8080 --project.home=/home/nginxWebUI/
Restart=always
RestartSec=10
StandardOutput=journal
StandardError=journal

[Install]
WantedBy=multi-user.target
EOF

启用服务:

bash 复制代码
systemctl daemon-reload
systemctl enable --now nginxwebui
systemctl status nginxwebui

六、访问与初始化

浏览器访问:

复制代码
http://<服务器IP>:8080

首次访问将提示设置管理员账号和密码。


七、注意事项

  • 确保防火墙开放 8080 端口(或自定义端口)。
  • project.home 目录需有读写权限(建议由运行用户拥有)。
  • 生产环境建议通过 Nginx 反向代理 + HTTPS 提供服务。
  • 升级时只需拉取新代码、重新 mvn package 并重启服务。

相关推荐
郭涤生1 分钟前
不同主机之间网络通信-以太网连接复习
开发语言·rk3588
山居秋暝LS6 分钟前
【无标题】RTX00安装paddle OCR,win11不能装最新的,也不能用GPU
开发语言·r语言
卢锡荣10 分钟前
单芯通吃,盲插标杆 —— 乐得瑞 LDR6020,Type‑C 全场景互联 “智慧芯”
c语言·开发语言·计算机外设
Xin_ye1008615 分钟前
C# 零基础到精通教程 - 第七章:面向对象编程(入门)——类与对象
开发语言·c#
辰海Coding42 分钟前
MiniSpring框架学习-完成的 IoC 容器
java·spring boot·学习·架构
AI科技星1 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
小小编程路1 小时前
C++ 多线程与并发
java·jvm·c++
审判长烧鸡1 小时前
【Go工具】go-playground是什么组织?官方的?
开发语言·安全·go
AI视觉网奇1 小时前
linux 检索库 判断库是否支持
java·linux·服务器
kkeeper~1 小时前
0基础C语言积跬步之字符函数与字符串函数(上)
c语言·开发语言