一、创建用户
CREATE USER ‘test‘@‘%‘ IDENTIFIED BY ‘test‘;
FLUSH PRIVILEGES;
二、授权
REPLICATION CLIENT:授予此权限,复制用户可以使用 SHOW MASTER STATUS, SHOW SLAVE STATUS和 SHOW BINARY LOGS来确定复制状态。
REPLICATION SLAVE:授予此权限,复制才能真正工作。
一般复制账号需要以上两个权限。
GRANT REPLICATION CLIENT ON *.* TO 'test'@'%' IDENTIFIED BY ‘test‘;
GRANT REPLICATION SLAVE ON *.* TO 'test'@'%' IDENTIFIED BY ‘test‘;
mysql> create user 'copyuser'@'%' identified by 'copypassword';
Query OK, 0 rows affected (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
mysql> grant REPLICATION CLIENT ON *.* to 'copyuser'@'%' identified by 'copypassword';
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> GRANT REPLICATION SLAVE ON *.* TO 'copyuser'@'%' identified by 'copypassword';
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
RESET SLAVE;
备注:reset master和reset slave的作用如下:
1)reset master
在master上执行
RESET MASTER
作用包括:
①删除binlog索引文件中列出的所有binlog文件;
②清空binlog索引文件;
③创建一个新的binlog文件;
④清空系统变量gtid_purged和gtid_executed;
⑤在MySQL 5.7.5 及后续版本中, RESET MASTER还会会清空 mysql.gtid_executed 数据表。
2)reset slave
在slave上执行
RESET SLAVE
作用包括:
①清除slave 复制时的master binlog的位置;
②清空master info, relay log info;
③删除所有的relay log文件,并创建一个新的relay log文件;
④重置复制延迟(CHANGE MASTER TO 的 MASTER_DELAY参数指定的)为0。
另外,
RESET SLAVE 不会改变gtid_executed or gtid_purged
RESET SLAVE 不会改变复制连接使用的参数,例如master host, master port, master user, or master password
如果要重置这些连接参数,需要使用命令
RESET SLAVE ALL
重置操作之后,就需要使用 CHANGE MASTER TO 重新指定复制连接参数。
完毕。