博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Keepalived安装与配置
阅读量:6080 次
发布时间:2019-06-20

本文共 5175 字,大约阅读时间需要 17 分钟。

一、概述

  keepalived介绍:Keepalived的作用是检测中间件服务器的状态,如果有一台中间件服务器死机,或工作出现故障,Keepalived将检测到,并将有故障的中间件服务器从系统中剔除,当中间件服务器工作正常后Keepalived自动将中间件服务器加入到服务器群中,这些工作全部自动完成,不需要人工干涉,需要人 工做的只是修复故障的中间件服务器。
二、环境
vip:192.168.1.203\204
mysql-master:192.168.1.231
mysql-slave:192.168.1.232
三、keepalived安装
安装步骤两台机mysql-master、mysql-slave一样,如下:
1、下载地址:http://www.keepalived.org/software/keepalived-1.2.12.tar.gz
2、安装环境

yum -y install openssl-devel

否则会报如下错误

configure: error:
  !!! OpenSSL is not properly installed on your system. !!!
  !!! Can not include OpenSSL headers files.
3、安装

tar -zxvf keepalived-1.2.12.tar.gzcd keepalived-1.2.12./configure --prefix=/keepalived --with-kernel-dir=/usr/src/kernels/2.6.32-431.el6.x86_64/makemake install

说明:

 --prefix:安装路径

 --with-kernel-dir:这个是重要的参数,这个参数并不表示我们要把Keepalived统进内核,而是指使用内核源码里面的头文件,也就是include目录。
  2.6.32-431.el6.x86_64可以通过
uname -r 命令查看到
 4、配置

# cp /keepalived/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/# cp /keepalived/etc/sysconfig/keepalived /etc/sysconfig/# mkdir /etc/keepalived# cp /keepalived/etc/keepalived/keepalived.conf /etc/keepalived/# cp /keepalived/sbin/keepalived /usr/sbin/

 5、启动/停止

service keepalived startservice keepalived stopservice keepalived restart

四、keepalived配置

1、mysql-master:192.168.1.231的配置

vi /etc/keepalived/keepalived.conf

配置如下:

