Mysql+DRBD+Heartbeat 实现mysql高可用的双机热备(mysql+heartbeat篇)

*************************************部署MYSQL*******************************************

yum -y install  gcc gcc-c++ gcc-g77 autoconf automake zlib* fiex* libxml* ncurses-devel libmcrypt* libtool-ltdl-devel* make cmake bison*

useradd mysql -d /usr/local/mysql -s /sbin/nologin

tar -zxvf mysql-5.1.72.tar.gz

cd mysql-5.1.72.tar.gz

./configure --prefix=/usr/local/mysql/ --with-charset=utf8

make && make install

chown -R mysql.mysql /usr/local/mysql

cd /usr/local/mysql/scripts

./mysql_install_db --user=mysql --basedir=/usr/local/mysql/ --datadir=/data/mysql

copy配置文件到/etc目录

[[email protected] mysql-5.1.72]# cp support-files/my-medium.cnf /etc/my.cnf

copy启动脚本到资源目录

cp support-files/mysql.server /etc/rc.d/init.d/mysqld

添加mysql服务

[[email protected] mysql-5.1.72]#chmod +x /etc/rc.d/init.d/mysqld

mysqladmin –u root password 123456        //设置roo密码

10、启动mysql

[[email protected] mysql-5.1.72]#service mysqld start

#配置库文件搜索路径

#echo "/usr/local/mysql/lib/mysql" >> /etc/ld.so.conf

#ldconfig

#添加/usr/local/mysql/bin到环境变量PATH中

#export PATH=$PATH:/usr/local/mysql/bin

cp -R /data/mysql

chown -R mysql.mysql /data/mysql

##编辑Mysql的配置文件/etc/my.cnf

[[email protected] ~]# sed -n "/^[^#]/p" /etc/my.cnf

[mysqld]

server-id=1                     ##保证全局唯一

log-bin=mysql-bin ##开启记录二进制日志的功能

relay-log=mysql-relay-bin

datadir=/data/mysql/

socket=/data/mysql/mysql.sock

user=mysql

symbolic-links=0

[mysqld_safe]

log-error=/var/log/mysqld.log

pid-file=/var/run/mysqld/mysqld.pid

将mysql启动交给heartbeat来管理,在heartbeat资源脚本目录中建立mysql的启动脚本的软链接

ln -s /etc/init.d/mysqld /etc/ha.d/resource.d/mysqld

#####重启mysql服务#######

service mysqld restart

##############配置mysql的主从复制####################

在master上增加一个用于复制的帐号

mysql>GRANT REPLICATION SLAVE ON *.* TO ‘repl‘@‘10.0.0.2‘ IDENTIFIED BY ‘repl123456‘;

备份master上的数据,首先执行如下语句:

mysql>FLUSH TABLES WITH READ LOCK;

mysql>reset master;

不要退出终端,否则这个锁就失效了,在不退出终端的情况下,再开启一个终端直接打包压缩数据文件或使用mysqldump工具来导出数据。

cd /data/mysql

tar zcvf mysql.tar.gz /data/mysql

scp mysql.tar.gz  [email protected]:/root/

数据传输完成后,再刚刚执行FLUSHTABLES WITH READ LOCK 命令的master 终端上执行如下命令:

mysql> UNLOCK TABLES;

查看master的状态:

mysql>show master status\G   #以下面列出的配置,进行设置slave的MASTER_LOG_FILE值,和MASTER_LOG_POS值。

设置slave主机

开启master与slave的同步,在slave上执行下列语句:

mysql>CHANGE MASTER TO MASTER_HOST=‘10.0.0.1‘,

->MASTER_USER=‘repl‘,

->MASTER_PASSWORD=‘repl123456‘,

->MASTER_LOG_FILE=‘mysql-bin.000001‘,

->MASTER_LOG_POS=106;

完成后,开启slave

mysql>slave start;

查看slave状态

mysql>show slave status\G

当Slave_IO_Running 和Slave_SQL_Running 都为yes时,表示配置成功。

****************************需要注意的几个问题********************************

1)如果在my.cnf中定义了log-bin、relay-log参数,那么要保证这些定义与主机名无关,

因为如果这两类的log文件名与主机名有关,切换过程会导致slave主机不能继续同步,可以如下设置:

log-bin=mysql-bin

relay-log=mysql-relay-bin

保证两台主机上两个文件的名字一样

2)保证mysql能通过 start\stop\status 三个参数,默认heartbeat采用的是LSB风格,

返回值包含OK或者running则表示资源正常,返回值包含stopped或NO则表示资源不正常,其他资源脚本也类似。

3)不要设置mysql在机器重启时自动启动,mysqld作为heartbeat的一项资源,heartbeat会统一管理。

4)保证每台mysql的my.cnf配置文件 除了server-id以外的其他配置项一模一样。

