MySQL主从介绍、配置主从、测试主从同步

6月28日任务

说明:有不少同学不能一次性把实验做成功,这是因为还不熟悉,建议至少做3遍
17.1 MySQL主从介绍
17.2 准备工作
17.3 配置主
17.4 配置从
17.5 测试主从同步
有的同学,遇到主从不能正常同步,提示uuid相同的错误。这是因为克隆机器导致。
https://www.2cto.com/database/201412/364479.html

 

17.1 MySQL主从介绍

MySQL主从又叫做Replication、AB复制。简单讲就是A和B两台机器做主从后,在A上写数据,另外一台B也会跟着写数据,两者数据实时同步的
MySQL主从是基于binlog的,主上须开启binlog才能进行主从。
主从过程大致有3个步骤
1)主将更改操作记录到binlog里
2)从将主的binlog事件(sql语句)同步到从本机上并记录在relaylog里
3)从根据relaylog里面的sql语句按顺序执行
主上有一个log dump线程,用来和从的I/O线程传递binlog
从上有两个线程,其中I/O线程用来同步主的binlog并生成relaylog,另外一个SQL线程用来把relaylog里面的sql语句落地。

 

MySQL主从原理图

 

 

使用场景:

第一种、作为单独数据的备份,因为数据很重要,在主上写一份数据,需要单独在存一份数据,只是针对一台主进行读写操作,而从备份的数据就单纯来备份备用着,假如主的主机出现硬件损坏突然宕机,随时可以把从机器启动起来,给客户端提供服务。

第二种、同样也是作为备份,但不仅是备份,web客户端还要在从上面读数据,正常情况下要写到主上,读也是在主上面读,如果主的压力比较大,现在就想在从上面做一个读,那么web服务器就可以在从上面读数据,但是不可以写。(用作存库作为读,减轻主的压力) 

 

17.2 准备工作

把limingsong-001作为主机器,limingsong-002作为从机器,同时把mysql进程启动起来。

启动主上的mysql进程

启动从上的mysql进程

100703  9:28:54 [ERROR] Plugin 'InnoDB' init function returned error. 
100703  9:28:54 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed. 


查看错误日志发现问题,删除mysql目录下的ib_logfile0和ib_logfile1两个文件,就可以解决问题了。

 

17.3 配置主

安装并启动好mysql后,修改my.cnf,增加server-id=128和log_bin=jimmy1

修改完配置文件后需要重启mysqld服务

可以查看到在mysql目录下多了2个文件,这2个文件甚至是更多的文件非常重要,是实现主从的根本,如果没这2个文件的话,主从也没办法完成。

备份mysql库并恢复成limingsong数据库作为测试使用

创建用作同步数据的用户

备份mysql2和test数据库,等会需要把tmp下面所有的sql文件拷贝到从上去。

 

17.4 配置从

编辑my.cnf配置文件,增加server-id=129,要求和主不一样。 

[root@jimmylinux-002 mysql]# vim /etc/my.cnf

增加 server-id=129

重启mysql服务

把主上的sql文件拷贝过来并做一个恢复

[root@jimmylinux-002 mysql]# msyql -uroot
-bash: msyql: 未找到命令

设置alias即可使用

[root@jimmylinux-002 mysql]# alias 'mysql=/usr/local/mysql/bin/mysql'
[root@jimmylinux-002 mysql]# alias 'mysqldump=/usr/local/mysql/bin/mysqldump'

登录mysql创建4个数据库

恢复数据库

登录mysql开始实行主从

如果出现Slave_IO_Running: Connecting 的情况,需要把主机器上的firewalld关闭,然后在执行同步即可。

[root@jimmylinux-001 mysql]# systemctl stop firewalld

这个时候主从就已经建立起来了,记得要把主机器上面解锁恢复写数据。

[root@jimmylinux-001 mysql]# mysql -uroot -pabcd1234  登录主机器的mysql

mysql> unlock tables;  解锁恢复写数据
Query OK, 0 rows affected (0.00 sec)

到此整个主从就已经搭建完成了

 

17.5 测试主从同步

测试主从同步之前先了解下主、从服务器上面的配置参数

配置文件都是my.cnf

主服务器上
 binlog-do-db=      //仅同步指定的库
 binlog-ignore-db= //忽略指定库

从服务器上
 replicate_do_db=
 replicate_ignore_db=
 replicate_do_table=
 replicate_ignore_table=
 replicate_wild_do_table=   //如jimmy.%, 支持通配符% 
 replicate_wild_ignore_table=

开始测试主、从同步

查看主机器的数据库信息

mysql> use mysql2
Database changed
mysql> show tables;
+---------------------------+
| Tables_in_mysql2          |
+---------------------------+
| columns_priv              |
| db                        |
| event                     |
| func                      |
| general_log               |
| help_category             |
| help_keyword              |
| help_relation             |
| help_topic                |
| innodb_index_stats        |
| innodb_table_stats        |
| ndb_binlog_index          |
| plugin                    |
| proc                      |
| procs_priv                |
| proxies_priv              |
| servers                   |
| slave_master_info         |
| slave_relay_log_info      |
| slave_worker_info         |
| slow_log                  |
| tables_priv               |
| time_zone                 |
| time_zone_leap_second     |
| time_zone_name            |
| time_zone_transition      |
| time_zone_transition_type |
| user                      |
+---------------------------+
28 rows in set (0.00 sec)

mysql> select count(*) user;
+------+
| user |
+------+
|    1 |
+------+
1 row in set (0.00 sec)

查看从机器的数据库信息

mysql> use mysql2
Database changed
mysql> show tables;
+---------------------------+
| Tables_in_mysql2          |
+---------------------------+
| columns_priv              |
| db                        |
| event                     |
| func                      |
| general_log               |
| help_category             |
| help_keyword              |
| help_relation             |
| help_topic                |
| innodb_index_stats        |
| innodb_table_stats        |
| ndb_binlog_index          |
| plugin                    |
| proc                      |
| procs_priv                |
| proxies_priv              |
| servers                   |
| slave_master_info         |
| slave_relay_log_info      |
| slave_worker_info         |
| slow_log                  |
| tables_priv               |
| time_zone                 |
| time_zone_leap_second     |
| time_zone_name            |
| time_zone_transition      |
| time_zone_transition_type |
| user                      |
+---------------------------+
28 rows in set (0.00 sec)

mysql> select count(*) user;
+------+
| user |
+------+
|    1 |
+------+
1 row in set (0.00 sec)

现在要在主上把这个表做一个清空操作

 从上显示为0

再测试一个删除表的操作

mysql> drop table user;     主上删除user表
Query OK, 0 rows affected (0.01 sec)


mysql> select * from user;  从上的表也同样没有了,所以会报错不存在。
ERROR 1146 (42S02): Table 'mysql2.user' doesn't exist

 

 

 

 

 

 

 

 

posted @ 2018-06-28 17:59  吉米乐享驿站  阅读(1512)  评论(0编辑  收藏  举报