drbd实现mysql地热备_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目录

[root@node1 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服务

[root@node1 mysql-5.1.72]#chmod +x /etc/rc.d/init.d/mysqld

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

10、启动mysql

[root@node1 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

[root@node1 ~]# 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  root@10.0.0.2:/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

[root@node2 ~]# sed -n "/^[^#]/p" /etc/ha.d/ha.cf

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

logfacilitylocal0

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  root@10.0.0.2:/root/

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

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

service heartbeat start

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

##############################drbddisk脚本#####################################

#!/bin/bash

#

# This script is inteded to be used as resource script by heartbeat

#

# Copright 2003-2008 LINBIT Information Technologies

# Philipp Reisner, Lars Ellenberg

#

###

DEFAULTFILE="/etc/default/drbd"

DRBDADM="/sbin/drbdadm"

if [ -f $DEFAULTFILE ]; then

. $DEFAULTFILE

fi

if [ "$#" -eq 2 ]; then

RES="$1"

CMD="$2"

else

RES="all"

CMD="$1"

fi

## EXIT CODES

# since this is a "legacy heartbeat R1 resource agent" script,

# exit codes actually do not matter that much as long as we conform to

# http://wiki.linux-ha.org/HeartbeatResourceAgent

# but it does not hurt to conform to lsb init-script exit codes,

# where we can.

# http://refspecs.linux-foundation.org/LSB_3.1.0/

#LSB-Core-generic/LSB-Core-generic/iniscrptact.html

####

drbd_set_role_from_proc_drbd()

{

local out

if ! test -e /proc/drbd; then

ROLE="Unconfigured"

return

fi

dev=$( $DRBDADM sh-dev $RES )

minor=${dev#/dev/drbd}

if [[ $minor = *[!0-9]* ]] ; then

# sh-minor is only supported since drbd 8.3.1

minor=$( $DRBDADM sh-minor $RES )

fi

if [[ -z $minor ]] || [[ $minor = *[!0-9]* ]] ; then

ROLE=Unknown

return

fi

if out=$(sed -ne "/^ *$minor: cs:/ { s/:/ /g; p; q; }" /proc/drbd); then

set -- $out

ROLE=${5%/**}

: ${ROLE:=Unconfigured} # if it does not show up

else

ROLE=Unknown

fi

}

case "$CMD" in

start)

# try several times, in case heartbeat deadtime

# was smaller than drbd ping time

try=6

while true; do

$DRBDADM primary $RES && break

let "--try" || exit 1 # LSB generic error

sleep 1

done

;;

stop)

# heartbeat (haresources mode) will retry failed stop

# for a number of times in addition to this internal retry.

try=3

while true; do

$DRBDADM secondary $RES && break

# We used to lie here, and pretend success for anything != 11,

# to avoid the reboot on failed stop recovery for "simple

# config errors" and such. But that is incorrect.

# Don't lie to your cluster manager.

# And don't do config errors...

let --try || exit 1 # LSB generic error

sleep 1

done

;;

status)

if [ "$RES" = "all" ]; then

echo "A resource name is required for status inquiries."

exit 10

fi

ST=$( $DRBDADM role $RES )

ROLE=${ST%/**}

case $ROLE in

Primary|Secondary|Unconfigured)

# expected

;;

*)

# unexpected. whatever...

# If we are unsure about the state of a resource, we need to

# report it as possibly running, so heartbeat can, after failed

# stop, do a recovery by reboot.

# drbdsetup may fail for obscure reasons, e.g. if /var/lock/ is

# suddenly readonly. So we retry by parsing /proc/drbd.

drbd_set_role_from_proc_drbd

esac

case $ROLE in

Primary)

echo "running (Primary)"

exit 0 # LSB status "service is OK"

;;

Secondary|Unconfigured)

echo "stopped ($ROLE)"

exit 3 # LSB status "service is not running"

;;

*)

# NOTE the "running" in below message.

# this is a "heartbeat" resource script,

# the exit code is _ignored_.

echo "cannot determine status, may be running ($ROLE)"

exit 4 # LSB status "service status is unknown"

;;

esac

;;

*)

echo "Usage: drbddisk [resource] {start|stop|status}"

exit 1

;;

esac

exit 0

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/501895.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入理解计算机系统第四版_深入理解计算机系统之存储器层次结构

我的计算机模型是这样的:CPU执行指令,内存犹如一个巨大的字节数组,存储着指令和数据,硬盘保存着各种程序与程序用到的数据。I/O完成输入输出的功能。在本文中我们抛开I/O,谈一谈关于CPU,内存,硬…

mysql8支持myISAM_mysql8 参考手册--优化MyISAM表

MyISAM存储引擎在以读为主的数据或低并发操作中表现最好,因为表锁限制了同时执行更新的能力。在MySQL中,InnoDB是默认的存储引擎,而不是MyISAM。优化MyISAM查询一些加快MyISAM表查询的一般技巧 :为了帮助MySQL更好地优化查询&…

python的模块提供了许多文件处理方法_详解使用Python处理文件目录的相关方法

所有文件都包含在各个不同的目录下,不过Python也能轻松处理。os模块有许多方法能帮你创建,删除和更改目录。mkdir()方法可以使用os模块的mkdir()方法在当前目录下创建新的目录们。你需要提供一个包含了要创建的目录名称的参数。语法:os.mkdir…

mysql替换json的key_mysql中json_replace函数的使用?通过json_replace对json对象的值进行替换...

需求描述:在看mysql中关于json的内容,通过json_replace函数可以实现对json值的替换,在此记录下.操作过程:1.查看带有json数据类型的表mysql> select * from tab_json;-------------------------------------------------------------------------------------------| id | d…

python中的array函数作用_Python中的Array | 数组2(简介和功能)

相关文章:Python中的数组Array | 1(简介和功能)以下是更多函数。1. typecode:此函数返回初始化数组所用的数据类型。2. itemsize:此函数返回单个数组元素的大小(以字节为单位)。3. buffer_info():返回一个元组,表示存储…

java生成pdf_JAVA 生成PDF 并导出

/***首先啥也不干,先写一个转换中文的方法,话说谁要整一个全英文数字的就不* 要写这个方法了....*str :要转换的内容 c:字体大小*/private static Paragraph getChinese(String str,int c) throws DocumentException, IOException{ BaseFont …

python爬取今日头条的文章_Python3爬取今日头条有关《人民的名义》文章

Python3爬取今日头条有关《人民的名义》文章最近一直在看Python的基础语法知识,五一假期手痒痒想练练,正好《人民的名义》刚结束,于是决定扒一下头条上面的人名的名义文章,试试技术同时可以集中看一下大家的脑洞也是极好的。首先&…

java jmeter_使用Jmeter中的Java Request进行性能测试

在使用jmeter进行性能测试的时候,有可能会需要通过一些脚本去测试性能,(比如通过sokeeper的api去测试sokeeper的读写性能)。这时,我们可以通过Java Request实现,以下是操作步骤。首先创建一个maven project。因Jmeter的Java Reque…

python虚拟环境 pyenv_Python 虚拟环境 pyenv、venv(pyvenv)、virtualenv之间的区别

请参考连接 https://blog.zengrong.net/post/2167.htmlhttps://blog.csdn.net/lanonjj/article/details/51050212为避免链接失效,把原文做了复制黏贴另外在python3.6中,虚拟应该用如下命令创建python3 -m venv /path/to/new/virtual/environment直接用py…

java resources 目录_[Java] 在 jar 文件中读取 resources 目录下的文件

注意两点:1. 将资源目录添加到 build path,确保该目录下的文件被拷贝到 jar 文件中。2. jar 内部的东西,可以当作 stream 来读取,但不应该当作 file 来读取。例子新建一个 maven 目录App.java 用于读取 resources 中的 a.txt 内容…

m.2接口和nvme区别_m.2 nvme和m.2有区别吗?

m2接口有两种,一种走sata的,另外一种走pcie(就是nvme)的。走sata的速度跟传统sata接口的没区别,就是接口变成了m2的了。走pcie的,就是我们说的nvme接口是m2的,性能也强了。M.2接口有SATA也有NVMe PCIe协议。这个是同一…

python编程软件排行榜_Python编程开发工具:这10个对Web开发者最有用的Python包

Python编程一时间成为了开发人员最喜欢的语言之一。无论是专业的,业余的,还是作为一个Python初学者,都可以从Python编程语言及其程序包中受益。Python已经被证明是当今最具活力的面向对象的编程语言之一。这就是为什么即使是一些很优秀的公司…

java excel 字体大小_Java将数据按列写入Excel并设置格式(字体、背景色、自动列宽、对齐方式等)...

/*** 按列写入Excel并设置格式**paramoutputUrl* 输出路径*paramsheetName* 工作薄名称*paramtitles* 表头*paramarrayList* 表头数据*throwsIOException*throwsRowsExceededException*throwsWriteException*/public static voidwriteExcel(String outputUrl, String sheetName…

如何查看cplex的help文档_word查看技巧:如何快速找到文档的修改痕迹

不知道大家在工作中有没有遇到过这类的工作场景:当初步拟好一份合作协议或是项目策划书后,发给老板或其他同事审阅和修订,通常会不断地来回修改文档。此时,如果你想要查看文档哪里被修改过?你会怎么操作?很…

java将数字替换为空_将数字替换为java中正确位置的单词

实际上我正试图用用户给出的句子中的数字替换为单词.本案例日期格式;例如:我的生日是在16/6/2000,我是java的新手 – >成为—>我的生日是七月十六日,我是java的新手这是代码:Scanner reader new Scanner(System.in);System.out.println("Ent…

java重载this_Java的this关键字的使用与方法的重载相关知识

Java this关键字详解this 关键字用来表示当前对象本身,或当前类的一个实例,通过 this 可以调用本对象的所有方法和属性。例如:public class Demo{public int x 10;public int y 15;public void sum(){// 通过 this 点取成员变量int z this…

python 类和对象 经常用吗_python基础教程之对象和类的实际运用

我们熟悉了对象和类的基本概念。我们将进一步拓展,以便能实际运用对象和类。调用类的其它信息中提到,在定义方法时,必须有self这一参数。这个参数表示某个对象。对象拥有类的所有性质,那么我们可以通过self,调用类属性…

java get properties_Java.lang.System之getProperties()方法

Environmentjava.vm.version——>25.60-b23java.vm.vendor——>Oracle Corporationjava.vendor.url——>http://java.oracle.com/idea.launcher.port——>7533java.vm.name——>Java HotSpot(TM) 64-Bit Server VMfile.encoding.pkg——>sun.iouser.country—…

mysql set语句_MySQL Prepared语句简介

之前的MySQL版本4.1,查询以文本格式发送到MySQL服务器。 之后,MySQL服务器使用文本协议将数据返回给客户端。MySQL必须完全解析查询,并将结果集转换为字符串,然后再将其返回给客户端。 文本协议具有严重的性能问题。为了解决这个问…

java resultset close_java代码ResultSet is closed

我用的Eclipse开发工具写java代码,连接的是SQLServer2000。提示ResultSetisclosed代码如下:privatestaticvoidgetDBConnection(){try{Class.forName(strName);connDriverManager.ge...我用的Eclipse开发工具写java代码,连接的是SQL Server 20…