在高可用集群环境中,一般都需要使用浮动IP来实现web高可用(High Availability)。

浮动IP的概念以及为什么需要浮动IP请参考:https://blog.csdn.net/readiay/article/details/53538085

本篇文章主要讲实际操作步骤:

可以是双机,也可以是多机,主服务器为10.61.1.22,从服务器为10.61.1.23,浮动IP设置为10.61.1.212。

一、配置浮动IP:

利用单个网卡可以绑定多个IP地址的技术。

1、在“主服务器”配置浮动IP

在主服务器上拷贝eth0为eth0:1,并做修改。

cp /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/sysconfig/network-scripts/ifcfg-eth0:1

编辑文件ifcfg-eth0:1:

vim /etc/sysconfig/network-scripts/ifcfg-eth0:1

修改DEVICE为eth0:1,NM_CONTROLLED设置为no,IPADDR改为浮动IP地址10.61.1.212,去掉网关信息,修改完如下:

DEVICE="eth0:1"

BOOTPROTO="static"

ONBOOT="yes"

NM_CONTROLLED="no"

TYPE="Ethernet"

IPADDR="10.61.1.212"

NETMASK="255.255.255.0"

或者:

DEVICE=eth0:1

IPADDR=10.61.1.212

NETMASK=255.255.255.0

ONBOOT=yes

然后启动该网卡,验证是否生效:

ifup eth0:1

查看是否有浮动IP地址:

ip addr或者ip a

接着访问浮动IP地址10.61.1.212,能访问成功,即和主服务器10.61.1.22访问的一样,则说明配置成功。

2、在“从服务器”配置浮动IP

配置步骤和主服务器完全一样,eth0:1的IP地址同样设置成浮动IP:10.61.1.212,在启动网卡测试之前,需在"主服务器"关闭浮动IP:

ifdown eth0:1

然后在"从服务器"启动eth0:1

ifup eth0:1

测试步骤也和"主服务器"一样。

3、其他“从服务器”配置浮动IP

如果还有其他从服务器,配置步骤如步骤“2”。

二、写脚本完成浮动IP的自动开启与关闭

利用crontab自动执行技术,定时检查IP地址的状态,并启动eth0:1或者关闭eth0:1。

1、“从服务器”脚本

在root目录下

#生成脚本文件

touch slaveFloatIP.sh

#编写脚本

vim slaveFloatIP.sh

复制下面的的代码进去:

MASTER_IP="10.61.1.22"

FLOAT_IP="10.61.1.212"

c1=$(/usr/bin/ping $MASTER_IP -c 1|grep Unreachable|wc -l)

c2=$(/usr/bin/ping $FLOAT_IP -c 1|grep Unreachable|wc -l)

c3=$(/usr/sbin/ip addr|grep eth0:1)

if[ $c1 -gt 0 -o $c2 -gt 0 ]

then

/usr/sbin/ifup eth0:1

elif [ $c1 -eq 0 -a $c2 -eq 0 -a "$c3" ]

then

/usr/sbin/ifdown eth0:1

fi

说明:

ping主服务器IP地址或者ping浮动IP地址,如果ping不通,说明主服务器挂掉了或者没启动浮动IP,则在从机上启动浮动IP。

当主服务器再上线,即能够ping通主服务器且能ping通浮动IP地址,则在从机上关闭浮动IP。

备注:

如果还有其他从服务器,只需拷贝该脚本。

2、“主服务器”脚本

在root目录下

#生成脚本文件

touch masterFloatIP.sh

#编写脚本

vim masterFloatIP.sh

复制下面的的代码进去:

FLOAT_IP="10.61.1.212"

c=$(/usr/bin/ping $FLOAT_IP -c 1|grep Unreachable|wc -l)

if [ $c -gt 0 ]

then

/usr/sbin/ifup eth0:1

fi

说明:

ping不通浮动IP地址,则启动eth0:1

3、使用crontab每隔5秒自动执行脚本。

使用crontab -e命令

进入文件编辑界面,“主服务器”配置如下:

* * * * * /root/masterFloatIP.sh

* * * * * sleep 5; /root/masterFloatIP.sh

* * * * * sleep 10; /root/masterFloatIP.sh

* * * * * sleep 15; /root/masterFloatIP.sh

* * * * * sleep 20; /root/masterFloatIP.sh

* * * * * sleep 25; /root/masterFloatIP.sh

* * * * * sleep 30; /root/masterFloatIP.sh

* * * * * sleep 35; /root/masterFloatIP.sh

* * * * * sleep 40; /root/masterFloatIP.sh

* * * * * sleep 45; /root/masterFloatIP.sh

* * * * * sleep 50; /root/masterFloatIP.sh

* * * * * sleep 55; /root/masterFloatIP.sh

“从服务器”配置也是一样的,脚本路径改为 /root/slaveFloatIP.sh

4、结果

到这里就完成了浮动IP的配置和主从服务器自动开启浮动IP。

