功能说明
nginxWebUI 是一款图形化管理 nginx 配置得工具,可以使用网页来快速配置 nginx 的各项功能,包括 http 协议转发,tcp 协议转发,反向代理,负载均衡,静态 html 服务器,ssl 证书自动申请、续签、配置等,配置好后可一建生成 nginx.conf 文件,同时可控制 nginx 使用此文件进行启动与重载,完成对 nginx 的图形化控制闭环.
nginxWebUI 也可管理多个 nginx 服务器集群,随时一键切换到对应服务器上进行 nginx 配置,也可以一键将某台服务器配置同步到其他服务器,方便集群管理.
nginx 本身功能复杂,nginxWebUI 并不能涵盖 nginx 所有功能,但能覆盖 nginx 日常 90% 的功能使用配置,平台没有涵盖到的 nginx 配置项,可以使用自定义参数模板,在 conf 文件中生成配置独特的参数。
部署此项目后,配置 nginx 再也不用上网各种搜索配置代码,再也不用手动申请和配置 ssl 证书,只需要在本项目中进行增删改查就可方便的配置和启动 nginx。
技术说明
本项目是基于 solon 的 web 系统,数据库使用 h2, 因此服务器上不需要安装任何数据库
本系统通过 Let's encrypt 申请证书,使用 acme.sh 脚本进行自动化申请和续签,开启续签的证书将在每天凌晨 2 点进行续签,只有超过 50 天的证书才会进行续签。只支持在 linux 下签发证书.
添加 tcp/ip 转发配置支持时,一些低版本的 nginx 可能需要重新编译,通过添加–with-stream 参数指定安装 stream 模块才能使用,但在 ubuntu 18.04 下,官方软件库中的 nginx 已经带有 stream 模块,不需要重新编译。本系统如果配置了 tcp 转发项的话,会自动引入 ngx_stream_module.so 的配置项,如果没有开启则不引入,最大限度优化 ngnix 配置文件.
jar 安装说明
以 Ubuntu 操作系统为例,
注意:本项目需要在 root 用户下运行系统命令,极容易被黑客利用,请一定修改密码为复杂密码
1. 安装 java 运行环境和 nginx
Ubuntu:
1 apt update
2 apt install openjdk-11-jdk
3 apt install nginx
Centos:
yum install java-11-openjdk
yum install nginx
Windows:
1 下载JDK安装包 https://www.oracle.com/java/technologies/downloads/
2 下载nginx http://nginx.org/en/download.html
3 配置JAVA运行环境
4 JAVA_HOME : JDK安装目录
5 Path : JDK安装目录\bin
6 重启电脑
2. 下载最新版发行包 jar
1 Linux: wget -O /home/nginxWebUI/nginxWebUI.jar http://file.nginxwebui.cn/nginxWebUI-3.1.8.jar
2
3 Windows: 直接使用浏览器下载 http://file.nginxwebui.cn/nginxWebUI-3.1.8.jar
有新版本只需要修改路径中的版本即可
3. 启动程序
1 Linux: nohup java -jar -Dfile.encoding=UTF-8 /home/nginxWebUI/nginxWebUI.jar --server.port=8080 --project.home=/home/nginxWebUI/ > /dev/null &
2
3 Windows: java -jar -Dfile.encoding=UTF-8 D:/home/nginxWebUI/nginxWebUI.jar --server.port=8080 --project.home=D:/home/nginxWebUI/
参数说明 (都是非必填)
--server.port 占用端口,默认以 8080 端口启动
--project.home 项目配置文件目录,存放数据库文件,证书文件,日志等,默认为 /home/nginxWebUI/
--spring.database.type=mysql 使用其他数据库,不填为使用本地 h2 数据库,可选 mysql
--spring.datasource.url=jdbc:mysql://ip:port/nginxwebui 数据库 url
--spring.datasource.username=root 数据库用户
--spring.datasource.password=pass 数据库密码
注意 Linux 命令最后加一个 & 号,表示项目后台运行
设置UBUNTU开机启动NGINX WebUi
1、编辑/etc/下的rc.local脚本
vi /etc/rc.local
2、然后把对应的需要执行的脚本写在 exit 0 前面,如下图所示
1 #!/bin/bash
2 # THIS FILE IS ADDED FOR COMPATIBILITY PURPOSES
3 #
4 # It is highly advisable to create own systemd services or udev rules
5 # to run scripts during boot instead of using this file.
6 #
7 # In contrast to previous versions due to parallel execution during boot
8 # this script will NOT be run after all other services.
9 #
10 # Please note that you must run 'chmod +x /etc/rc.d/rc.local' to ensure
11 # that this script will be executed during boot.
12
13
14 nohup java -jar -Dfile.encoding=UTF-8 /home/nginxWebUI/nginxWebUI.jar --server.port=8080 --project.home=/home/nginxWebUI/ > /dev/null &
15 exit 0
编辑好以后保存退出即可 :wq
docker 安装说明
本项目制作了 docker 镜像,支持 x86/x86_64/arm64/arm v7 平台,同时包含 nginx 和 nginxWebUI 在内,一体化管理与运行 nginx.
1. 安装 docker 容器环境
Ubuntu:
apt install docker.io
Centos:
yum install docker
2. 拉取镜像:
docker pull cym1102/nginxwebui:latest
3. 启动容器:
docker run -itd \
-v /home/nginxWebUI:/home/nginxWebUI \
-e BOOT_OPTIONS="--server.port=8080" \
--privileged=true \
--net=host \
cym1102/nginxwebui:latest
注意:
- 启动容器时请使用 --net=host 参数,直接映射本机端口,因为内部 nginx 可能使用任意一个端口,所以必须映射本机所有端口.
- 容器需要映射路径 /home/nginxWebUI:/home/nginxWebUI, 此路径下存放项目所有数据文件,包括数据库,nginx 配置文件,日志,证书等,升级镜像时,此目录可保证项目数据不丢失。请注意备份.
- -e BOOT_OPTIONS 参数可填充 java 启动参数,可以靠此项参数修改端口号,--server.port 为占用端口参数,不填默认以 8080 端口启动
- 日志默认存放在 /home/nginxWebUI/log/nginxWebUI.log
更新说明
1.windows 下支持自动更新
2. 使用 java 实现 tail 命令,跟踪日志不再使用 websocket 协议
3. 修复通过非 443,80 端口代理情况下白屏问题
4. 修复导入文件过大无法识别问题
5. 修复远程同步数据过大无法同步问题
6. 修复指定 project.home 后 log 存放路径错误问题
7. 修复 windows 下运行 docker 乱码问题
8. 替换 mysql 驱动为 8.x, 规避漏洞
相关链接
- nginxWebUI 的详细介绍:点击查看
- nginxWebUI 的下载地址:点击下载