Nginx深度3-高并发/高可用集群
Nginx深度3-高并发/高可用集群
什么是集群
项目中为什么要使用集群
项目中如何落地Nginx集群
条件
1、linux
2、 nginx
3、keepalived
步骤
虚拟机准备:
1、先通过vwworkstation创建2台linux主机
nginx准备:
2、然后分别在2台主机上安装nginx
192.168.44.3:
1 安装 nginx需要工具
yum -y install gcc make pcre-devel zlib-devel tar zlib
2 下载nginx
wget http://nginx.org/download/nginx-1.17.1.tar.gz
3 nginx解压/nginx目录
tar -zxvf nginx-1.17.1.tar.gz
4 切换到/nginx/nginx-1.17.1
执行./configure
make
make install 进行安装
5 切换到/usr/local/nginx/sbin
执行 ./nginx 启动nginx
yum方式
192.168.44.4:
1 安装 nginx需要工具
yum -y install gcc make pcre-devel zlib-devel tar zlib
2 下载nginx
wget http://nginx.org/download/nginx-1.17.1.tar.gz
3 nginx解压/nginx目录
tar -zxvf nginx-1.17.1.tar.gz
4 切换到/nginx/nginx-1.17.1
执行./configure
make
make install 进行安装
5 切换到/usr/local/nginx/sbin
执行 ./nginx 启动nginx
yum方式安装
3、然后配置分别将秒杀项目部署到Nginx中
在192.168.44.4主机中进行部署
server {
listen 8081;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
proxy_pass http://192.168.44.4:5000;
}
}
keepalived准备
1、先分别在2台主机上安装keepalived
yum install keepalived
2、然后启动keepalived
systemctl start keepalived.service systemctl stop keepalived.service systemctl restart keepalived.service
3、然后在192.168.44.4配置Keepalive
进入到cd /etc/keepalived/keepalived.conf配置文件
global_defs {
notification_email { # keepalived服务宕机异常出现的时候,发送通知邮件 可以是多个 [email protected] # 收件人邮箱1
[email protected] # 收件人邮箱2
[email protected] # 收件人邮箱3
}
notification_email_from [email protected] #邮件发件人
smtp_server 192.168.200.1 # 邮件服务器地址
smtp_connect_timeout 30 # 超时时间
router_id LVS_DEVEL # 机器标识 局域网内唯一即可
vrrp_skip_check_adv_addr # 默认是不跳过检查。检查收到的VRRP通告中的所有地址可能会比较耗时,设置此命令的意思是,如果通告与接收的上一个通告来自相同的master路由器,则不执行检查(跳过检查)。
#vrrp_strict # 严格遵守VRRP协议。下列情况将会阻止启动Keepalived:1. 没有VIP地址。2. 单播邻居。3. 在VRRP版本2中有IPv6地址。
vrrp_garp_interval 0 # 小数类型,单位秒,在一个网卡上每组gratuitous arp消息之间的延迟时间,默认为0,一个发送的消息=n组 arp报文
vrrp_gna_interval 0 # 小数类型,单位秒, 在一个网卡上每组na消息之间的延迟时间,默认为0
}
vrrp_instance VI_1 {
state MASTER # 服务器状态 MASTER是主服务器 BACKUP是备份服务器 主服务器的priority要比备份服务器大
interface ens33 # 通信端口 通过ip addr可以看到 根据自己的机器配置
virtual_router_id 51 # vrrp实例id keepalived集群,实例id必须一致
priority 100 # 权重比 主服务器的priority要比备份服务器大
advert_int 1 # 心跳间隔 单位秒 keepalived多机器集群 通过心跳检测,如果发送心跳没反应 就立刻接管;
authentication { # 服务器之间通信密码
auth_type PASS
auth_pass 1111
}
virtual_ipaddress { # 自定义虚拟IP
192.168.91.199
}
}
3、然后在192.168.44.3配置Keepalive
进入到cd /etc/keepalived/keepalived.conf配置文件
global_defs {
notification_email { # keepalived服务宕机异常出现的时候,发送通知邮件 可以是多个 [email protected] # 收件人邮箱1
[email protected] # 收件人邮箱2
[email protected] # 收件人邮箱3
}
notification_email_from [email protected] #邮件发件人
smtp_server 192.168.200.1 # 邮件服务器地址
smtp_connect_timeout 30 # 超时时间
router_id LVS_DEVEL # 机器标识 局域网内唯一即可
vrrp_skip_check_adv_addr # 默认是不跳过检查。检查收到的VRRP通告中的所有地址可能会比较耗时,设置此命令的意思是,如果通告与接收的上一个通告来自相同的master路由器,则不执行检查(跳过检查)。
#vrrp_strict # 严格遵守VRRP协议。下列情况将会阻止启动Keepalived:1. 没有VIP地址。2. 单播邻居。3. 在VRRP版本2中有IPv6地址。
vrrp_garp_interval 0 # 小数类型,单位秒,在一个网卡上每组gratuitous arp消息之间的延迟时间,默认为0,一个发送的消息=n组 arp报文
vrrp_gna_interval 0 # 小数类型,单位秒, 在一个网卡上每组na消息之间的延迟时间,默认为0
}
vrrp_instance VI_1 {
state BACKUP # 服务器状态 MASTER是主服务器 BACKUP是备份服务器 主服务器的priority要比备份服务器大
interface ens33 # 通信端口 通过ip addr可以看到 根据自己的机器配置
virtual_router_id 51 # vrrp实例id keepalived集群,实例id必须一致
priority 99 # 权重比 主服务器的priority要比备份服务器大
advert_int 1 # 心跳间隔 单位秒 keepalived多机器集群 通过心跳检测,如果发送心跳没反应 就立刻接管;
authentication { # 服务器之间通信密码
auth_type PASS
auth_pass 1111
}
virtual_ipaddress { # 自定义虚拟IP
192.168.91.199
}
}
4、然后重启Keepalived
systemctl restart keepalived.service
5、日志查看 tail -f /usr/local/nginx/logs/access.log tail -f /var/log/messages
2、查看进程 ps -ef|grep keep
Nginx自动重启-手动
条件
1、nginx_check.sh
步骤
1、先创建nginx_check.sh
2、然后添加内容
#!/bin/bash
echo 'xxxxxx'
count_nginx=`ps -ef|grep -w nginx|grep -v grep|wc -l`
echo $count_nginx
if [ $count_nginx -eq 0 ];then
/usr/local/nginx/sbin/nginx
sleep 2
if [ `ps -ef|grep -w nginx|grep -v grep|wc -l` -eq 0 ];then
systemctl stop keepalived.service
fi
fi
3、然后重启Nginx
Nginx自动重启-启动
条件
1、keepalived
步骤
1、在keepalived.conf中添加内容
vrrp_script chk_http_port {
script "/root/nginx_check.sh" #脚本地址
interval 2 #检测脚本执行的间隔
weight 2 #比重
}
Keepalived高可用原理
条件
1、VRRP