原文地址:https://juejin.cn/post/7090721267011026981
作者:MacroZheng
Nginx是一款非常流行的Web服务器,作为程序员我相信大家没少和它打交道。在我使用Nginx的过程中,一直觉得它的配置很麻烦,尤其是在Linux服务器上用vim手撸配置的时候!最近发现一款开源的Nginx可视化配置工具NginxConfig
,能轻松生成Nginx配置,推荐给大家!
SpringBoot实战电商项目mall(50k+star)地址:https://github.com/macrozheng/mall
NginxConfig简介
NginxConfig号称你唯一需要的Nginx配置工具,可以使用可视化界面来生成Nginx配置,功能非常强大,在Github上已有15K+Star!
下面是NginxConfig使用过程中的一张效果图,大家可以看下!
安装
安装Node.js
首先从官网下载Node.js的安装包,下载地址:https://nodejs.org/zh-cn/download/
下载成功后将安装包解压到/usr/local/src/
目录下,使用如下命令即可。
cd /usr/local/src/ tar xf node-v16.14.2-linux-x64.tar.xz cd node-v16.14.2-linux-x64/ ./bin/node -v
使用./bin/node -v
命令可查看当前安装版本。
如果想在Linux命令行中直接运行,还需对node和npm命令创建软链接。
ln -s /usr/local/src/node-v16.14.2-linux-x64/bin/node /usr/bin/node ln -s /usr/local/src/node-v16.14.2-linux-x64/bin/npm /usr/bin/npm node -v npm -v
创建完成后使用命令查看版本,至此Node.js安装完成。
安装NginxConfig
首先下载NginxConfig的安装包,下载地址:https://github.com/digitalocean/nginxconfig.io
下载完成后解压到指定目录,并使用npm命令安装依赖并运行。
tar -zxvf nginxconfig.io-master.tar.gz npm install npm run dev
NginxConfig运行成功后就可以直接访问了,看下界面支持中文还是挺不错的,访问地址:http://192.168.3.105:8080
使用
使用准备
首先我们需要安装Nginx,我们将实现如下功能,通过静态代理访问在不同目录下的静态网站,通过动态代理来访问SpringBoot提供的API接口。
# 静态代理,访问mall文档网站 docs.macrozheng.com # 静态代理,访问mall前端项目 mall.macrozheng.com # 动态代理,访问mall线上API api.macrozheng.com
需要提前修改下本机host文件。
192.168.3.105 docs.macrozheng.com 192.168.3.105 mall.macrozheng.com 192.168.3.105 api.macrozheng.com
文档网站配置
我们先来配置下mall文档网站的访问,域名为:docs.macrozheng.com。
不需要HTTPS的话可以选择不启用。
然后在全局配置->安全中去除Content-Security-Policy设置
再修改性能配置,开启Gzip压缩,删除资源有效期限制。
前端网站配置
再来配置下mall前端网站的访问,域名为:mall.macrozheng.com。
接下来我们再添加一个站点,修改下服务配置即可,其他和上面的基本一致。
API网站配置
最后配置下mall的Swagger API文档网站的访问,域名为:api.macrozheng.com。
继续添加一个站点,修改服务配置,只需修改站点名称即可。
然后启用反向代理并设置,反向代理到线上API。
路由功能暂时不用可以关闭。
使用配置
接下来我们就可以直接下载NginxConfig给我们生成好的配置了。
我们先来看下NginxConfig给我们生成的配置内容,这种配置手写估计要好一会吧。
点击按钮下载配置,完成后改个名字,然后上传到Linux服务器的Nginx配置目录下,使用如下命令解压。
tar -zxvf nginxconfig.io.tar.gz
大家可以看到NginxConfig将为我们生成如下配置文件。
接下来将我们之前的mall文档网站和mall前端网站放到Nginx的html目录下,然后重启Nginx就可以查看效果了。
docker restart nginx
先访问下我们的mall文档网站,访问地址:docs.macrozheng.com
在访问下mall的前端网站,访问地址:mall.macrozheng.com
最后访问下mall的API文档网站,访问地址:http://api.macrozheng.com/swagger-ui.html
总结
体验了一把NginxConfig的配置生成功能,这种不用手写配置,直接通过可视化界面来生成配置的方式确实很好用。NginxConfig不愧是配置高性能、安全、稳定的NgInx服务器的最简单方法!