keepalived容灾方案,实现nginx负载均衡主从架构(1)
一:环境准备:4台nginx服务器,两台用yum安装,两台使用源码安装
第一步:使用yum安装nginx服务器,在浏览器输入ip,可以显示以下内容,这步比较简单,安装好修改/usr/share/nginx/html/index.html就可以显示了:

第二步:使用源码部署nginx,操作步骤如下所示
~:$ yum -y install pcre-devel zlib-devel
~:$ yum -y groupinstall "Development Tools"
~:$ wget http://nginx.org/download/nginx-1.16.1.tar.gz -O /opt/nginx-1.16.1.tar.gz
~:$ tar xf /opt/nginx-1.16.1.tar.gz -C /opt/
~:$ useradd -s /sbin/nologin nginx
~:$ cd /opt/nginx-1.16.1/
/opt/nginx-1.16.1:$ ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx
/opt/nginx-1.16.1:$ make && make install
$ vim /usr/bin/nginxctl -- 设置nginx控制启动命令 #以下是制作一个控制命令的脚本
#!/usr/bin/env bash
#
# nginx service control
case $1 in
stop)
/usr/local/nginx/sbin/nginx -s quit
;; start)
/usr/local/nginx/sbin/nginx
;; reload)
/usr/local/nginx/sbin/nginx -s reload
; ; *)
echo "please input (start|stop|reload)"
;;
esac
#接下来便是准备nginx主配置文件,用于配置负载均衡加反向代理,有3种配置方案,可以进行随意搭配
user nginx;
worker_processes auto;
error_log logs/error.log;
events {
use epoll;#使用异步方式
worker_connections 1024;#最大并发数
}
http {
include mime.types;
default_type application/octet-stream;
log_format main '$remote_addr' - '$remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log logs/loadbalance_access.log main;
sendfile on;
keepalive_timeout 65;
轮询方式:按照时间顺序依次分配请求到后端
upstream myweb01 {
server 192.168.161.21:80;
server 192.168.161.22:80;
server 192.168.161.23:80;
}
ip_hash会话保持:针对解决session会话问题
upstream myweb02 {
server 192.168.161.21:80;
server 192.168.161.22:80;
server 192.168.161.23:80;
ip_hash;
}
weight权重:用于解决后端服务器性能不均情况;权重值越大,被访问到的几率就越大;
upstream myweb03 {
server 192.168.161.21:80 weight=6;
server 192.168.161.22:80 weight=3;
server 192.168.161.23:80 backup;
}
server {
listen 80;
server_name www.bavdu.com;
location / {
#配置反向代理至upstream地址池,由upstream分配请求至地址池中的某台机器;
proxy_pass http://myweb;
#设置反向代理可以获取到用户的真实IP地址;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
#允许客户端请求的最大单文件字节数;
client_max_body_size 10m;
#缓冲区代理缓冲用户端请求的最大字节数;
client_body_buffer_size 128K;
#和后端服务器连接超时时间;
proxy_connect_timeout 90;
#接收后端服务器响应超时时间;
proxy_read_timeout 90;
#设置保存用户头部信息的缓冲区大小;
proxy_buffer_size 4k;
#高负荷下缓冲区大小;
proxy_busy_buffers_size 64k;
}
}
}
负载均衡加反向代理实现好之后,接下来就是安装keepalived,主从的配置也不一样
nginx-loadbalance-master:设置vip
~:$ ifconfig ens33:1 192.168.161.100 broadcast 192.168.161.255 netmask 255.255.255.0 up
~:$ route add -host 192.168.161.100 dev ens33:1
主机安装keepalived服务
~:$ yum -y install openssl-devel popt-devel libnl-devel kernel-devel
~:$ wget https://www.keepalived.org/software/keepalived-2.0.18.tar.gz
~:$ tar xf keepalived-2.0.18.tar.gz
~:$ cd keepalived-2.0.18
keepalived-2.0.18:$ ./configure --prefix=/usr/local/keepalived
keepalived-2.0.18:$ make && make install
配置keepalived服务
~:$ mkdir -p /etc/keepalived
~:$ ln -s /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/#从机不需要此操作
~:$ systemctl start keepalived && systemctl status keepalived
~:$ cp /usr/local/keepalived/etc/keepalived/{keepalived.conf,keepalived.conf.old}
~:$ vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived
global_defs {
router_id loadbalance01 # 设定本机的唯一标识,一般为主机名
}
vrrp_script check_nginx_status {
script /etc/keepalived/check_nginx_status.sh # 指定脚本位置
interval 5 # 执行脚本的间隔
weight -20 # 设置脚本执行优先级
}
前提nginx要启动才会有虚拟ip出现,当nginx停止后,便会执行脚本,停止keepalived,便会进行ip漂移
vrrp_instance VI_1 {
state MASTER #标示状态为MASTER 备份机为BACKUP
interface ens33 #设置实例绑定的网卡
virtual_router_id 51 #virtual_router_id必须相同
priority 100 #MASTER权重要高于BACKUP 比如BACKUP为99
advert_int 1 #MASTER与BACKUP负载均衡器之间同步检查的时间间隔,单位是秒
authentication { #主从服务器验证方式
auth_type PASS
auth_pass 123456
}
virtual_ipaddress { #设置vip
192.168.161.100
}
track_script { #执行检查脚本,当检测到nginx宕掉后,把keepalived也杀死,从而进行故障转移
check_nginx_status
}
}
这个脚本是检测nginx是否运行,如果没有运行就执行杀死keepalived的进程,一旦进程杀死,虚拟ip便会漂移到从机上,
!/usr/bin/env bash
file: /etc/keepalived/check_nginx_status.sh
usage: monitor nginx status;
nginx_number=$(ps -C nginx | grep -v PID | wc -l)
if [ ${nginx_number} -eq 0 ];then
yum -y install psmisc &
killall keepalived &
fi
从机节点的设置
从节点配置
! Configuration File for keepalived
global_defs {
router_id loadbalance02
}
vrrp_script check_nginx_status {
script /etc/keepalived/check_nginx_status.sh
interval 5
weight -20
}
vrrp_instance VI_1 {
state BACKUP
interface ens33
virtual_router_id 51 #必须和主设置一样
priority 99 #必须比主机的小,优先级低
advert_int 1 #1s检测一次
authentication {
auth_type PASS
auth_pass 123456
}
virtual_ipaddress {
192.168.161.100 #一个虚拟ip,但是要在同网段上
}
track_script {
check_nginx_status
}
}
keepalived容灾方案,实现nginx负载均衡主从架构(1)的更多相关文章
- lvs(+keepalived)、haproxy(+heartbeat)、nginx 负载均衡的比较分析
目前使用比较多的就是标题中提到的这两者,其实lvs和haproxy都是实现的负载均衡的作用,keepalived和heartbeat都是提高高可用性的,避免单点故障.那么他们为什么这么搭配,而又有什么 ...
- Nginx负载均衡(架构之路)
[前言] 在大型网站中,负载均衡是有想当必要的.尤其是在同一时间访问量比较大的大型网站,例如网上商城,新闻等CMS系统,为了减轻单个服务器的处理压力,我们引进了负载均衡这一个概念,将一个服务器的压力分 ...
- Nginx(七):keepalived实现Nginx负载均衡服务器的双机高可用
前言 之前咱们通过 Nginx(六):Nginx HTTP负载均衡和反向代理的配置与优化 和 Nginx+tomcat组合实现高并发场景的动静分离和负载均衡方案 这两篇文章了解了Nginx对高并发应用 ...
- 企业级Nginx负载均衡与keepalived高可用实战(二)keepalived篇
1.Keepalived高可用软件 1.1.Keepalived介绍 Keepalived软件起初是专门为LVS负载均衡软件设计的,用来管理并监控LVS集群系统中各个服务节点的状态,后来又加入了可以实 ...
- 企业级Nginx负载均衡与keepalived高可用实战(一)Nginx篇
1.集群简介 1.1.什么是集群 简单地说,集群就是指一组(若干个)相互独立的计算机,利用高速通信网络组成的一个较大的计算机服务系统,每个集群节点(即集群中的每台计算机)都是运行各自服务的独立服务器. ...
- Net分布式系统之三:Keepalived+LVS+Nginx负载均衡之高可用
上一篇写了nginx负载均衡,此篇实现高可用(HA).系统整体设计是采用Nginx做负载均衡,若出现Nginx单机故障,则导致整个系统无法正常运行.针对系统架构设计的高可用要求,我们需要解决Nginx ...
- Nginx+Keepalived 实现双击热备及负载均衡
Nginx master : 10.1.58.191 Nginx负载均衡主机 Nginx slave : 10.1.58.181 Nginx负载均衡备机Nginx_VIP_TP: 10 ...
- Nginx+keepalived做双机热备加tomcat负载均衡
Nginx+keepalived做双机热备加tomcat负载均衡 环境说明: nginx1:192.168.2.47 nginx2:192.168.2.48 tomcat1:192.168.2.49 ...
- Keepalived+LVS+Nginx负载均衡之高可用
Keepalived+LVS+Nginx负载均衡之高可用 上一篇写了nginx负载均衡,此篇实现高可用(HA).系统整体设计是采用Nginx做负载均衡,若出现Nginx单机故障,则导致整个系统无法正常 ...
随机推荐
- sqli-labs(25a)
0X01 看见bind好像是盲注的意思 尝试闭合语句 加入’ 报错 双引号也报错 难道是不许要闭合的? 我们尝试一下 发现过滤了and ?id= and = 那么我们构造 ?id= aandnd = ...
- 挖矿病毒DDG的分析与清除
注:以下所有操作均在CentOS 7.2 x86_64位系统下完成. 今天突然收到“阿里云”的告警短信: 尊敬的****:云盾云安全中心检测到您的服务器:*.*.*.*(app)出现了紧急安全事件:挖 ...
- JS将页面中表格,导出到Excel中(IE中)
原文地址:http://blog.csdn.net/sinat_15114467/article/details/51098522 var idTmr; function getExplorer() ...
- 八、RF的内置变量
1.表示“空”的变量 ${EMPTY} 空 适用输入空的案例 2.表示“空格”的变量 ${SPACE} 空格,如果是需要5个空格可以这样写${SPACE*5} 3.目录的绝对路径 ${CURDIR} ...
- 在SOUI3中使用预编译XML
传统的XML文件通常是utf8编码的文本文件.使用文本文件好处在于方便查阅及修改. SOUI使用XML做为布局描述语言,所有的布局资源都是XML.文本文件格式自由,XML解析器需要对文件中的字符逐个解 ...
- 【mysql】查询最新的10条记录
实现查询最新10条数据方法: select * from 表名 order by id(主键) desc limit 10 参考文档: MySQL查询后10条数据并顺序输出
- Openstack_单元测试工具 tox
目录 目录 扩展阅读 Openstack 的单元测试工具 单元测试工具使用流程 tox toxini 参考文章 扩展阅读 Python Mock的入门 Openstack 的单元测试工具 unitte ...
- lnmp 安装 访问 配置 laravel
环境要求 Lnmp 一键安装包安装 php7.2+ Mysql 5.7 Innodb 开启 第一步 上传项目到 /home/wwwroot/default/ 或者composer命令行安装larave ...
- MariaDB增删改
1.MariaDB 数据类型 MariaDB数据类型可以分为数字,日期和时间以及字符串值. 使用数据类型的原则:够用就行, 尽量使用范围小的,而不用大的 常用的数据类型: 1.整数:int, bit( ...
- lsb-realse
[root@localhost ~]# lsb_release -a -bash: lsb_release: command not found 解决方法:yum install redhat-lsb ...