前文链接
四 NGINX 高可用实施方案
高可用的实施, 主要步骤概述如下:
- NGINX 的安装及基础配置
- 负载均衡层高可用: NGINX + Keepalived配置
- 应用服务层高可用: NGINX -> 应用服务层 转发配置
系统软 硬件详细配置清单
根据制造业高可用架构设计, 以及业务需求, 部署模型建议配置如下:
- 负载均衡服务器(即 NGINX + Keepalived): 2台, 操作系统 Linux. 配置建议如下:
名称规格备注CPU2 core内存4 GB硬盘50 GB操作系统SUSE12 64位及补丁网卡至少1块网卡, 支持VRRP 技术
软件规格NGINX1.16.1Keepalived2.0.104.1 NGINX 安装及配置
4.1.1 分区及目录
建议至少分为以下3个区:
分区及目录大小备注主分区( /)默认nginx程序及配置文件位于该分区(/etc/nginx)日志分区(/var/log/nginx)10G-20G程序目录分区(/usr/share/nginx/html)10G可选, nginx用作web server时需要用到此目录.4.1.2 程序及依赖版本
程序组件安装包名版本md5nginxnginx-1.16.1-1.sles12.ngx.x86_64.rpm1.16.1396A359F26DD0100CD59545BAFFAFE854.1.3 NGINX程序规范
- nginx程序目录: /etc/nginx
- 执行程序路径: /usr/sbin/nginx
- 主配置文件路径:/etc/nginx/conf/nginx.conf
- 各个应用系统转发配置文件目录:/etc/nginx/conf.d/
- 日志目录:/var/log/nginx
- 各个应用系统静态文件目录:/usr/share/nginx/html
4.1.4 系统级别配置优化
❕ 注意:
需要 root 用户执行.
- vi /etc/security/limits.conf
- # vi编辑
- * soft nofile 65535
- * hard nofile 65535
复制代码- vi /etc/sysctl.conf
- # vi编辑
- # NGINX Tuning Performance
- fs.file-max = 65535
- vm.zone_reclaim_mode = 0
- net.core.somaxconn = 2048
- net.ipv4.tcp_tw_recycle = 0
- net.ipv4.tcp_timestamps = 1
- net.ipv4.tcp_slow_start_after_idle = 0
- net.ipv4.tcp_mtu_probing = 1
- # 生效
- sysctl -p
复制代码 4.1.5 配置NGINX repo
❕ 注意:
本节命令可以根据具体情况, 在公司内部 repo 仓库机器上进行操作.
其他机器只需要配置内部 repo 地址即可.
键入以下 zypper 命令以添加 SLES 的 zypper 存储库- $ sudo zypper addrepo -G -t yum -c 'http://nginx.org/packages/sles/12' nginx
复制代码
接下来,您必须验证数字签名以保持下载包的完整性和来源。使用wget命令获取nginx签名密钥:- $ wget http://nginx.org/keys/nginx_signing.key
复制代码 示例输出:- --2020-01-09 23:48:48-- http://nginx.org/keys/nginx_signing.key
- Resolving nginx.org (nginx.org)... 206.251.255.63, 95.211.80.227, 2001:1af8:4060:a004:21::e3, ...
- Connecting to nginx.org (nginx.org)|206.251.255.63|:80... connected.
- HTTP request sent, awaiting response... 200 OK
- Length: 1561 (1.5K) [text/plain]
- Saving to: ‘nginx_signing.key’
-
- 100%[==================================================>] 1,561 --.-K/s in 0s
-
- 2020-01-09 23:48:49 (117 MB/s) - ‘nginx_signing.key’ saved [1561/1561]
复制代码 使用rpm命令将密钥导入rpm:- $ sudo rpm --import nginx_signing.key
复制代码 4.1.6 SUSE 上安装NGINX
键入以下 zypper 命令:- $ sudo zypper install nginx=1.16.1
复制代码
4.1.7 可选: 配置防火墙
❕ 注意:
如果机房流量入口有其他专用防火墙, 则可以关闭 nginx 服务器上的防火墙, 且不需要执行此步骤.
首先创建Nginx特定服务的配置文件,使用vi命令等文本编辑器打开端口80:- $ sudo vi /etc/sysconfig/SuSEfirewall2.d/services/nginx
复制代码 添加以下配置:- ## Name: Nginx web server
- ## Description: Open ports for Nginx Server
-
- # space separated list of allowed TCP ports
- TCP="http"
复制代码 (如果不需要 HTTPS 支持,则只需要允许 TCP 端口号 80 上的通信。)保存并退出 VI/VIM 文本编辑器。现在,只需运行以下命令打开端口80:必须使用 TAB 和箭头键在 YaST 中跳转。在 YaST 中,跳转到允许的服务,然后按 Enter 键:

