MySQL数据库优化之主从复制
思想部分
(喜欢实战的可以先看实战)
-
MySQL复制能解决什么问题
- MySQL的负载均衡(分担读负载)
- 为高可用 灾难恢复 备份提供更多的选择
- 读写分离
-
主从配置优点
- 解决应用系统,数据库出现的性能瓶颈,采用数据库集群的方式来实现查询负载;通常情况下一个系统中数据库的查询操作比更新操作要多得多,通过多台查询服务器将 数据库的查询分担到不同的查询服务器上从而提高查询效率。
- 数据备份,高可用性和故障切换,增强了数据库的安全性,利用从库备份来减少主库负载,从库复制并不能代替备份.,备份是有必要的
- 实现数据库的在线升级
-
MySQL日志
MySQL有很多种日志分为两类-
MySQL存储引擎日志
Innodb: 重做日志 , 回滚日志
- MySQL服务层日志(默认只有error日志,其他的需要在配置文件中手动开启) 慢查询日志、二进制日志(习惯称bin_log日志)、通用日志等
-
-
二进制日志
- 记录了所有对MySQL数据库的修改事件,包括增删改查事件和对表结构的修改事件
- 没有执行成功的SQL是不会记录到二进制日志 还有就是当你重启了mysql之后,会从新生成一个二进制文件,旧的会保存一段时间
-
复制如何工作
- 在主库上把数据更改记录到二进制日志(bin-log)中(这些记录日志被称为二进制日志事件)
- 从库将主库上的日志复制到自己中继日志
- 从库读取自己的中继日志中的事件,将其重放到自己数据上
6. 一主多从
实战开始
image笔者按量购买了两台阿里云服务器,1小时4毛钱
两台机器都需要安装mysql
主库和从库分别执行以下命令:
apt-get update
apt-get install mysql-server
登陆主库,创建一个从库可以访问的帐号
进入mysql,输入以下命令创建用户
grant replication slave on *.* to 'USERNAME'@'IP' identified by 'PASSWORD';
Username(帐号)、IP(服务器地址)、Password(密码)需要自己指定。 mysql库中user表的数据
同源策略,将主库的库文件复制到从库
注意,先要停止Mysql服务,主库从库都要停止。
service mysql stop
库位置/var/lib/mysql
,mysql文件夹就是这个所有的库,需要把这个文件夹复制到从库。现将这个文件进行压缩。
tar -zcvf mysql.tar.gz ./mysql/
然后,复制到从库。下面这条命令是超服务器传输的复制命令
scp ./mysql.tar.gz UserName@IP:/tmp
Username 换成主库的帐号,IP主库的IP,/tmp是复制到主库的/tmp文件夹下,当然可以自己指定。 首先进入从库,查看从库是否有了这个压缩文件,并进行移动到从库的
/var/lib/
cd /tmp/
mv mysql.tar.gz /var/lib/
将从库mysql文件夹进行备份,以防失败。
cd /var/lib/
mv mysql mysql.bak
将主库传过来的mysql.tar.gz 解压,这就完成了同源策略
tar -zxvf mysql.tar.gz
这时,就可以主从就都可以开启mysql服务了。
service mysql start
配置主库和从库
主库配置/etc/mysql/my.cnf
[mysqld]
server-id = 1
log_bin = /var/log/mysql/mysql-bin.log
expire_logs_days = 10
max_binlog_size = 100M
binlog-ignore-db=mysql //不进行主从复制的库
# 将bind-address注释,为了能够使用从库服务器IP登陆主库
#bind-address = 127.0.0.1
从库配置/etc/mysql/my.cnf
[mysqld]
server-id = 2
log_bin = /var/log/mysql/mysql-bin.log
expire_logs_days = 10
max_binlog_size = 100M
binlog-ignore-db=mysql
注意配置文件可能因为版本不同,而产生配置文件不对应,只需要自己去找一下,配置中包含[mysqld]选项的进行修改就可以了。
配置主从库登陆信息
在主库执行命令,查看bin-log日志写到了什么位置
show master status;
查看bin-log
查看到了File和Position,我们会用到这两个值。 接下来,在从库中执行面的命令。配置主库的信息
CHANGE MASTER TO MASTER_HOST ='120.24.47.140',MASTER_USER = 'test1', MASTER_PASSWORD='123456',MASTER_LOG_FILE = 'mysql-bin.000001',MASTER_LOG_POS=107;
参数解析
MASTER_HOST:主服务器IP
MASTER_USER:在主服务器中创建一个帐号,笔者是test1
MASTER_PASSWORD:自己定义的密码,笔者是123456
MASTERLOGFILE:上一步查看的FILE文件,笔者是mysql-bin.000001
MASTERLOGPOS:上一步查看的Postion位置,笔者是107
最后,成功的最后一步
启动复制
mysql > START SLAVE;
停止复制
STOP SLAVE;
查看状态
SHOW SLAVE STATUS;
主从复制成功.png
扩展:Laravel中读写分离的实现
image
网友评论