Linux集群介绍
- 按功能分:高可用和负载均衡
- 高可用集群通常为两台服务器 ,一台工作,另一台作为冗余
- 负载均衡集群:需一台服务器作为分发器(把用户的请求分发给后端的服务器处理),还要给用户提供服务的服务器,服务器至少2个
- 高可用开源软件:heartbeat,keepalived
- 负载均衡软件:LVS,keepalived,haproxy,nginx,商业:F5,Netsacler
keepalived+Nginx实验部分
主(master):192.168.206.128
从(backup):192.168.206.129
虚拟IP(VIP):192.168.206.200
echo 'this is master' > /usr/share/nginx/html/index.html 主节点
echo 'this is slave' > /usr/share/nginx/html/index.html 备节点
Keepalived+Nginx 安装
Keepalived配置
主要有三个模块:core,check,vrrp
需要两台机器 安装keepalived+Nginx
扫描二维码关注公众号,回复:
16701868 查看本文章
yum -y install keepalived nginx
Nginx配置
#下载
wget http://nginx.org/download/nginx-1.18.0.tar.gz
tar -zxvf nginx-1.18.0.tar.gz
cd nginx-1.18.0.tar.gz
#所需安装包
yum -y install gcc pcre-devel zlib zlib-devel
#编译运行
./configure --prefix=/usr/local/nginx
#安装
make && make install
Nginx服务配置
#进入对应文件
cd /usr/local/nginx/sbin
./nginx #启动nginx
./nginx -s quit 或者 ./nginx -s stop #结束nginx
./nginx -s reload #重启nginx
keepalived配置文件
主配置文件
!Configuration File for keepalived
global_defs {
notification_email {
[email protected]
[email protected]
[email protected]
}
notification_email_from [email protected]
smtp_server 192.168.200.1
smtp_connect_timeout 30
router_id LVS_DEVEL
}
#keepalived会定时执行脚本并对脚本执行的结果进行分析,动态调整vrrp_instance的优先级。
vrrp_script chk_nginx {
#运行脚本,脚本内容下面有,就是起到一个nginx宕机以后,自动开启服务
script "/etc/keepalived/nginx_check.sh"
interval 1 #检测时间间隔
weight -2 #如果条件成立的话,则权重 -2
}
vrrp_instance VI_1 {
state MASTER #来决定主从
interface ens33 # 绑定 IP 的网卡口,根据自己的机器填写 (修)
virtual_router_id 120 # 虚拟路由的 ID 号, 两个节点设置必须一样
mcast_src_ip 192.168.206.128 #填写本机ip (修)
priority 100 # 节点优先级,主要比从节点优先级高
advert_int 1 # 组播信息发送间隔,两个节点设置必须一样,默认 1s
authentication {
auth_type PASS
auth_pass 1111
}
# 将 track_script 块加入 instance 配置块
track_script {
chk_nginx #执行 Nginx 监控的服务
}
virtual_ipaddress {
192.168.206.200/24 # 虚拟ip,通过虚拟Ip切换进行nginx主备切换功能(修)
}
}
备配置文件
! Configuration File for keepalived
vrrp_script chk_nginx {
script "/etc/keepalived/nginx_check.sh" #运行脚本,脚本内容下面有,就是起到一个nginx宕机以后,自动开启服务
interval 1 #检测时间间隔
weight -2 #如果条件成立的话,则权重 -20
}
vrrp_instance VI_1 {
state BACKUP #来决定主从
interface ens33 # 绑定 IP 的网卡名称,根据自己的机器填写
virtual_router_id 120 # 虚拟路由的 ID 号, 两个节点设置必须一样
mcast_src_ip 192.168.206.129 #填写本机ip
priority 99 # 节点优先级,主要比从节点优先级高
advert_int 1 # 组播信息发送间隔,两个节点设置必须一样,默认 1s
#nopreempt #设置为不抢夺VIP
authentication {
auth_type PASS
auth_pass 1111
}
# 将 track_script 块加入 instance 配置块
track_script {
chk_nginx #执行 Nginx 监控的服务
}
virtual_ipaddress {
192.168.206.200/24 # 虚拟ip
}
}
配置监控脚本
命令配置
vi /etc/keepalived/nginx_check.sh
chmod 755 /etc/keepalived/nginx_check.sh
监控脚本
#文件位置 /usr/local/sbin/check.sh
#!/bin/bash
#时间变量,用于记录日志
d=`date --date today +%Y%m%d_$H:%M:%S`
#计算Nginx进程数量
n=`ps -C nginx --no-heading | wc -l`
#如果进程为0,则启动nginx,并且再次检测nginx进程数量
if[$n -eq "0"]; then
/etc/init.d/nginx start
n2=`ps -C nginx --no-heading|wc -l`
#如果还是为0,说明nginx无法启动,此时需要关闭keepalived
if[$n2 -eq "0"]; then
echo "$d nginx down,keepalived will stop" >> /var/log/check.log
systemctl stop keepalived
fi
fi
Keepalived+Nginx实现高可用
#主从配置都开启keepalived服务+Nginx服务
# 启动 | 停止 | 重启
service keepalived start | stop | restart
#主从设备同时开启keepalived服务,访问VIP地址
#两个设备同时ip a,显示VIP地址为192.168.206.200
curl 192.168.206.200
#输出结果this is master
#主设备关闭Nginx,访问VIP地址
#从设备显示VIP地址为从设备的IP地址
curl 192.168.206.200
#输出结果 this is slave