文章目录
-
- keepalived介绍
- 环境准备
- 实现架构
- 小结
keepalived介绍
keepalived是什么:
keepalived是集群管理中保证集群高可用的一个服务软件,用来防止单节点故障。
keepalived工作原理:
keepalived是以VRRP协议为实现基础的,VRRP全称Virtual Router Redundancy Protocol,即虚拟路由冗余协议。
虚拟路由冗余协议:
可以认为是实现高可用的协议,即将N台提供相同功能的路由器组成一个路由器组,这个组里面有一个master和多个backup,master上面有一个对外提供服务的vip(该路由器所在局域网内其他机器的默认路由为该vip),master会发组播,当backup收不到vrrp包时就认为master宕掉了,这时就需要根据VRRP的优先级来选举一个backup当master。这样的话就可以保证路由器的高可用了。
keepalived主要有三个模块,分别是core、check和vrrp。core模块为keepalived的核心,负责主进程的启动、维护以及全局配置文件的加载和解析。check负责健康检查,包括常见的各种检查方式。vrrp模块是来实现VRRP协议的。
整体架构流程
环境准备
1.ip
准备四台机器:
c1 192.168.43.121
c2 192.168.43.123
c3 192.168.43.124
c4 192.168.43.127
2.软件环境
1.keepalived
2.nginx
c1和c2做代理服务器,c3和c4做真实服务器提供页面
##为了方便,我从c1(master),c2(salve)选择nginx做了代理,c3,c4还是选择nginx提供了页面
架构实现
Master
1. 下载nginx
yum -y install nginx
2. 做负载均衡
cd /etc/nginx/conf.d
mv default.cong default.conf.bak
vim default.conf
####添加以下内容#########
upstream index {
server 192.168.43.124:80 weight=1 max_fails=2 fail_timeout=2;
server 192.168.43.127:80 weight=2 max_fails=2 fail_timeout=2;
}
server {
listen 80;
server_name localhost;
access_log /var/log/nginx/host.access.log main;
location / {
proxy_pass http://index;
proxy_redirect default;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
Slave
1. 下载nginx
yum -y install nginx
2. 做负载均衡
upstream index {
server 192.168.246.162:80 weight=1 max_fails=2 fail_timeout=2;
server 192.168.246.163:80 weight=2 max_fails=2 fail_timeout=2;
}
server {
listen 80;
server_name localhost;
access_log /var/log/nginx/host.access.log main;
location / {
proxy_pass http://index;
proxy_redirect default;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}