************************************Heartbeat部署****************************************

两台主机的心跳网卡是eth1

node1的心跳IP是:10.0.0.1

node2的心跳IP是:10.0.0.2

安装heartbeat:

1、首先创建用户和组

groupadd -g 2000 haclient

useradd -u 2000 -g haclient hacluster

装heartbeat所需的软件包:

yum -y  install  pkgconfig glib2-devel  e2fsprogs  libxml2*  PyXML

再编译安装libnet

tar -zxvf libnet-1.1.2.1.tar.gz -C ./

./configure

make && make install

安装heartbeat

tar -zxvf heartbeat-2.1.2.tar.gz -C ./

./ConfigureMe configure

make&& make install

配置heartbeat

需要的配置文件有三个:ha.cf、haresources、authkeys。

这三个配置文件需要在/etc/ha.d 目录下面,但是默认是没有这三个文件的,所以你要:

copy 存放路径/heartbeat-2.1.2/doc/ha.cf         /etc/ha.d/

copy 存放路径/ heartbeat-2.1.2/doc/haresources  /etc/ha.d/

copy 存放路径/ heartbeat-2.1.2/doc/authkeys     /etc/ha.d/

修改authkeys的权限为600

chmod 600 /etc/ha.d/authkeys

配置ha.cf

[[email protected] ~]# sed -n "/^[^#]/p" /etc/ha.d/ha.cf

logfile /var/log/ha-log     #指定heartbeat日志的位置

logfacility local0

keepalive 1                 #每秒检测心跳

deadtime 15 #备用节点15s内没有检测到主机心跳,确认对方故障

warntime 5 #警告5次

initdead 30 #守护进程启动30s后,启动服务资源

ucast eth1 10.0.0.1 #另一台主机的eth1和eth0的ip地址,通过两个不同的网络来检测心跳可用性

ucast eth0 10.2.16.254

auto_failback off           #当主节点切换到备节点之后,主节点恢复正常后,不进行切回操作,因为切换一次mysql-master的成本很高

respawn hacluster /usr/lib64/heartbeat/ipfail

respawn hacluster /usr/lib64/heartbeat/dopd #开启dopd功能

apiauth ipfail gid=haclient uid=hacluster

apiauth dopd gid=haclient uid=hacluster

node node1 定义节点的主机名

node node2 定义节点的主机名

配置资源文件haresources

/etc/ha.d/haresources

node1  drbddisk::r0 Filesystem::/dev/drbd0::/data mysqld IPaddr::10.2.16.250/24/eth0

node1 是主节点的主机名

drbddisk是管理DRBD的脚本,默认heartbeat没有,需要拷贝此脚本到 /etc/ha.d/resource.d/drbddisk (文末有此脚本,直接复制粘贴即可)

r0是drbd的启动资源, “drbddisk::r0"可以切换drbd的主机为primary节点或secondary节点,只有状态为primary的节点才能挂载drbd分区

drbddisk脚本相当于执行drbdadm primary r0 或 drbdadm secondary r0操作,把drbd的资源角色变更并且挂载

mysqld 表示启动本机的mysql服务

Ipaddr::10.2.16.250/24/eth0 表示虚拟IP为250实现IP漂移

配置authkeys认证文件

/etc/ha.d/authkeys

auth 1

1 sha1 HA_cluster  #使用sha1验证,密码为:HA_cluster

#将drbddisk脚本加执行权限:

chmod+x /etc/ha.d/resource.d/drbddisk

将主节点设置好后,直接拷贝 ha.cf haresources authkeys 以及 drbddisk文件到 备节点

scp ha.cf haresources authkeys  resources.d/drbddisk  [email protected]:/root/

在备节点上移动至ha.d目录后,修改ha.cf的ucast值为主节点IP即可,其他不用变

确认mysql服务关闭后,在两台主机上,同时开启heartbeat服务

service heartbeat start

通过查看 /var/log/ha-log 来观察heartbeat的启动过程

Mysql+DRBD+Heartbeat 实现mysql高可用的双机热备(mysql+heartbeat篇),布布扣,bubuko.com

时间: 2024-10-25 15:36:42

Mysql+DRBD+Heartbeat 实现mysql高可用的双机热备(mysql+heartbeat篇)的相关文章

启博VPN高可用(HA)双机热备解决方案

有些用户的业务系统的特殊性,不允许长时间断网要保证系统的可靠性.通用的做法是布署两台相同配置的硬件VPN网关,一台设备设置为主模式,另一台设备设置为从模式.两台设备同时工作,如果主设备出现问题,另一台从设备会自动切换成主设备模式接管主设备的工作,不需要人工干预. 启博VPN双机热备(HA)功能除了支持常见的主从模式切换,还支持当主设备恢复工作后,会自动抢占成为主设备,从设备自动降为从设备工作模式.接线方式是通过网线把两台设备的LAN口连接起来,或者把两台设备LAN口接在同一个交换机上. 另外启博

