Mysql应用MySQL5.6基于GTID的主从复制
《Mysql应用MySQL5.6基于GTID的主从复制》要点: MYSQL入门MySQL 5.6 的新特性之一,是加入了全局事务 ID (GTID) 来强化数据库的主备一致性,故障恢复,以及容错能力. MYSQL入门什么是GTID? MYSQL入门官方文档:http://dev.mysql.com/doc/refman/5.6/en/replication-gtids.html在这篇文档里,我们可以知道全局事务 ID 的官方定义是:GTID = source_id:transaction_id MYSQL入门MySQL 5.6 中,每一个 GTID 代表一个数据库事务.在上面的定义中,source_id 表示执行事务的主库 uuid(server_uuid),transaction_id 是一个从 1 开始的自增计数,表示在这个主库上执行的第 n 个事务.MySQL 会保证事务与 GTID 之间的 1 : 1 映射. MYSQL入门一、环境准备 MYSQL入门操作系统:CentOS6.5 64位 MYSQL入门数据库版本:MySQL5.6.23 MYSQL入门 MYSQL入门拓扑如下: MYSQL入门 MYSQL入门三、安装主数据库(masterdb.example.com) MYSQL入门1、准备数据存放目录、创建用户 MYSQL入门
[root@masterdb ~]#mkdir /data/mysqldata -p #创建数据存放目录
[root@masterdb ~]#mkdir /data/mysqlLog/logs -p #创建日志存放目录
[root@masterdb ~]#groupadd -r mysql
[root@masterdb ~]#useradd -g mysql -r -s /sbin/nologin -M -d /data/mysqldata mysql
[root@masterdb ~]#chown -R mysql:mysql /data/mysqldata
[root@masterdb ~]#chown -R mysql:mysql /data/mysqlLog/logs
MYSQL入门?2、安装并初始化mysql5.6.23 MYSQL入门
[root@masterdb ~]# tar xf mysql-advanced-5.6.23-linux-glibc2.5-x86_64.tar.gz -C /usr/local/
[root@masterdb ~]# cd /usr/local/
[root@masterdb ~]# ln -sv mysql-advanced-5.6.23-linux-glibc2.5-x86_64 mysql
[root@masterdb ~]# chown -R root.mysql mysql
[root@masterdb ~]# cd mysql
[root@masterdb ~]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld
[root@masterdb ~]# cp support-files/my-default.cnf /etc/my.cnf
[root@masterdb ~]# chmod +x /etc/rc.d/init.d/mysqld
[root@masterdb ~]# chkconfig --add mysqld
[root@masterdb ~]# chkconfig mysqld on
[root@masterdb ~]# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysqldata/
MYSQL入门3、输出mysql的man手册至man命令的查找路径: MYSQL入门编辑/etc/man.config,添加如下行即可: MYSQL入门4、输出mysql的头文件至系统头文件路径/usr/include: MYSQL入门这可以通过简单的创建链接实现: MYSQL入门
[root@masterdb ~]#ln -sv /usr/local/mysql/include /usr/include/mysql
MYSQL入门5、输出mysql的库文件给系统库查找路径: MYSQL入门
[root@masterdb ~]#echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf
MYSQL入门而后让系统重新载入系统库: MYSQL入门
[root@masterdb ~]# ldconfig
MYSQL入门6、修改PATH环境变量,让系统可以直接使用mysql的相关命令: MYSQL入门
[root@masterdb ~]# vim /etc/profile.d/mysql.sh
export PATH=$PATH:/usr/local/mysql/bin
[root@masterdb ~]#source /etc/profile.d/mysql.sh
MYSQL入门从数据库安装同上,具体过程略过. MYSQL入门四、分别为主从数据库提供配置文件/etc/my.cnf MYSQL入门要在MySQL 5.6中使用复制功能,其服务配置段[mysqld]中于少应该定义如下选项: MYSQL入门主数据库上: MYSQL入门
[client]
port = 3306
socket = /tmp/mysql.sock
default-character-set = utf8
[mysql]
no-auto-rehash
default-character-set = utf8
[mysqld]
server-id = 1
port = 3306
user = mysql
basedir = /usr/local/mysql
datadir = /data/mysqldata
socket = /tmp/mysql.sock
default-storage-engine = INNODB
character-set-server = utf8
connect_timeout = 60
interactive_timeout = 28800
wait_timeout = 28800
back_log = 500
event_scheduler = ON
skip_name_resolve = ON;
###########binlog##########
log-bin = /data/mysqlLog/logs/mysql-bin
binlog_format = row
max_binlog_size = 128M
binlog_cache_size = 2M
expire-logs-days = 5
log-slave-updates=true
gtid-mode=on
enforce-gtid-consistency=true
master-info-repository=TABLE
relay-log-info-repository=TABLE
sync-master-info=1
slave-parallel-workers=4
#rpl_semi_sync_master_enabled = 1
slow_query_log = 1
slow_query_log_file = /data/mysqlLog/logs/mysql.slow
long_query_time = 1
log_error = /data/mysqlLog/logs/error.log
max_connections = 3000
max_connect_errors = 32767
log_bin_trust_function_creators = 1
transaction_isolation = READ-COMMITTED
MYSQL入门从数据库上: MYSQL入门
[client]
port = 3306
socket = /tmp/mysql.sock
default-character-set = utf8
[mysql]
no-auto-rehash
default-character-set = utf8
[mysqld]
server-id = 205
port = 3306
user = mysql
basedir = /usr/local/mysql
datadir = /data/mysqldata
socket = /tmp/mysql.sock
default-storage-engine = INNODB
character-set-server = utf8
connect_timeout = 60
wait_timeout = 18000
back_log = 500
event_scheduler = ON
###########binlog##########
log-bin = /data/mysqlLog/logs/mysql-bin
binlog_format = row
max_binlog_size = 128M
binlog_cache_size = 2M
expire-logs-days = 5
log-slave-updates=true
gtid-mode=on
enforce-gtid-consistency=true
master-info-repository=TABLE
relay-log-info-repository=TABLE
sync-master-info=1
slave-parallel-workers=4
#rpl_semi_sync_slave_enabled = 1
skip-slave-start
slow_query_log = 1
slow_query_log_file = /data/mysqlLog/logs/mysql.slow
long_query_time = 2
log-error = /data/mysqlLog/logs/error.log
max_connections = 3000
max_connect_errors = 10000
log_bin_trust_function_creators = 1
transaction_isolation = READ-COMMITTED
MYSQL入门五、分别在主从数据库上启动mysqld服务 MYSQL入门
[root@masterdb ~]# service mysqld start
Starting MySQL...... [ OK ]
[root@masterdb ~]#
[root@slavedb ~]# service mysqld start
Starting MySQL...... [ OK ]
[root@slavedb ~]#
MYSQL入门六、在主数据库上创建复制用户 说明:172.16.88.205是从节点服务器;如果想一次性授权更多的节点,可以自行根据需要修改; MYSQL入门七、启动从数据库上的复制线程 MYSQL入门
mysql> CHANGE MASTER TO MASTER_HOST='masterdb.example.com',MASTER_USER='repluser',MASTER_PASSWORD='replpassword',MASTER_AUTO_POSITION=1;
mysql>start slave;
MYSQL入门八、在从数据库上查看复制状态 MYSQL入门
mysql> show slave statusG;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: masterdb.56xyl.com
Master_User: repluser
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000002
Read_Master_Log_Pos: 191
Relay_Log_File: slavedb-relay-bin.000003
Relay_Log_Pos: 401
Relay_Master_Log_File: mysql-bin.000002
Slave_IO_Running: Yes #IO线程已正常运行
Slave_SQL_Running: Yes #SQL线程已正常运行
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: 191
Relay_Log_Space: 1899
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: 0
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: 1
Master_UUID: 971d7245-c3f8-11e5-8b6b-000c2999e5a5
Master_Info_File: mysql.slave_master_info
SQL_Delay: 0
SQL_Remaining_Delay: NULL
Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it
Master_Retry_Count: 86400
Master_Bind:
Last_IO_Error_Timestamp:
Last_SQL_Error_Timestamp:
Master_SSL_Crl:
Master_SSL_Crlpath:
Retrieved_Gtid_Set: 971d7245-c3f8-11e5-8b6b-000c2999e5a5:1-6
Executed_Gtid_Set: 89e78301-c3f4-11e5-8b51-00505624d26a:1-3,971d7245-c3f8-11e5-8b6b-000c2999e5a5:1-6
Auto_Position: 1
1 row in set (0.00 sec)
ERROR:
No query specified
mysql>
MYSQL入门 MYSQL入门在主库上创建数据库: MYSQL入门
mysql> create database log_statics;
Query OK,1 row affected (0.11 sec)
mysql> use log_statics;
Database changed
到从数据库上查看log_statics是否已经复制过去
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| log_statics |
| mysql |
| performance_schema |
+--------------------+
4 rows in set (0.01 sec)
mysql>
MYSQL入门可以看到log_statics数据库已经存在于从数据库上. MYSQL入门以上就是本文的全部内容,希望对大家的学习有所帮助. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |