MHA 配置文件样本描述

        与绝大多数Linux应用程序类似,MHA的正确使用依赖于合理的配置文件。MHA的配置文件与mysql的my.cnf文件配置相似,采取的是分模块,param=value的方式来配置,配置文件位于管理节点,通常包括每一个mysql server的主机名,mysql用户名,密码,工作目录等等。本文列出了单套MHA以及采用全局配置来管理多套MHA配置文件的一些样例,供大家参考。

1、单套MHA配置样本 manager_host$ cat /etc/app1.cnf

[server default] # 登陆mysql数据库账户及密码,缺省为root,因为需要STOP SLAVE, CHANGE MASTER, RESET SLAVE等。 user=root password=mysqlpass

# working directory on the manager  #位于管理节点工作目录 manager_workdir=/var/log/masterha/app1

# manager log file #位于管理节点工作日志文件 manager_log=/var/log/masterha/app1/app1.log

# working directory on MySQL servers # node 上用于产生日志的工作目录,如果不存在,MHA node会自动创建,前提需要有相应的权限,否则node会终止。 # 缺省目录为 "/var/tmp". remote_workdir=/var/log/masterha/app1

#[serverN] 部分,为各节点配置信息,作用域为各单独节点,各节点书写顺序影响成为新master的顺序 #也可以通过配置candidate_master参数来影响哪个节点具有优先级成为新master [server1] hostname=host1

[server2] hostname=host2

[server3] hostname=host3

2、多套MHA配置样本 如果生产环境中基于单个管理节点部署了多套MHA,可以通过使用全局配置文件来配置相同或共有部分以达到简化配置,易于管理的目的。 假定我们创建了/etc/masterha_default.cnf,则MHA Manager脚本会首先都读取该文件然后再读取指定的配置文件。 这个功能类似于/etc/profile,然后再读取~/.bash_profile 如果在未配置全局的配置文件的情形下,会收到以下提示: [warning] Global configuration file /etc/masterha_default.cnf not found. Skipping.

a、全局配置文件样本 如:/etc/masterha_default.cnf [server default] user=root password=rootpass ssh_user=root

#mysql 数据库master节点binlog的位置,该参数用于当master节点死掉后通过ssh方式顺序读取binlog event #该参数需要配置,因为master节点死掉后无法通过replication机制来自动获取binlog日志位置 #以下为rpm安装方式缺省binlog位置,应根据情形做相应调整 master_binlog_dir= /var/lib/mysql remote_workdir=/data/log/masterha

#用于检测各节点间的连接性,此处详细可参考MHA parameters描述部分 secondary_check_script= masterha_secondary_check -s remote_host1 -s remote_host2 ping_interval=3

#定义用于实现VIP漂移的脚本,后面的是shutdown以及report脚本 master_ip_failover_script=/script/masterha/master_ip_failover shutdown_script= /script/masterha/power_manager report_script= /script/masterha/send_master_failover_mail

b、各MHA单独配置样本 以下为2套不同应用对应的MHA配置文件,如下 app1:   manager_host$ cat /etc/app1.cnf

  [server default]   manager_workdir=/var/log/masterha/app1       #工作目录      Author:Leshami   manager_log=/var/log/masterha/app1/app1.log  #日志文件 Blog   :http://blog.csdn.net/leshami   [server1]   hostname=host1   candidate_master=1   [server2]   hostname=host2   candidate_master=1   [server3]   hostname=host3   [server4]   hostname=host4   no_master=1

app2:   manager_host$ cat /etc/app2.cnf

  [server default]   manager_workdir=/var/log/masterha/app2   manager_log=/var/log/masterha/app2/app2.log   [server1]   hostname=host11   candidate_master=1   [server2]   hostname=host12   candidate_master=1   [server3]   hostname=host13   [server4]   hostname=host14   no_master=1

注:对于上述配置,如果各应用配置与全局配置不同,应用配置具有最高优先级,即相同的项,应用配置的值会替换掉全局配置的值

3、Binlog server 该功能自被MHA 0.56版支持。即可以定义[binlogN]选项。在这个部分,可以定义mysqlbinlog streaming servers. 如果开启了GTID,则MHA会检查binlog服务器,且binlog服务器日志在其他从节点日志之前,则MHA会在恢复之前从binlog服务器apply差量日志 如果未开启GTID,则MHA 忽略 binlog servers。如下样本:

manager_host$ cat /etc/app1.cnf   [server default]   # mysql user and password   user=root   password=mysqlpass   # working directory on the manager   manager_workdir=/var/log/masterha/app1   # manager log file   manager_log=/var/log/masterha/app1/app1.log   # working directory on MySQL servers   remote_workdir=/var/log/masterha/app1   [server1]   hostname=host1   [server2]   hostname=host2   [server3]   hostname=host3

  [binlog1]   hostname=binlog_host1

  [binlog2]   hostname=binlog_host2 参考:Writing an application configuration file

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏互扯程序

Linux常用Shell脚本,值得学习及收藏

在运维中,尤其是linux运维,都知道脚本的重要性,脚本会让我们的 运维事半功倍,所以学会写脚本是我们每个linux运维必须学会的一门功课,这里收藏linux运...

1591
来自专栏点滴积累

OpenStack(企业私有云)万里长征第五步——虚拟机Migrate&Resize

一、前言 上一篇文章讲了OpenStack的部署和简单操作,今天介绍一下如何实现虚拟机的Migrate以及Resize。Migrate操作和Resize操作基本...

4125
来自专栏Java架构沉思录

Linux常用Shell脚本知多少

在运维中,尤其是linux运维,都知道脚本的重要性,脚本会让我们的 运维事半功倍,所以学会写脚本是我们每个linux运维必须学会的一门功课,这里收藏linux运...

1121
来自专栏散尽浮华

MySQL高可用架构-MHA环境部署记录

一、MHA介绍 MHA(Master High Availability)目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeNA公司youshim...

6216
来自专栏黄希彤的专栏

knockd:CVM云主机的隐形斗篷

用knockd隐藏服务器的ssh等各种高危端口,让服务器在黑客眼前隐形。

9735
来自专栏步履前行

深入理解JVM--(1)运行时的数据区域划分- 虚拟机栈

  之前提到了虚拟机栈,接下来我们说的本地方法栈正好和虚拟机栈对应,一个是是虚拟机为执行java方法也就是字节码服务,另一个则是为本地方法服务。   因为本地方...

2924
来自专栏北京马哥教育

GlusterFS分布式文件系统使用简介

术语简介 GlusterFS是一个开源的分布式文件系统。更多特性介绍附录的参考文档。 Brick:GFS中的存储单元,通过是一个受信存储池中的服务器的一个导出...

5656
来自专栏PhpZendo

Jerry Qu 博客 Nginx 配置之性能篇

在介绍完我博客(imququ.com)的 Nginx 配置中与安全有关的一些配置后,这篇文章继续介绍与性能有关的一些配置。WEB 性能优化是一个系统工程,涵盖很...

1032
来自专栏恰同学骚年

.NET Core微服务之基于Consul实现服务治理(续)

上一篇发布之后,很多人点赞和评论,不胜惶恐,这一篇把上一篇没有弄到的东西补一下,也算是给各位前来询问的朋友的一些回复吧。

1465
来自专栏琯琯博客

优化 Laravel 网站打开速度

1.关闭debug 打开.env文件,把debug设置为false. APP_ENV=local APP_DEBUG=false APP_KEY=base64...

41711

扫码关注云+社区

领取腾讯云代金券