完成后就可以通过浮动IP地址访问,服务器集群内只要有一台服务器正常运行,web就能访问,实现了web高可用。

Linux配置浮动IP的更多相关文章

  1. Linux配置浮动IP实现WEB高可用

    在高可用集群环境中,一般都需要使用浮动IP来实现web高可用(High Availability). 浮动IP的概念以及为什么需要浮动IP请参考:浮动IP(FLOAT IP) 本篇文章主要讲实际操作步 ...

  2. Linux系统浮动IP的配置

    什么是浮动IP,为什么要配置浮动IP 首先说一下为什么要配置浮动IP. 原文链接:https://blog.csdn.net/readiay/article/details/53538085 现在有一 ...

  3. linux配置网卡IP地址命令详细介绍及一些常用网络配置命令

    linux配置网卡IP地址命令详细介绍及一些常用网络配置命令2010-- 个评论 收藏 我要投稿 Linux命令行下配置IP地址不像图形界面下那么方 便,完全需要我们手动配置,下面就给大家介绍几种配置 ...

  4. 详述Linux配置静态IP、设置DNS和主机名(一)

    Linux配置静态IP.设置DNS和主机名首先要找到配置文件,这是在Linux系统下进行工作的必须知道工作方式.后面一步步的跟着这个范例来进行配置相信你最终也会完成Linux配置静态IP.设置DNS和 ...

  5. Linux配置代理IP

    Linux配置代理IP: vim /etc/profile http_proxy=http://username:password@ip:port/ https_proxy=http://userna ...

  6. Linux 配置多IP

    这里以红帽Linux为例.假定原系统已配置一个IP,地址为:192.168.20.140,配置文件路径/etc/sysconfig/network-script/ifcfg-eth0.现在需要配置一个 ...

  7. Linux 配置静态Ip地址

    注:所有红色字体标注均为 Linux 的 操作命令 ! 1, 使用root账户登录系统 2, 可以先使用 ifconfig : 查看网卡信息   eth0 为默认的第一个网卡 , 如果有第二个就会显示 ...

  8. Linux配置临时IP地址

    # ifconfig 查看网卡信息,如下图所示: # ifconfig eth0 192.168.0.107 eth0表示第一块网卡,Linux中所有的设配都是文件,所以eth0是第一块网卡的文件名, ...

  9. Linux配置静态IP

    在一块SSD的CentOS配置静态IP 1. 配置静态IP #vi /etc/sysconfig/network-scripts/ifcfg-eth0   DEVICE="eth0" ...

随机推荐

  1. SpringMVC中文乱码的解决办法

    中文乱码分类: (1)按照请求分类: GET请求乱码 POST请求乱码 (2)按照乱码位置分类 从前台传到后台的数据乱码(存储到数据库中的数据乱码) 从后台传到前台的数据乱码(显示在页面的数据乱码) ...

  2. day36 数据库表操作 数据类型 完整性约束

    今日内容 1.存储引擎表类型 2.数据类型 3.完整性约束 1.存储引擎表类型 指令: 1.show engines:#查看MySQL所有的引擎, 2.show variables like &quo ...

  3. vue-7-表单

    示例: <input v-model="message" placeholder="edit me"> <p>Message is: { ...

  4. python中的各种模块(np,os,shutill)

    PS:本博文摘抄自中国慕课大学上的课程<Python数据分析与展示>,推荐刚入门的同学去学习,这是非常好的入门视频. #np模块 .ndim :维度 .shape :各维度的尺度 (2,5 ...

  5. hibernate查询oracle数据库表报错SQL state [null]; error code [17027]; 流已被关闭; nested exception is java.sql.SQLException: 流已被关闭

    把表字段类型 long 修改为 number类型即可

  6. 谈谈你对Java面向对象的理解

    面向对象,其实是一种思考的思想,是一种思想,而这种思想它早期的思想是面向过程,通过不断的演化变成了现在的面向对象,思想有一个演变形式,早期是面向过程,现在是面向对象. 故事:把大象放进冰箱里,分几步? ...

  7. 驱动链表(LIST_ENTRY)

    DDK提供了两种链表的数据结构,双向链表和单向链表,其定义如下: typedef struct _LIST_ENTRY { struct _LIST_ENTRY *Flink; struct _LIS ...

  8. centos7配置mysql

    一:mysql安装方法一:yum安装 下载并安装MySQL官方的 Yum Repository https://dev.mysql.com/ cd ~ wget -i -c https://dev.m ...

  9. 201621123001 《Java程序设计》第11周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 一个进程可以同时运行多个不同线程,不同的线程执行不同的任务 Java线程是通过java.lang包中定义的Thre ...

  10. <Spark Streaming><Flume><Integration>

    Overview Flume:一个分布式的,可靠的,可用的服务,用于有效地收集.聚合.移动大规模日志数据 我们搭建一个flume + Spark Streaming的平台来从Flume获取数据,并处理 ...