您好,欢迎访问一九零五行业门户网

MySQL双Master配置_MySQL

主机环境说明。
master1: 10.8.1.11
master2: 10.8.1.12
版本信息:
    [root@m1 ~]# mysql -v
    mysql  ver 14.14 distrib 5.6.27, for linux (x86_64) using  editline wrapper
1、主库开启bin-log功能,配置server-id
修改my.cf配置文件,开启bin-log功能,配置server-id。
[root@m1 ~]# more /etc/my.cnf # for advice on how to change settings please see # http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html [mysqld] server-id = 1 datadir = /var/lib/mysql log_bin = /var/lib/mysql/bin-log socket = /var/lib/mysql/mysql.sock slave_net_timeout = 60 log-slave-updates slave-skip-errors=all skip-name-resolve sync_binlog=1 auto_increment_increment=2 auto_increment_offset=1 sql_mode=no_engine_substitution,strict_trans_tables #salve-net-timeout默认是3600秒,缩短时间是为了防止双yes的假象#(事实上我已遇到,参考地址:http://www.cnblogs.com/billyxp/p/3470376.html)如果要指定同步或不同步哪些库,可使用如下参数#binlog-do-db=osyunweidb #需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行#binlog-ignore-db=mysql #不同步mysql系统数据库
至于这些参数的说明具体看手册。
红色的部分非常重要,如果一个master 挂掉的话,另外一个马上接管。
紫红色的部分指的是服务器频繁的刷新日志。这个保证了在其中一台挂掉的话,日志刷新到另外一台。从而保证了数据的同步
2、确认bin-log与server-id是否开启:
查看命令 show variables like 'log_bin'; show variables like 'server_id';
mysql> show variables like 'log_bin';+---------------+-------+|variable_name | value |+---------------+-------+|log_bin | on |+---------------+-------+1 rowin set (0.00 sec)mysql>show variables like 'server_id';+---------------+-------+|variable_name | value |+---------------+-------+|server_id | 1 |+---------------+-------+1 rowin set (0.00 sec)
3、创建复制授权用户
mysql> grant replication slave on *.* to replication@'%'identified by '123456'; #授权该用户对所有表都能进行复制
mysql>flush privileges; #刷新权限
4、锁表,记录log-bin文件名和位置
mysql>flush tables with read lock; #锁定所有表,此时数据库不能写入数据queryok, 0 rows affected (0.05 sec)mysql>show master status; #查看最新bin-log文件及位置+------------------------+------------+-------------------+-------------------------+|file | position | binlog_do_db | binlog_ignore_db |+------------------------+------------+-------------------+-------------------------+|mysql-bin.000001 | 26314 | | |+------------------------+------------+-------------------+-------------------------+1row in set (0.00 sec)
5、锁表状态全备mysql数据
由于退出当前mysql登陆窗口,锁表功能就失效,需克隆一个会话进行全备。
#mysqldump-uroot -p -a -b > /tmp/mysql_bak_2015_11_17.sql
看下备份数据大小,确认备份成功。
[root@m1 ~]# ls -l mysql_bak_2015_11_17.sql
-rw-r--r--. 1 root root 645327 nov 18 06:27 mysql_bak_2015_11_17.sql
[root@m1 ~]#
6、解除锁表
mysql>unlock tables;
或直接quit退出即可。
7、从库开启bin-log功能,配置server-id
从库开启bin-log功能后,待会在主上在配置同步,互为主从就完成了。
[root@m2 ~]# vi /etc/my.cnf # for advice on how to change settings please see # http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html [mysqld] server-id = 2 datadir = /var/lib/mysql log_bin = /var/lib/mysql/mysql-bin socket = /var/lib/mysql/mysql.sock slave_net_timeout = 60 log-slave-updates slave-skip-errors=all skip-name-resolve sync_binlog=1 auto_increment_increment=2 auto_increment_offset=2 sql_mode=no_engine_substitution,strict_trans_tables#salve-net-timeout默认是3600秒,缩短时间是为了防止双yes的假象
#
至于这些参数的说明具体看手册。
红色的部分非常重要,如果一个master 挂掉的话,另外一个马上接管。
紫红色的部分指的是服务器频繁的刷新日志。这个保证了在其中一台挂掉的话,日志刷新到另外一台。从而保证了数据的同步
#/etc/init.d/mysql restart
8、确认从库bin-log与server-id是否开启
查看命令 show variables like 'log_bin'; show variables like 'server_id';
mysql>show variables like 'log_bin';+---------------+-------+|variable_name | value |+---------------+-------+|log_bin | on |+---------------+-------+1row in set (0.00 sec)mysql>show variables like 'server_id';+---------------+-------+|variable_name | value |+---------------+-------+|server_id | 2 |+---------------+-------+1row in set (0.00 sec)
9、从库导入主库的全备数据
登陆mysql导入数据
mysql>source /root/mysql_bak_2015_11_17.sql
10、记录从库bin-log信息
因为在从库导入全备数据时,此时主库与从库的内容是一致的,但是bin-log位置不一定一致。
mysql>show master status; #查看最新bin-log文件及位置+------------------------+------------+-------------------+-------------------------+|file |position | binlog_do_db | binlog_ignore_db |+------------------------+------------+-------------------+-------------------------+|mysql-bin.000003 | 2328055 | | |+------------------------+------------+-------------------+-------------------------+1row in set (0.00 sec)
11、从库设置同步主库
此处binlog文件与位置状态,是主库在步骤4锁表时show master status查看的位置状态。
change master to master_host='10.8.1.11',master_port=3306,master_user='replication',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=26314;
12、开启从库同步并确认同步是否成功
使用start slave开启同步功能,使用show slave status\g查看同步是否成功
mysql>start slave;queryok, 0 rows affected (0.00 sec)mysql>show slave status\g #\g不按表格输出***************************1. row *************************** slave_io_state: waiting formaster to send event master_host: 10.0.0.2 master_user: replication master_port: 8306 connect_retry: 60 master_log_file: mysql-bin.000001 read_master_log_pos: 136270 relay_log_file:mysqld-relay-bin.000002 relay_log_pos: 72697 relay_master_log_file: mysql-bin.000001 slave_io_running:yes slave_sql_running:yes replicate_do_db: replicate_ignore_db: replicate_do_table: replicate_ignore_table: replicate_wild_do_table: replicate_wild_ignore_table: last_errno: 0 last_error: skip_counter: 0 exec_master_log_pos: 98758 relay_log_space: 110366 until_condition: none until_log_file: until_log_pos: 0 master_ssl_allowed: no master_ssl_ca_file: master_ssl_ca_path: master_ssl_cert: master_ssl_cipher: master_ssl_key: seconds_behind_master: 622 #查看主从同步延迟,延迟大则可能需要优化master_ssl_verify_server_cert:no last_io_errno: 0 last_io_error: last_sql_errno: 0 last_sql_error: replicate_ignore_server_ids: master_server_id: 11row in set (0.00 sec)
#sql线程与io线程都是yes,slave配置成功。
13、主库设置同步从库
由于从库是全备导入,原先在主库上配置的复制帐户也同样导入,所以这里不用在从库上新授权复制用户。
从库上的binlog文件与位置状态,是从库在刚导入时show master status查看到的位置状态。
changemaster to master_host='10.8.1.12',master_port=3306,master_user='replication',master_password='123456',master_log_file='mysql-bin.000003',master_log_pos=2328055;#修改相应信息,直接把这些配置在mysql中粘贴即可。
14、开启同步并确认同步是否成功
使用start slave开启同步功能,使用show slave status\g查看同步是否成功
mysql>start slave;queryok, 0 rows affected (0.00 sec)mysql>show slave status\g***************************1. row *************************** slave_io_state: waiting formaster to send event master_host: 172.16.0.2 master_user: replication master_port: 3306 connect_retry: 60 master_log_file: mysql-bin.000007 read_master_log_pos: 107 relay_log_file:mysqld-relay-bin.000006 relay_log_pos: 253 relay_master_log_file: mysql-bin.000007 slave_io_running: yes slave_sql_running:yes replicate_do_db: replicate_ignore_db: replicate_do_table: replicate_ignore_table: replicate_wild_do_table: replicate_wild_ignore_table: last_errno: 0 last_error: skip_counter: 0 exec_master_log_pos: 107 relay_log_space: 556 until_condition: none until_log_file: until_log_pos: 0 master_ssl_allowed: no master_ssl_ca_file: master_ssl_ca_path: master_ssl_cert: master_ssl_cipher: master_ssl_key: seconds_behind_master: 0master_ssl_verify_server_cert:no last_io_errno: 0 last_io_error: last_sql_errno: 0 last_sql_error: replicate_ignore_server_ids: master_server_id: 21row in set (0.00 sec)
#io线程与sql线程都是正常。
15、互为主从测试
在两台mysql各创建一个库,看两边是否都能进行同步。
分别在主库上执行 create database test01;
从库上执行create database test02;
看两台数据库上执行show databases;,看是否都有test01表和test02表。
我的经过测试,双主测试成功。
其它类似信息

推荐信息