【愚公系列】2022年04月 .NET架构班 035-分布式中间件 Nginx集群的搭建

举报
愚公搬代码 发表于 2022/04/05 00:27:48 2022/04/05
【摘要】 一、Nginx集群的搭建 1.虚拟机准备1、先通过vwworkstation创建2台linux主机​地址:192.168.44.3​地址:192.168.44.42、然后分别在2台主机上安装nginx192.168.44.3:1 安装 nginx需要工具 yum -y install gcc make pcre-devel zlib-devel tar zlib2 下载nginx wg...

一、Nginx集群的搭建

1.虚拟机准备

1、先通过vwworkstation创建2台linux主机

​地址:192.168.44.3
​地址:192.168.44.4

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
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

3、然后配置分别将秒杀项目部署到Nginx中

在192.168.44.4主机中进行部署

4、然后在192.168.44.3配置秒杀项目地址

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;
     }
}

2.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服务宕机异常出现的时候,发送通知邮件 可以是多个   acassen@firewall.loc  #  收件人邮箱1
		 failover@firewall.loc #  收件人邮箱2
		 sysadmin@firewall.loc #  收件人邮箱3
   }

   notification_email_from Alexandre.Cassen@firewall.loc  #邮件发件人

   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
	}
}

4、然后在192.168.44.3配置Keepalive

进入到cd /etc/keepalived/keepalived.conf配置文件

global_defs {

   notification_email { # keepalived服务宕机异常出现的时候,发送通知邮件 可以是多个   acassen@firewall.loc  #  收件人邮箱1
		 failover@firewall.loc #  收件人邮箱2
		 sysadmin@firewall.loc #  收件人邮箱3
   }

   notification_email_from Alexandre.Cassen@firewall.loc  #邮件发件人

   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
	}
}

5、然后重启Keepalived

systemctl restart keepalived.service

6、日志查看

tail -f /usr/local/nginx/logs/access.log
tail -f /var/log/messages

7、查看进程

ps -ef|grep keep

3.Nginx自动重启-手动

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

4.Nginx自动重启-启动

1、在keepalived.conf中添加内容

vrrp_script chk_http_port {
     script "/root/nginx_check.sh" #脚本地址
     interval 2 #检测脚本执行的间隔
     weight 2 #比重
}
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。