博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL主从复制和读写分离
阅读量:6383 次
发布时间:2019-06-23

本文共 1888 字,大约阅读时间需要 6 分钟。

我们知道应用对数据库的訪问通常情况下大部分都是读操作,写仅仅占非常少一部分。因此读写分离(read-write-splitting)能有效减少主库压力,从而解决站点发展过程中遇到的第一次数据库瓶颈。

主从复制

首先必须开启master库的bin-log,由于mysql的主从复制是异步的。所以master库必须将更新操作记录下来以供slave库读取。

假设如今有A, B两台机器,A为master, B为slave。

Master

ssh至A服务器,登陆mysql, 创建一个复制专用用户repl

GRANT REPLICATION SLAVE ON *.* TO 'repl'@'B的IP' IDENTIFIED BY '111111';

改动my.cnf文件。开启bin-log并设置server-id:

[mysqld]log-bin = /XXXX/mysql-bin.logserver-id = 1

重新启动mysql使配置生效。

然后设置读锁,确保在配置好slave库之前master库没有读写操作:

flush tables with read lock;

查看master库当前bin-log的文件名称和偏移量:

show master status;+------------------+----------+--------------+------------------+| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |+------------------+----------+--------------+------------------+| mysql-bin.000002 |     1075 |              |                  |+------------------+----------+--------------+------------------+1 row in set (0.00 sec)

记下文件名称和偏移量。此时master已经停止了全部的数据更新操作,这时候我们要把master库的数据进行备份,然后还原到slave库中。推荐通过mysqldump命令完毕该操作。master备份完毕后就可以取消锁:

unlock tables;

Slave

ssh至B服务器,改动配置文件:

[mysqld]server-id = 2

通过mysqld_safe启动从库。加入--skip-slave-start參数:

mysqld_safe --skip-slave-start

这样做的目的是不要让从库启动时就启动复制线程。由于我们还没有配置主库信息。

mysql> CHANGE MASTER TO-> MASTER_HOST='主库地址',-> MASTER_PORT=3306,-> MASTER_USER='repl',-> MASTER_PASSWORD='111111',-> MASTER_LOG_FILE='mysql-bin.000002', -> MASTER_LOG_POS=1075;

启动slave线程:

start slave;

至此从库配置完毕。假设一切顺利的话,此时在主库运行一条更新操作,从库也会立即跟进。

假设发现有问题,能够运行

show slave status;

查看具体信息。

读写分离

眼下读写分离有两种方案:

  1. 控制应用程序,写操作连接主库,读操作连接从库。
  2. 引入数据库中间件。如官方的mysql-proxy

    优点是读写分离相应用程序全然透明,不须要对程序代码做不论什么改动。

    可是眼下mysql-proxy依旧仅仅有alpha版本号,而且官方也不推荐将其用在生产环境中。

事实上对于方案一另一个比較优雅的解决方式。那就是使用ReplicationDriver

MySQL的JDBC驱动中自带ReplicationDriver。它能够将JDBC中全部conn.setReadOnly(true)的连接路由到从库中,从而使得我们不必对程序代码动大手术。

配合Spring, 我们能够使用@Transactional(readOnly = true)注解。

由于MySQL主从复制有延迟,所以对于实时性要求高的操作,我们能够将readOnly设为false来让ReplicationDriver从主库中读取数据,这也是一种能够接受的方案。

配置演示样例:

转载地址:http://bzzha.baihongyu.com/

你可能感兴趣的文章
在.NET中实现彩色光标/动画光标和自定义光标[转]
查看>>
freemarker错误七
查看>>
Cocos2dx 3.x创建Layer的步骤
查看>>
ASP.NET MVC 中将数据从View传递到控制器中的三种方法(表单数据绑定)
查看>>
SpringMVC+easyUI CRUD 添加数据C
查看>>
本地CS的导出xls代码段
查看>>
C++数组和指针
查看>>
恭贺自己itpub和csdn双双获得专家博客称号
查看>>
xml 转map dom4j
查看>>
Vitamio视频播放器
查看>>
Java编程的逻辑 (66) - 理解synchronized
查看>>
[置顶] android 自定义ListView实现动画特效
查看>>
机器学习A-Z~Logistic Regression
查看>>
聊聊flink的NetworkEnvironmentConfiguration
查看>>
【Go】strings.Replace 与 bytes.Replace 调优
查看>>
RSA签名的PSS模式
查看>>
c# 注销 代码
查看>>
ubuntu 安装-apache2-trac-ldap【验证】-svn-mysql
查看>>
Nginx 安装
查看>>
php GD库
查看>>