mysql主从读写分离实战

栏目: 数据库 · Mysql · 发布时间: 4年前

内容简介:推荐第二种方式,尤其是数据量较大的情况下

环境

  • mysql-5.7.19
  • Centos7
  • master: 192.168.111.64
  • slave: 192.168.111.66

主从配置

master配置

## GTID
server_id = 100  # 服务器id,从库最好大于主库,注意要唯一
gtid_mode = on    #开启gtid模式
enforce_gtid_consistency = on    #强制gtid一致性,开启后对特定的create table不被支持
log-bin = mysql-bin    #开启二进制日志
binlog_format = row    #默认为mixed混合模式,更改成row复制,为了数据一致性
log-slave-updates = 1    #从库binlog才会记录主库同步的操作日志
skip_slave_start=1    #跳过slave复制线程

slave配置

## 设置server_id,注意要唯一
server_id=101
log-bin = mysql-bin
binlog_format = row
log-slave-updates = 1
gtid_mode = on
enforce_gtid_consistency = on
skip_slave_start=1
# 从库设置为只读
read_only=on

重启数据库

service mysqld restart

创建用户

# 用户从库同步
GRANT SELECT,RELOAD,SHOW DATABASES,LOCK TABLES,EVENT,REPLICATION CLIENT  ON *.* TO 'repl_user'@'192.168.111.64' IDENTIFIED BY '123456';

# 创建只读用户,用户从库读取数据
GRANT Select ON *.* TO 'reader'@'192.168.111.%'  IDENTIFIED BY "123456";

数据导出

# 在192.169.111.66上操作
nohup mysqldump --single-transaction --master-data=2 --triggers --routines --all-databases --events -h192.168.111.64 -u'root' -p'password' > /home/backup.sql &
因为数据量较大(导出大概30G),使用 nohup [commend] & 使用后台导出,防止导出时间过长连接断开,可以使用 jobs -l 命令查看

数据导出也可以直接在主库服务器上导出,然后通过 scp backup.sql 192.168.111.66:/home 命令传到从库服务器

从库数据导入

连接 mysql 导入

  • 登陆mysql
# 连接到数据库
mysql -uroot -p'123456';
  • 执行导入 sql 命令
source /home/backup.sql

命令直接导入

nohup mysql -uroot -p’123456’ < /home/backup.sql &

推荐第二种方式,尤其是数据量较大的情况下

在192.168.111.66上设置主从连接

  • 连接mysql
mysql -uroot -p'123456'
  • 设置
# 设置
CHANGE MASTER TO MASTER_HOST='192.168.111.64', MASTER_PORT=3306,MASTER_USER='repl_user',MASTER_PASSWORD='123456',MASTER_AUTO_POSITION=1;

# 开启主从
start slave;

# 查看主从状态
show slave status \G;

常用命令:

stop slave
reset slave
reset master

以上所述就是小编给大家介绍的《mysql主从读写分离实战》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Internet与WWW程序设计教程(第三版)

Internet与WWW程序设计教程(第三版)

戴特尔 / 电子工业出版社 / 2005-8 / 95.00元

《Internet与WWW程序设计教程》(第3版)以大量生动、实用的示例讲述了如何编写多层的、客户/服务器的、数据密集的、基于Web的应用程序,介绍了如何使用XHTML、JavaScript、DHTML、Flash和XML建立客户端应用程序,也介绍了如何使用Web服务器(IIS、PWS和Apache)、数据库(SQL、MySQL、DBI和ADO)、ASP、Perl、CGI、Python、PHP、J......一起来看看 《Internet与WWW程序设计教程(第三版)》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器