MySQL 数据库——主从复制与读写分离

前言

在实际的生产环境中,如果对MySQL数据库的读和写都在一台数据库服务中操作,无论在安全性、高可用性,还是高并发性等各个方面都是完全不能满足实际需求的,一般来说都是通过主从复制(Master-Slave)的方式来同步数据,再通过读写分离来提升数据库的并发负载能力这样的方案进行部署与实施

一、案例概述

在企业应用中,成熟的业务通常数据量都比较大
单台 Mysql 在安全性、高可用性和高并发方面都无法满足实际的需求
配置多台主从数据库服务器以实现读写分离

二、mysql主从复制原理

1、mysql的复制类型

基于语句的复制
基于行的复制
混合类型的复制

2、mysql主从复制的工作原理

主服务器 master 记录数据库通过 dump 线程将操作记录到 Binary log
从服务器开启 I/O 线程向主服务器发送同步日志请求
主服务器把二进制日志内容发送给从服务器
从服务器将二进制日志记录的操作同步到relay log (中继日志) (存在从服务器的缓存中)
从服务器中的sql线程将relay log日志记录的操作在从服务器执行后写入从服务器数据库。

在这里插入图片描述

三、mysql读写分离原理

读写分离就是只在主服务器上写,只在从服务上读;
主数据库处理事务性查询,从数据库处理 select 查询;
数据库复制被用来把事务性查询导致的变更同步到集群中的从数据库

四、部署主从同步

1、主从服务器设置时间同步
在这里插入图片描述
2.主服务器的mysql配置
在这里插入图片描述

3.授权
在这里插入图片描述

4.show master status;
//如显示以下
在这里插入图片描述
5.从服务器显示配置
在这里插入图片描述
6.授权在这里插入图片描述
7.启动同步,查看状态
在这里插入图片描述
slave2同样的步骤

五.验证

主服务器上进入执行 create database db_test;
在这里插入图片描述
去从服务器上查看 show databases;
在这里插入图片描述
再看slave2
在这里插入图片描述
如图主从复制成功。

五,部署读写分离

在这里插入图片描述

cp jdk-6u14-linux-x64.bin /usr/local/

cd /usr/local/
chmod +x jdk-6u14-linux-x64.bin
./jdk-6u14-linux-x64.bin
#按住Enter键不动一直到最下面,有提示输入YES+回车即可

在这里插入图片描述

mv jdk1.6.0_14/ /usr/local/jdk1.6
#改名

vim /etc/profile
#编辑全局配置文件,在最后一行添加以下配置
export JAVA_HOME=/usr/local/jdk1.6
export CLASSPATH=$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib
export PATH=$JAVA_HOME/lib:$JAVA_HOME/jre/bin/:$PATH:$HOME/bin
export AMOEBA_HOME=/usr/local/amoeba
export PATH=$PATH:$AMOEBA_HOME/bin

#输出定义Java的工作目录
#输出指定的java类型
#将java加入路径环境变量
#输出定义amoeba工作目录
#加入路径环境变量


source /etc/profile
#执行修改后的全局配置文件
java -version
#查看java版本信息以检查是否安装成功

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值