global_defs { router_id mysql-master #修改为自己的主机名 notification_email { mengtao10@163.com #接收邮件,可以有多个,一行一个} #当主、备份设备发生改变时,通过邮件通知 notification_email_from lzyangel@126.com #发送邮箱服务器 smtp_server stmp.163.com #发送邮箱超时时间 smtp_connect_timeout 30 }##################第一部分###################vrrp_instance VI_1 {     state BACKUP #都修改成BACKUP     interface eth0 #绑定的网卡     virtual_router_id 60 #默认51 主从都修改为60     priority 100 #优先级,在mysql-slave上LVS上修改成80     advert_int 1     nopreempt #不抢占资源,意思就是它活了之后也不会再把主抢回来     authentication {     # 认证方式,可以是PASS或AH两种认证方式     auth_type PASS     # 认证密码     auth_pass 1111     }virtual_ipaddress {     192.168.1.203     192.168.1.204 #这可以增加多个VIP     }}##################第二部分###################virtual_server 192.168.1.203 3306 {     delay_loop 6     lb_algo wrr     lb_kind DR     nat_mask 255.255.255.0     persistence_timeout 50     protocol TCP    real_server 192.168.1.231 3306 {     weight 1     notify_down /root/mysql_down.sh     TCP_CHECK {         connect_timeout 10         nb_get_retry 3         connect_port 3306         }     }}

 2、mysql-master:192.168.1.232的配置

/etc/keepalived/keepalived.conf

 配置如下:

global_defs { router_id mysql-master #修改为自己的主机名 notification_email { mengtao10@163.com #接收邮件,可以有多个,一行一个} #当主、备份设备发生改变时,通过邮件通知 notification_email_from lzyangel@126.com #发送邮箱服务器 smtp_server stmp.163.com #发送邮箱超时时间 smtp_connect_timeout 30 }##################第一部分###################vrrp_instance VI_1 {     state BACKUP #都修改成BACKUP     interface eth0 #绑定的网卡     virtual_router_id 60 #默认51 主从都修改为60     priority 80 #优先级,在mysql-master上LVS上修改成100     advert_int 1     authentication {     # 认证方式,可以是PASS或AH两种认证方式     auth_type PASS     # 认证密码     auth_pass 1111     }virtual_ipaddress {     192.168.1.203     192.168.1.204 #这可以增加多个VIP     }}##################第二部分###################virtual_server 192.168.1.203 3306 {     delay_loop 6     lb_algo wrr     lb_kind DR     nat_mask 255.255.255.0     persistence_timeout 50     protocol TCP    real_server 192.168.1.232 3306 {     weight 1     notify_down /root/mysql_down.sh     TCP_CHECK {         connect_timeout 10         nb_get_retry 3         connect_port 3306         }     }}

 3、myslq_down.sh配置,两台机都要配置这一步!!!

这里需要注意的是,notify_down /root/mysql_down.sh这个选项,这个是是在keepalived检测不到mysql的时候要执行的脚本,从上面的配置文件来看real服务器只有本机。那么,keeaplived如果启动,客户端也只是访问本机的mysql。nopreempt这个选下也得注意,这个是不抢占资源在优先级高的机器上配置就可以。
看下这个脚本的内容:

# vi /root/mysql_down.sh#!/bin/bashpkill keepalived# chmod +x /root/mysql_down.sh #授权可执行权限

脚本内容就一条命令:pkill keepalived,主要作用是如果本机的mysql挂掉了,那么同时会杀死本机的keepalived,这样另外一台就会接替他工作,虚拟IP也会被另一台接管,如果不杀死keepalived虚拟IP不会被另一台接管,mysql访问也就不会切换过去。

 注意:必须要先启动MYSQL,再启动keepalived,否则keepalived启动后会运行mysql_down.sh脚本,等于自杀。
4、mysql-master(231)启动后查看IP的绑定情况,如下:

ifconfig -a1: lo: 
mtu 16436 qdisc noqueue state UNKNOWN link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 inet 127.0.0.1/8 scope host lo inet6 ::1/128 scope host valid_lft forever preferred_lft forever2: eth0:
mtu 1500 qdisc pfifo_fast state UP qlen 1000 link/ether 08:00:27:cc:92:22 brd ff:ff:ff:ff:ff:ff inet 192.168.1.232/24 brd 192.168.1.255 scope global eth0 inet 192.168.1.203/32 scope global eth0 inet 192.168.1.204/32 scope global eth0 inet6 fe80::a00:27ff:fecc:9222/64 scope link valid_lft forever preferred_lft forever

五、测试

1、231、232两台机同时启动MYSQL及Keepalived.
   通过连接VIP:192.168.1.203或204,如下:

mysql -h192.168.1.203 -usunney -p
mysql> show databases;

注意:这时存储的数据库是mysql-master(192.168.1.231)因为他是主库。配置 priority 100 优先级高。
2、mysql-slave(232)的机同时关闭MYSQL及Keepalived.这时关闭上以上的是一样的。因为他没有走这个库。
3、mysql-master(231)同时关闭MYSQL及Keepalived,mysql-slave(232)同时启动MYSQL及Keepalived

切换很快,大概在2到3秒之间!

通过连接VIP:192.168.1.203或204,如下:

mysql -h192.168.1.203 -usunney -p
mysql> show databases;

参考http://www.cnblogs.com/yuanermen/p/3735263.html

转载于:https://www.cnblogs.com/priestess-zhao/p/8268369.html

你可能感兴趣的文章
Windows Server 2008 计划任务配置(任务计划程序)每分钟执行BAT
查看>>
【VNC】Linux环境VNC服务安装、配置与使用
查看>>
动态创建地图文档MXD并发布地图服务
查看>>
Repodata is over 2 weeks old. Install yum-cron? Or run: yum makecache fast
查看>>
单例模式讲解
查看>>
Linux权限管理(笔记)
查看>>
(笔记)电路设计(二)之串联匹配电阻的应用
查看>>
Linux下的grep搜索命令详解(二)
查看>>
C 基本语法
查看>>
Codeforces Round #258 (Div. 2) A. Game With Sticks 水题
查看>>
Server 2008 R2 事件查看器实现日志分析
查看>>
解决Cookie乱码问题
查看>>
javascript中的链表结构—从链表中删除元素
查看>>
用实例揭示notify()和notifyAll()的本质区别
查看>>
Android MediaPlayer接口及状态迁移
查看>>
JQuery------prevAll(),nextAll(),attr()方法的使用
查看>>
Disciz!NT开源资源汇总
查看>>
Python网络编程笔记
查看>>
Vim自动补全神器–YouCompleteMe
查看>>
Mysql 小工具
查看>>