拓扑如下:
三、安装主数据库(masterdb.example.com)
1、准备数据存放目录、创建用户
[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/logs2、安装并初始化mysql5.6.23
[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/3、输出mysql的man手册至man命令的查找路径:
[root@masterdb ~]#ln -sv /usr/local/mysql/include /usr/include/mysql5、输出mysql的库文件给系统库查找路径:
[root@masterdb ~]#echo "/usr/local/mysql/lib" > /etc/ld.so.conf.d/mysql.conf而后让系统重新载入系统库:
[root@masterdb ~]# ldconfig6、修改PATH环境变量,让系统可以直接使用mysql的相关命令:
[root@masterdb ~]# vim /etc/profile.d/mysql.shexport PATH=$PATH:/usr/local/mysql/bin[root@masterdb ~]#source /etc/profile.d/mysql.sh从数据库安装同上,具体过程略过。
[client]port = 3306socket = /tmp/mysql.sockdefault-character-set = utf8[mysql]no-auto-rehashdefault-character-set = utf8[mysqld]server-id = 1port = 3306user = mysqlbasedir = /usr/local/mysqldatadir = /data/mysqldatasocket = /tmp/mysql.sockdefault-storage-engine = INNODBcharacter-set-server = utf8connect_timeout = 60interactive_timeout = 28800wait_timeout = 28800back_log = 500event_scheduler = ONskip_name_resolve = ON;###########binlog##########log-bin = /data/mysqlLog/logs/mysql-binbinlog_format = rowmax_binlog_size = 128Mbinlog_cache_size = 2Mexpire-logs-days = 5log-slave-updates=truegtid-mode=onenforce-gtid-consistency=truemaster-info-repository=TABLErelay-log-info-repository=TABLEsync-master-info=1slave-parallel-workers=4#rpl_semi_sync_master_enabled = 1slow_query_log = 1slow_query_log_file = /data/mysqlLog/logs/mysql.slowlong_query_time = 1log_error = /data/mysqlLog/logs/error.logmax_connections = 3000max_connect_errors = 32767log_bin_trust_function_creators = 1transaction_isolation = READ-COMMITTED从数据库上:
[client]port = 3306socket = /tmp/mysql.sockdefault-character-set = utf8[mysql]no-auto-rehashdefault-character-set = utf8[mysqld]server-id = 205port = 3306user = mysqlbasedir = /usr/local/mysqldatadir = /data/mysqldatasocket = /tmp/mysql.sockdefault-storage-engine = INNODBcharacter-set-server = utf8connect_timeout = 60wait_timeout = 18000back_log = 500event_scheduler = ON###########binlog##########log-bin = /data/mysqlLog/logs/mysql-binbinlog_format = rowmax_binlog_size = 128Mbinlog_cache_size = 2Mexpire-logs-days = 5log-slave-updates=truegtid-mode=on enforce-gtid-consistency=truemaster-info-repository=TABLErelay-log-info-repository=TABLEsync-master-info=1slave-parallel-workers=4#rpl_semi_sync_slave_enabled = 1skip-slave-startslow_query_log = 1slow_query_log_file = /data/mysqlLog/logs/mysql.slowlong_query_time = 2log-error = /data/mysqlLog/logs/error.logmax_connections = 3000max_connect_errors = 10000log_bin_trust_function_creators = 1transaction_isolation = READ-COMMITTED五、分别在主从数据库上启动mysqld服务
[root@masterdb ~]# service mysqld startStarting MySQL......[ OK ][root@masterdb ~]# [root@slavedb ~]# service mysqld startStarting MySQL......[ OK ][root@slavedb ~]#六、在主数据库上创建复制用户
mysql> CHANGE MASTER TO MASTER_HOST="masterdb.example.com", MASTER_USER="repluser", MASTER_PASSWORD="replpassword", MASTER_AUTO_POSITION=1;mysql>start slave;八、在从数据库上查看复制状态
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: 3306Connect_Retry: 60Master_Log_File: mysql-bin.000002 Read_Master_Log_Pos: 191Relay_Log_File: slavedb-relay-bin.000003Relay_Log_Pos: 401Relay_Master_Log_File: mysql-bin.000002Slave_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: 191Relay_Log_Space: 1899Until_Condition: NoneUntil_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: NoLast_IO_Errno: 0Last_IO_Error: Last_SQL_Errno: 0Last_SQL_Error:Replicate_Ignore_Server_Ids: Master_Server_Id: 1 Master_UUID: 971d7245-c3f8-11e5-8b6b-000c2999e5a5Master_Info_File: mysql.slave_master_info SQL_Delay: 0 SQL_Remaining_Delay: NULLSlave_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-6Auto_Position: 11 row in set (0.00 sec)ERROR: No query specifiedmysql>
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>可以看到log_statics数据库已经存在于从数据库上。