服务搭建篇(四) 搭建基于Nginx + keepalived的高可用服务

简介: 比如我这里虚拟IP+nginx端口是 : 192.168.154.10:80 , 我直接访问 , 出来的是192.168.154.134服务器上的nginx , 因为我刚刚做了区分 , 所以这个时候就可以知道访问的是哪个机器的Nginx , 然后我们把134的Nginx停掉 , 然后再次访问 , 仍然可以使用 , 此时 ,出现的135的页面 , 也就是访问的是192.168.154.135的Nginx

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

内容随意修改 , 可以标识两台服务器即可

e947884e03ecdc738a3459f08f5db436_9c27f684ff8e409dbeeb3143579522f4.png


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 , 可以看到如下两个页面

b2fd283b44040c03b29b63d5bec7caae_125e2382cacb4cbc80eeb4bb64c825ba.png



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

相关文章
|
5天前
|
应用服务中间件 网络安全 nginx
快速上手!使用Docker和Nginx部署Web服务的完美指南
快速上手!使用Docker和Nginx部署Web服务的完美指南
|
11天前
|
应用服务中间件 nginx
树莓派安装Nginx服务结合内网穿透实现无公网IP远程访问
树莓派安装Nginx服务结合内网穿透实现无公网IP远程访问
|
3月前
|
负载均衡 应用服务中间件 Linux
高可用系列文章之三 - NGINX 高可用实施方案
高可用系列文章之三 - NGINX 高可用实施方案
|
4月前
|
负载均衡 Ubuntu 应用服务中间件
【Linux】Web服务之Nginx服务
【Linux】Web服务之Nginx服务
40 0
|
5天前
|
存储 Ubuntu 应用服务中间件
【Nginx】centos和Ubuntu操作系统下载Nginx配置文件并启动Nginx服务详解
【Nginx】centos和Ubuntu操作系统下载Nginx配置文件并启动Nginx服务详解
11 1
|
2天前
|
搜索推荐 网络协议 应用服务中间件
nginx高可用实践简记
nginx高可用实践简记
8 1
|
16天前
|
Kubernetes 搜索推荐 应用服务中间件
通过keepalived+nginx实现 k8s apiserver节点高可用
通过keepalived+nginx实现 k8s apiserver节点高可用
35 16
|
2月前
|
NoSQL 关系型数据库 MySQL
Docker安装详细步骤及相关环境安装配置(mysql、jdk、redis、自己的私有仓库Gitlab 、C和C++环境以及Nginx服务代理)
Docker安装详细步骤及相关环境安装配置(mysql、jdk、redis、自己的私有仓库Gitlab 、C和C++环境以及Nginx服务代理)
233 0
|
2月前
|
安全 应用服务中间件 nginx
|
2月前
|
域名解析 网络协议 应用服务中间件
nginx-ingress通过ipv6暴露服务,并在nginx ingress日志中记录客户端真实ipv6的ip地址
本文主要通过阿里云提供的clb和nlb来实现,建议是提前创建好双栈的vpc和vsw(使用clb可以不用双栈vpc和vsw)
192 1