使用 TAB 跳转到“Allowed Services”,然后按向下箭头键选择 Nginx web server,然后按回车键。必须按 Alt-A 来将Nginx服务器添加到防火墙:

按 Alt-N 和 Alt-F 保存并完成 SLES 上的防火墙设置。返回 shell 提示符后,列出 sle 上的所有 iptables 规则:示例输出:- -A input_ext -p tcp -m limit --limit 3/min -m tcp --dport 80 --tcp-flags FIN,SYN,RST,ACK SYN -j LOG --log-prefix "SFW2-INext-ACC-TCP " --log-tcp-options --log-ip-options
- -A input_ext -p tcp -m tcp --dport 80 -j ACCEPT
复制代码 使用 sudo 命令和 grep 命令的组合来确定端口 80 是否打开:- sudo sh -c 'iptables -L -n -v | grep :80'
复制代码 4.1.8 启动 NGINX Server
键入以下 systemctl 命令以在系统启动时启用 Nginx: (开机自启)- $ sudo systemctl enable nginx
复制代码 启动 Nginx web 服务器:- $ sudo systemctl start nginx
复制代码 验证:
要判断 80 端口是否监听, 运行以下 netstat 命令或 ss 命令:- $ sudo netstat -tulpn | grep :80
- $ sudo ss -tulpn | grep :80
复制代码
4.1.9 NGINX 基础操作
停止:- $ sudo systemctl stop nginx
复制代码 启动:- $ sudo systemctl start nginx
复制代码 重新启动服务:- $ sudo systemctl restart nginx
复制代码 更改配置后重新加载 Ngnix:- $ sudo systemctl reload nginx
复制代码ℹ️ 建议:
配置更新后使用 reload 来重新加载nginx.
访问 nginx 页面:
假设 NGINX IP为: 192.168.0.1. 使用浏览器或 curl 访问:- http://serve_IP
- http://your-domain
- http://192.168.0.1
复制代码 示例输出:- HTTP/1.1 200 OK
- Server: nginx/1.16.1
- Date: Sat, 03 Feb 2020 19:18:53 GMT
- Content-Type: text/html
- Content-Length: 612
- Last-Modified: Tue, 17 Oct 2019 13:30:50 GMT
- Connection: keep-alive
- ETag: "59e6060a-264"
- Accept-Ranges: bytes
复制代码 4.1.10 查找有关 SLES 上 Nginx 配置文件的信息
现在 Nginx 已经启动并运行了。接下来可以定制配置。
SLES 的服务器配置文件:
- /etc/nginx/: nginx 默认配置目录
- /etc/nginx/nginx.conf: nginx 主配置文件
- /etc/nginx/conf.d/default.conf: 默认 virtual host 的配置
修改主配置:- $ sudo vi /etc/nginx/nginx.conf
复制代码 4.1.11 NGINX 日志
- /var/log/nginx/access.log: 访问日志
- /var/log/nginx/error.log: 错误日志
4.1.12 nginx.conf
主配置文件详细说明如下:✔️ 建议:
为了保证主配置文件的干净. 建议通过 include conf.d/default.conf; 类似这样的方式来引入其他virtual hosts配置.
4.1.13 日志转储
- sudo vi /etc/logrotate.d/nginx
- 编辑内容:
- /var/log/nginx/*.log {
- daily
- rotate 90 # 保留90天, 按需调整
- create
- dateext
- #compress # 是否启用压缩, 按需调整
- #minsize 1M
- #create 0644 nginx nginx # nginx日志所属用户和组, 按需调整
- # copytruncate 用于还在打开中的日志文件,把当前日志备份并截断;是先拷贝再清空的方式,拷贝和清空之间有一个时间差,可能会丢失部分日志数据。
- # delaycompress 和compress 一起使用时,转储的日志文件到下一次转储时才压缩
- missingok
- ifempty # default
- nomail
- #noolddir # default
- sharedscripts # 运行postrotate脚本,作用是在所有日志都轮转后统一执行一次脚本。如果没有配置这个,那么每个日志轮转后都会执行一次脚本
- postrotate # 在logrotate转储之后需要执行的指令,例如重新启动 (kill -HUP) 某个服务!必须独立成行
- if [ -f /var/log/nginx/nginx.pid ]; then
- kill -USR1 `cat /var/log/nginx/nginx.pid`
- fi
- endscript
- }
复制代码 - 强制运行一次来测试:logrotate -f -v /etc/logrotate.d/nginx(对应目录只能 user 有w权限, 否则会报错)
- 配置好即可, logrotate 会自动读取/etc/logrotate.d的配置并自动执行.
<blockquote>
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |