如何给两台机器集群设置VIP(虚拟IP)

原文链接:https://www.cnblogs.com/qianz/articles/16825567.html

一、环境准备

1.集群 IP部署

172.16.30.181是主节点,172.16.30.182是备节点,VIP是172.16.30.183

我是在openstack上搭建的集群,建议大家将需要用到的IP都固定到端口上,不要绑定浮动的IP,以免会出现网络跳动,导致IP配置失败。

二、配置VIP

1.安装 keepalived

两台机器上都要进行安装

|---|-----------------------------|
| 1 | yum install -y keepalived |

有时候需要先卸载再安装。卸载命令:yum -y remove keepalived

2.配置文件 keepalived.conf

|---|---------------------------------------|
| 1 | vim /etc/keepalived/keepalived.conf |

  • master上修改配置内容

|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | vrrp_instance VI_1 { ``state MASTER ``interface eth0 # VIP绑定网卡 ``virtual_router_id 51 ``priority 101 ``advert_int 1 ``authentication { ``auth_type PASS # VRRP验证类型,PASS、AH两种 ``auth_pass 1111 # VRRP验证密码,在同一个vrrp_instance下,主、从必须使用相同的密码才能正常通信 ``} ``virtual_ipaddress { ``172.16.30.183 ##虚拟IP地址(VIP) ``} ``unicast_src_ip 172.16.30.181 ##(本地IP地址) ``unicast_peer { ``172.16.30.182 ##(对端IP地址)此地址一定不能忘记 ``} } |

  • slave上修改配置内容

|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | vrrp_instance VI_1 { ``state BACKUP ``interface eth0 # VIP绑定网卡 ``virtual_router_id 51 ``priority 100 ``advert_int 1 ``authentication { ``auth_type PASS # VRRP验证类型,PASS、AH两种 ``auth_pass 1111 # VRRP验证密码,在同一个vrrp_instance下,主、从必须使用相同的密码才能正常通信 ``} ``virtual_ipaddress { ``172.16.30.183 ##虚拟IP地址(VIP) ``} ``unicast_src_ip 172.16.30.182 ##(本地IP地址) ``unicast_peer { ``172.16.30.181 ##(对端IP地址)此地址一定不能忘记 ``} } |

参数解释:

state 服务状态;MASTER(工作状态)BACKUP(备用状态)

priority 优先级;取值范围:0~254;MASTER > BACKUP

(只要保证主节点的priority大于备节点就可以)

virtual_ipaddress表示虚拟ip的地址,主、备节点必须一致,可以定义多个VIP

注意要在配置文件里加入以下配置:

|---------|----------------------------------------------------------------------------------------------|
| 1 2 3 4 | unicast_src_ip 172.16.30.xxx ##(本地IP地址) unicast_peer { ``172.16.30.xxx ##(对端IP地址) } |

如果不加入以上配置,可能在两台机器上可以同时看到VIP,这样就失去了我们设置集群VIP的意义。

出现这种问题是因为路由交换层禁用了ARP的广播限制,造成Keepalive主备协议无法通过广播的方式进行通信,造成主备两台服务器都强占HAVIP地址,出现同时两台服务器都有VIP地址的情况出现,必须通过配置来指定IP的两台服务器间进行通讯。

3.启动 keepalived 服务

|-----|-------------------------------------------------------------------------------------------|
| 1 2 | systemctl start keepalived.service #启动服务 systemctl enable keepalived.service #开机自启动服务 |

  • master上的IP地址信息

|---|---------------------|
| 1 | ip addr show eth0 |

  • slave上的IP地址信息

可以看到这时候,VIP绑定在了主节点上。

当主机点上的keepalived 服务停止时,VIP又绑定在备节点上了。

相关推荐
等风来不如迎风去17 分钟前
用你本地已有的私钥(private key)去 SSH 登录远程 Ubuntu 服务器
服务器·ubuntu·ssh
tomcsdn4123 分钟前
SMTPman高效稳定的smtp服务器使用指南解析
服务器·邮件营销·外贸开发信·邮件群发·域名邮箱·邮件服务器·红人营销
艾莉丝努力练剑24 分钟前
【Linux指令 (二)】不止于入门:探索Linux系统核心与指令的深层逻辑,理解Linux系统理论核心概念与基础指令
linux·服务器·数据结构·c++·centos
conkl35 分钟前
Linux IP 网络配置与管理详解
linux·网络·tcp/ip
lijunjun1 小时前
当ubuntu 系统的IP地址修改之后,gitlab服务应该如何修改?
tcp/ip·ubuntu·gitlab
weixin_441455261 小时前
Mysql MVCC
数据库·mysql
Su-RE1 小时前
【ElasticSearch】text 和 keyword 类型区分
java·数据库·elasticsearch
武子康1 小时前
Java-146 深入浅出 MongoDB 数据插入、批量写入、BSON 格式与逻辑查询and or not操作指南
java·开发语言·数据库·sql·mongodb·性能优化·nosql
奥尔特星云大使1 小时前
MySQL快速构建主从(基于GTID)
数据库·mysql·主从复制
小园子的小菜1 小时前
MySQL ORDER BY 深度解析:索引排序规则与关键配置参数阈值
数据库·mysql