Mysql+DRBD+Heartbeat 实现mysql高可用的双击热备(DRBD篇)

DRBD官方tar包下载地址:   http://oss.linbit.com/drbd/ 环境介绍: 系统版本:CentOS 6.4 (64位) 内核版本  2.6.32-358.el6.x86_64 软件版本:drbd-8.4.3.tar.gz 主:10.0.0.1   从:10.0.0.2 两台机器上的hosts都需要修改: [[email protected] ~]# vim /etc/hosts 10.0.0.1    node1 10.0.0.2    node2 两台服务器双网卡,

mysql流行的四种高可用架构之:Keepalived+Mysql Replication

关于MySQL-HA,目前有很多种解决方案,目前互联网上用的较多的是Keepalived+Mysql Replication组合.MMM+Mysql Replication组合.Heartbeat+DRBD+Mysql组合,以及红帽RHSC高可用集群套件.

Linux高可用集群方案之配置heartbeat v2基于crm+hb_gui接口,配置高可用httpd,mysql,lvs

本章主要配置heartbeat v2基于crm+hb_gui接口,配置高可用httpd,mysql,lvs. 如何安装heartbeat v2.httpd.nfs.配置心跳连接.ssh密钥通信.同步时间.添加名称解析.配置yum源等请参照: >> Linux高可用集群方案之配置heartbeat v2基于haresources配置文件的httpd高可用集群 http://ccschan.blog.51cto.com/11854461/1922966  ll  本文导航    · 前期准备及相关

常用数据库高可用和分区解决方案(1) — MySQL篇

在本文中我们将会讨论MySQL.Oracle.MongoDB.Redis以及Oceanbase数据库,大家可能会奇怪为什么看不到有名关系型数据库MSSQL.DB2或者有名NoSQL数据库Hbase.LevelDB等,最主要原因是我对这些数据库熟悉层度不够.但相信这些数据库都会有相应的解决方案. 首先我们看一下数据库以及常看到的HA以及分布式架构方案 数据库类型 架构方案 架构类型 MySQL Keepalived+MySQL Replication HA MHA+MySQL Replicatio

heartbeat v1(CRM)+DRBD实现数据库服务器高可用集群搭建

一. 方案简介 本方案采用Heartbeat双机热备软件来保证数据库的高稳定性和连续性,数据的一致性由DRBD这个工具来保证.默认情况下只有一台mysql在工作,当主mysql服务器出现问题后,系统将自动切换到备机上继续提供服务,当主数据库修复完毕,又将服务切回继续由主mysql提供服务. 二. 方案优缺点 优点:安全性高.稳定性高.可用性高,出现故障自动切换, 缺点:只有一台服务器提供服务,成本相对较高.不方便扩展.可能会发生脑裂. 三. 方案架构图 四.  方案适用场景 本方案适用于数据库访

MySQL双主+keepalived实现高可用

mysql+keepalived实现高可用+主主复制模式 为了解决mysql的单点故障问题,衍生出很多mysql的高可用方案: keepalived+双主.MHA.PXC.MMM.Hearbeat+DRBD等,比较常用的一般是keepalived+双主,MHA和PXC 在此搭建实验环境,实现keepalived+mysql双主模式. 实验思路: 两台MySQL互为主从关系(双主),通过keepalived配置虚拟vip,实现当其中的一台MySQL数据库宕机后,应用能自动切换到另外一台MySQL数

Linux集群(keepalived介绍,Keepalived配置高可用集群,Keepa+mysql

一.Linux集群概述 根据功能划分为两大类:高可用和负载均衡 (1)高可用集群通常为两台服务器,台工作,另外一台作为准备,当提供服务的机器宕机,另外一台将接替继续提供服务. 实现高可用的开源软件有:heartbeat,keepalived (2)负载均衡集群:需要有一台服务器作为分发器,它负责吧用户的请求分发给后端的服务器处理,在这个集群里,除了分发器外,就是给用户提供服务的服务器了,这些服务器数量最少为2 实现负载均衡的开源软件有LVS,keepalived,haproxy,nginx,商业

Keepalived+Haproxy双主高可用负载均衡web和mysql综合实验

日期及版本:2014.5.4v1.0 架构图 实验目的: 1.Haproxy+Keepalived双主双机高可用模型,keepalived为Haproxy主从提供高可用保证haproxy-master若挂掉haproxy-backup能无缝接管,haproxy为后端Web提供负载均衡,缓解并发压力,实现WEB站点负载均衡+高可用性: 2. Haproxy反代web做动静分离: 3. Haproxy反代mysql 算法leastconn和roundrobin的不同效果: 系统环境: OS:cent