您的位置:首页 > 数据库 > MySQL

mysql主备复制搭建

2015-11-11 18:33 645 查看
这里我使用单台服务器上的两个mysql实例进行搭建,主要用到了mysql自带的mysqld_multi

一、复制原理
开始搭建前有个mysql复制原理的基础知识需要补充:
mysql进行主备复制使用到了三个线程:
1.主库上的转存储线程:
会将mysql server提交的事务写入到二进制文件中,这个二进制文件就叫做binlog。
2.备库上的连接线程:
备库启动后,负责和主库通信,读取binlog,同时,将binlog存储进自己的一个叫中继日志的relaylog中。
3.备库上的relaylog重放线程:
此线程会将relaylog中的事件在备库上进行回放,说白点就是重新执行一次

二、搭建步骤
1./etc新增文件mysqld_multi.cnf
将/user/share/mysql/my-innodb-heavy-4G.cnf文件复制到/etc,重新命名为xxx.cnf(任何你想要的名字)
在配置文件中新增两个实例

Java代码

1. [mysqld1]
2. # generic configuration options
3. port = 3306
4. socket = /home/tmp/server1/mysql1.sock
5. datadir = /home/mysql/data1
6. log-error = /home/mysql/data1/error.log
7. pid-file = /home/mysql/data1/mysql1.pid
8. log_bin = mysql-bin
9. server_id = 101
10.
11. [mysqld2]
12. port = 3307
13. socket = /home/tmp/server2/mysql2.sock
14. datadir = /home/mysql/data2
15. log-error = /home/mysql/data2/error.log
16. pid-file = /home/mysql/data2/mysql2.pid
17. log_bin = mysql-bin
18. server_id = 102
19. relay_log = /home/relaylog/mysql-relay-bin
20. log_slave_updates = 1
21. read_only = 1

这里我会将将mysqld1这个实例做为主库,mysqld2这个实例作为备库

2.做好了配置之后开启两个实例:
mysqld_multi--defaults-file=xxx.cnf start 1,2 &

3.开启实例后检测两个实例是否正常启动:

mysqld_multi --defaults-file=xxx.cnf report 1

mysqld_multi --defaults-file=xxx.cnf report 2
如果都看到如下结果,说明实例已启动成功:

4.开启复制前主库的准备工作:
1.在主库上增加一个复制账号:
使用sock文件登陆mysql:
mysql -u root -S/home/tmp/server1/mysql1.sock(这个套接字文件还记得吗,是在之前定义实例的时候 定义的)

Java代码

1. grant replication slave,replication client on *.* to repl@'127.0.0.1' identified by 'xxxxx';

2.查看主库上的binlog是否开启:

showmaster status;

Java代码

1. +------------------+----------+--------------+------------------+
2. | File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
3. +------------------+----------+--------------+------------------+
4. | mysql-bin.000001 | 507 | | |
5. +------------------+----------+--------------+------------------+

mysql-bin.000001这个文件的前缀就是你在配置实例1时指定的log-bin。

5.开启复制:
登陆到备库:
mysql -u root-S/home/tmp/server2/mysql2.sock

Java代码

1. change master to master_host = "localhost",
2. master_user = 'repl',
3. master_password = 'xxx',(你之前在主库上创建复制账号时指定的)
4. master_log_file = 'mysql-bin.000001',
5. master_log_pos = 0,
6. master_port = 3306;

查看复制是否开始工作:

Java代码

1. Slave_IO_State: Waiting for master to send event
2. Master_Host: localhost
3. Master_User: repl
4. Master_Port: 3306
5. Connect_Retry: 60
6. Master_Log_File: mysql-bin.000001
7. Read_Master_Log_Pos: 507
8. Relay_Log_File: mysql-relay-bin.000174
9. Relay_Log_Pos: 235
10. elay_Master_Log_File: mysql-bin.000001
11. Slave_IO_Running: Yes
12. Slave_SQL_Running: Yes

当看到Slave_IO_Running: Yes 和 Slave_SQL_Running:Yes证明io通信线程和sql回放线程都已经启动。至此,主备复制结构配置完成
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: