一.Nginx安装
1.1.依赖下载
yum install gcc gcc-c++ make automake autoconf libtool pcre pcre-devel zlib zlib-devel openssl openssl-devel
1.2.nginx安装包下载
wget http://nginx.org/download/nginx-1.13.0.tar.gz
1.3.解压
tar -zxvf nginx-1.13.0.tar.gz
1.4.编译并安装
cd nginx-1.13.0 ./configure --prefix=/usr/local/nginx make && make install
1.5.编辑nginx首页 , 用来区分两台服务器
vim /usr/local/nginx/html/index.html
内容随意修改 , 可以标识两台服务器即可
1.6.验证配置文件
/usr/local/nginx/sbin/nginx -t
出来如下配置表示配置文件没有问题
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
1.7.启动
/usr/local/nginx/sbin/nginx
分别访问这两台nginx , 可以看到如下两个页面
1.8.nginx设置开机自启动
vim /usr/lib/systemd/system/nginx.service
[Unit] Description=nginx After=network.target [Service] Type=forking ExecStart=/usr/local/nginx/sbin/nginx ExecReload=/usr/local/nginx/sbin/nginx -s reload ExecStop=/usr/local/nginx/sbin/nginx -s quit PrivateTmp=true [Install] WantedBy=multi-user.target
1.9.其他命令
开机自启动 : systemctl enable nginx
重新加载配置 : systemctl daemon-reload
启动 : systemctl start nginx
停止 : systemctl stop nginx
状态 : systemctl status nginx
二.keepalived安装
2.1.下载
https://www.keepalived.org/software/keepalived-2.0.20.tar.gz
2.2.解压
tar -zxvf keepalived-2.0.20.tar.gz
2.3.编译并安装
cd keepalived-2.0.20 ./configure --prefix=/usr/local/keepalived make && make install
2.4.配置
mkdir /etc/keepalived cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/ cp /usr/local/keepalived/sbin/keepalived /etc/init.d/
三.keepalived+Nginx 高可用
3.1.修改配置文件
vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived global_defs { ## keepalived 自带的邮件提醒需要开启 sendmail 服务。 建议用独立的监控或第三方 SMTP router_id node08 ## 标识本节点的字条串,通常为 hostname } ## keepalived 会定时执行脚本并对脚本执行的结果进行分析,动态调整 vrrp_instance 的优先级。如果脚本执行结果为 0,并且 weight 配置的值大于 0,则优先级相应的增加。如果脚本执行结果非 0,并且 weight配置的值小于 0,则优先级相应的减少。其他情况,维持原本配置的优先级,即配置文件中 priority 对应的值。 vrrp_script chk_nginx { script "/etc/keepalived/nginx_check.sh" ## 检测 nginx 状态的脚本路径 interval 2 ## 检测时间间隔 weight -20 ## 如果条件成立,权重-20 } ## 定义虚拟路由, VI_1 为虚拟路由的标示符,自己定义名称 vrrp_instance VI_1 { state MASTER ## 主节点为 MASTER, 对应的备份节点为 BACKUP interface ens33 ## 绑定虚拟 IP 的网络接口,与本机 IP 地址所在的网络接口相同, 我的是 eth0 virtual_router_id 33 ## 虚拟路由的 ID 号, 两个节点设置必须一样, 可选 IP 最后一段使用, 相同的 VRID 为一个组,他将决定多播的 MAC 地址 mcast_src_ip 192.168.154.134 ## 本机 IP 地址 priority 100 ## 节点优先级, 值范围 0-254, MASTER 要比 BACKUP 高 nopreempt ## 优先级高的设置 nopreempt 解决异常恢复后再次抢占的问题 advert_int 1 ## 组播信息发送间隔,两个节点设置必须一样, 默认 1s ## 设置验证信息,两个节点必须一致 authentication { auth_type PASS auth_pass 1111 ## 真实生产,按需求对应该过来 } # 虚拟 IP 池, 两个节点设置必须一样 virtual_ipaddress { 192.168.154.10 ## 虚拟 ip,可以定义多个 } ## 将 track_script 块加入 instance 配置块 track_script { chk_nginx ## 执行 Nginx 监控的服务 } }
3.2.编辑nginx配置文件
vim /etc/keepalived/nginx_check.sh 1 #!/bin/bash A=`ps -C nginx –no-header |wc -l` if [ $A -eq 0 ];then /usr/local/nginx/sbin/nginx sleep 2 if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then killall keepalived fi fi
3.3.启动keepalived
systemctl start keepalived
3.4.其他命令
systemctl start keepalived #启动 systemctl restart keepalived #重启 systemctl stop keepalived #关闭 systemctl status keepalived # 状态
3.5 查看keepalived状态
测试 : 首先访问虚拟IP+nginx端口 , 可以看到134的页面 , 停掉134nginx , 再次访问 , 就会看到135的nginx页面 , 再次启动134nginx和keepalived , 正常访问134nginx
比如我这里虚拟IP+nginx端口是 : 192.168.154.10:80 , 我直接访问 , 出来的是192.168.154.134服务器上的nginx , 因为我刚刚做了区分 , 所以这个时候就可以知道访问的是哪个机器的Nginx , 然后我们把134的Nginx停掉 , 然后再次访问 , 仍然可以使用 , 此时 ,出现的135的页面 , 也就是访问的是192.168.154.135的Nginx