- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
MySQL主备双活安装说明分析
MySQL主备双活安装说明
MySQL主备集群模式采用日志回放的模式将主服务器上执行过的日志信息在备机上重新进行一次回放确保主备服务器数据的一致性
对于一个mysql服务器,一般有两个线程来负责复制和被复制。
1. 作为主服务器Master,会把自己的每一次改动都记录到 二进制日志 Binarylog 中;
2. 作为从服务器Slave,会用master上的账号登陆到 master上, 读取master的Binarylog,写入到自己的中继日志 Relaylog,然后自己的sql线程会负责读取这个中继日志,并执行一遍。
MySQL主备双活即主服务器负责写入读取从服务器则只能进行读取操作MySQL主主双活则在主备的基础上采用互为备份的方式
2.1. 环境说明
两台服务器IP地址分别为(以下简称A机) 14.04。
2.2. MySQL安装
在两台服务器上分别安装MySQL服务器。
$ sudo apt-get install mysql-server
2.3. 创建备份用户
在A机上执行
mysql grant replication slave on *.* to repl@10.68.19.183 identified by replpwd;
mysql flush privileges;
在
mysql grant replication slave on *.* to repl@10.68.19.182 identified by replpwd;
mysql flush privileges;
2.4. 修改MySQL配置
在A机上修改配置文件$ sudo vi /etc/mysql/my.cnf
#bind-address = 127.0.0.1
server-id = 101
log_bin = /var/log/mysql/mysql-bin.log
expire_logs_days = 10
max_binlog_size = 100M
#binlog_do_db = include_database_name
binlog_ignore_db = mysql
binlog_ignore_db = information_schema
binlog_ignore_db = performance_schema
log-slave-updates
sync_binlog=0
auto-increment-increment= 2
auto-increment-offset = 1
备注说明:
bind-address注释掉或者修改为本地IP地址,否则外部机器无法连接到MySQL服务器;
server-id为服务器的ID值,两台不同的MySQL服务器,必须配置成不同;
binlog_do_db为需要同步的数据库,当前部署采用采用排除模式,不进行设置;
binlog_ignore_db设定忽略哪些数据库的日志,当前的配置排除了系统自带的数据库;
log-slave-updates这个参数用来配置从服务器的更新是否写入二进制日志,例如A-B B-A,在 B中设置log_slave_updates后还可以B-C. 这样A,C中的数据也是一致的,在主主互备的方式中,日志会自动过滤自己发送给其它服务器的日志;
sync_binlog对应的数值为0或任意整形数据,如果大于0,当每个sync_binlog写入该二进制日志后,MySQL服务器将它的二进制日志同步到硬盘上(fdatasync())。请注意如果在autocommit模式,每执行一个语句向二进制日志写入一次,否则每个事务写入一次。 默认值是0,不与硬盘同步。值为1是最安全的选择,因为崩溃时,你最多丢掉二进制日志中的一个语句/事务;
auto-increment-increment、auto-increment-offsetauto-increment-increment用于设定自动增长字段的数值间隔,auto-increment-offset用于设定自动增长的偏移量(每台MySQL需配置不同值)。在本应用设置中,A机自动增长的数值为1、3、5…,B机自动增长的数值为…。
在B机上修改配置文件
$ sudo vi /etc/mysql/my.cnf
#bind-address = 127.0.0.1
server-id = 102
log_bin = /var/log/mysql/mysql-bin.l
文档评论(0)