mysql主备复制搭建

这里我使用单台服务器上的两个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回放线程都已经启动。至此,主备复制结构配置完成

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值