单个mysql数据库在处理业务的时候肯定是有限的,这时我们扩展数据库的第一种方式就是对数据库做读写分离(主从复制)
,本文我们就先来介绍下怎么来实现mysql的主从复制操作。
原理:需要搭建主从模式,让主数据库(master)处理事务性增、改、删操作(INSERT、UPDATE、DELETE),而从数据库(slave)处理 SELECT 查询操作。
Mycat 配合数据库本身的复制功能,可以解决读写分离的问题。
什么是主从备份: 就是一种主备模式的数据库应用.
主库(Master)数据与备库(Slave)数据完全一致.
实现数据的多重备份, 保证数据的安全.
可以在 Master[InnoDB
]和 Slave[MyISAM
]中使用不同的数据库引擎,实现读写的分离
InnoDB
:支持事务处理
MyISAM
:不支持事务处理
在老旧版本的 MySQL 数据库系统中,不支持主从备份,需要安装额外的 RPM 包.如果需要安装 RPM,只能在一个位置节点安装.
保证数据的安全. 尽量避免数据丢失的可能.
使用不同的数据库引擎,实现读写分离.提高所有的操作效率.
InnoDB 使用 DML 语法操作. MyISAM 使用 DQL 语法操作.
所有对 Master 的操作,都会同步到 Slave 中.如果 Master 和 Salve 天生上环境不同,那么对 Master 的操作,可能会在 Slave 中出现错误如: 在创建主从模式之前,Master 有 database : db1, db2, db3. Slave 有 database: db1, db2.创建主从模式.现在的情况 Master 和 Slave 天生不同.主从模式创建成功后,在 Master 中 drop database db3. Slave 中抛出数据库 SQL 异常.后续所有的命令不能同步.一旦出现错误. 只能重新实现主从模式.
mysql安装教程:
https://blog.csdn.net/weixin_45600622/article/details/102647528
环境地址:
主节点:192.168.88.180
从节点:192.168.88.181
路径:/etc/my.cnf
本环境中 server_id 是 1
MySQL 服务唯一标识
配置要求:
server_id 任意配置,只要是数字即可
server_id Master 唯一标识数字必须小于 Slave 唯一标识数字.
本环境中 log_bin 值 : master_log
开启日志功能以及日志文件命名,log_bin=master_log
变量的值就是日志文件名称.是日志文件名称的主体.
MySQL 数据库自动增加文件名后缀和文件类型.
service mysql restart
从mysql的安装路径下进入
./bin/mysql -uroot -h127.0.0.1 -p123456
在 MySQL 数据库中,为不存在的用户授权,就是同步创建用户并授权.
此用户是从库访问主库使用的用户
ip
地址不能写为%. 因为主从备份中,当前创建的用户,是给从库 Slave 访问主库 Master使用的.用户必须有指定的访问地址.不能是通用地址.
grant all privileges on *.* to ‘username’@’ip’ identified by ‘password’ with grant option;
flush privileges;
grant all privileges on *.* to 'myslave'@'192.168.88.181' identified by 'myslave' with grant
option;
flush privileges;
use mysql;
select host, user from user;
master_log.00003就是主从复制中从数据库要读取的日志文件。
注意
:关闭防火墙或在防火墙中开放 3306 端口
从库的 server_id要比主库中的server_id的值要大
stop slave
需要修改的数据是依据 Master 信息修改的.ip
是 Master 所在物理机 IP. 用户名和密码是Master 提供的 Slave 访问用户名和密码. 日志文件是在 Master 中查看的主库信息提供的.在Master 中使用命令 show master status 查看日志文件名称.
change master to master_host=’ip
’, master_user=’username
’, master_password=’password
’, master_log_file=’log_file_name
’;
start slave;
show slave status \G; # \G 行转列
注意
:如果输出中有如下提示:
Last_IO_Error: Fatal error: The slave I/O thread stops because master and slave have equal MySQL server ids; these ids must be different for replication to work (or the –replicate-same-server-id option must be used on slave but this does not always make sense; please check the manual before using it).
原因是以为两个数据库是克隆出来的,所以uuid是一致的,这时只需要删除掉一个uuid即可,具体如下:
把auto.cnf
注释掉或者删除掉,重启mysql就会重新分配!
在master上新建一个数据库,然后查看slave中是否也有即可
create database demo2 default character set utf8;
create table t_user (id varchar(20),name varchar(20));
insert into t_user (id,name)values('666','bobo');
通过演示我们发现主数据库的修改会及时的同步到从数据库,这样mysql的主从配置就OK了,好了本文就到此,下篇来详细介绍一下MyCat的安装与配置