mysql读写分离怎么实现(数据库读写分离实现)

为什么要实现mysql读写分离大型网站为了解决大量的并发访问,除了在网站实现分布式负载均衡,远远不够。到了数据业务层、数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器来处理如此多的数据库连接操作,数据库必然会崩溃,特别是数据丢失的话,后果更是不堪设想。这时候,我们会考虑如何减少数据库的连接,下面就进入我们今天的主题。​利用主从数据库来实现读写分离,从而分担主数据库的压力。在多个服…

大家好,又见面了,我是你们的朋友全栈君。

一、为什么要实现mysql读写分离

大型网站为了解决大量的并发访问,除了在网站实现分布式负载均衡,远远不够。到了数据业务层、数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器来处理如此多的数据库连接操作,数据库必然会崩溃,特别是数据丢失的话,后果更是不堪设想。这时候,我们会考虑如何减少数据库的连接,下面就进入我们今天的主题。

​ 利用主从数据库来实现读写分离,从而分担主数据库的压力。在多个服务器上部署mysql,将其中一台认为主数据库,而其他为从数据库,实现主从同步。其中主数据库负责主动写的操作,而从数据库则只负责主动读的操作(slave从数据库仍然会被动的进行写操作,为了保持数据一致性),这样就可以很大程度上的避免数据丢失的问题,同时也可减少数据库的连接,减轻主数据库的负载。

在这里插入图片描述

二、mysql读写分离

mysql读写分离概述

1、mysql本身不能实现读写分离的功能,需要借助中间件实现,例如:Amoeba,Mysql Proxy,Atlas。今天主要介绍Amoeba实现mysql读写分离。

​2、 Amoeba(变形虫)项目,该开源框架于2008发布一款Amoeba for mysql软件,该软件致力于mysql的分布式数据库前端代理层,**主要的作用是应用服务访问mysql服务器时充当SQL路由功能,并具有负载均衡、高可用性、SQL过滤、读写分离、可路由相关SQL的到目标数据库、可并发请求多台数据库全并结果的作用。**通过Amoeba能够完成多数据源的高可用、负载均衡、数据切片的功能。

目前Amoeba已在很多企业的生产线上面使用;其版本可在官网进行下载。其工作原理图如下:

在这里插入图片描述

三、mysql读写分离原理

读写分离就是利用mysql的主从复制完成的,本质就是在主服务器上修改,数据会同步到从服务器,从服务器只能提供读取数据,不能写入,实现备份的同时也实现了数据库性能的优化,以及提升了服务器安全。

四、mysql读写分离配置

本次mysql读写分离使用Amoeba实现,以下为实验过程。

五、mysql读写分离部署配置

主机名               IP           系统
amoeba           10.0.0.41     centos7.3
Mysql-Master     10.0.0.42     centos7.3
Mysql-Slave      10.0.0.43     centos7.3

注:mysql版本和安装方式无要求,实现主从即可。

六、先在amoeba服务器上操作

1、配置jdk环境
cd /usr/local/src/
yum -y install lrzsz    
rz
#增添执行权限
chmod +x jdk-6u14-linux-x64.bin 
#执行安装一路空格,yes安装即可.
./jdk-6u14-linux-x64.bin 
mv jdk1.6.0_14 /usr/local/jdk1.6

在这里插入图片描述

七、配置全局环境变量

vim /etc/profile
#添加如下二行到全局环境变量
export JAVA_HOME=/usr/local/jdk1.6
export PATH=$PATH:$JAVA_HOME/bin
#使环境变量生效
source /etc/profile
#查看java的版本
java -version
#创建一个amoeba目录
mkdir /usr/local/amoeba
#指定路径解压ameoba包
tar zxf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba/
#进入amoeba配置文件
cd /usr/local/amoeba/
cd conf/

在这里插入图片描述

八、Amoeba配置文件位于/usr/local/amoeba/conf目录下,配置读写分离我们只需关注dbServers.xml和amoeba.xml,首先我们先对dbServers.xml 文件进行配置更改操作

vim /usr/local/amoeba/conf/dbServers.xml 

在这里插入图片描述

在这里插入图片描述

九、之后再去MysqL-Master服务器上授权账号,设置amoeba连接后端数据库服务器的账号

grant all on *.* he@'%' identified by '123';
flush privileges;

十、然后再回到amoeba服务器上再去更改另一个配置文件amoeba.xml

 vim /usr/local/amoeba/conf/amoeba.xml 

在这里插入图片描述

在这里插入图片描述

 cd ..
 cd bin/
 #前台启动amoeba服务,之后再开一个窗口进行操作
 ./amoeba start
 #或者执行这个
 /usr/local/amoeba/bin/amoeba start
 mysql -uroot -p123 -h10.0.0.41 -P8066

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

十一、测试读写分离是否成功,读和写是否分开

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

至此,MysqL读写分离功能成功部署。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/126314.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • scp命令拷贝文件

    scp命令拷贝文件简介scp(securecopy)是一个基于SSH协议在网络之间进行安全传输的命令。如果是从本地拷贝到远程,格式为:scp文件用户名@IP地址:目标目录如果是从远程拷贝到本地,格式为:scp用户名@ip地址:带路径文件名本地目录参数-v显示详细的连接进度-P指定远程主机的sshd端口号-r用于传送文件夹-6使用IPv6协议例子从本地拷贝到远程[root@localhost~]#scpmyhistory.txtroot@192.168.31.

    2022年8月22日
    12
  • 服务器系统监控工具,10款超实用的服务器监控工具和软件

    服务器系统监控工具,10款超实用的服务器监控工具和软件服务器监控软件和工具可以帮助我们从任何一个地方实时了解服务器的性能和功能。由于复杂的社交网络系统以及我们对于互联网的高度依赖,我们绝不允许那些宝贵的客户因自身系统停运而流失。选用实用的服务器工具和软件是一个明智的决定,能够同时为你带来短期效益和长期效益。下面是10款超实用的服务器监控工具和软件:1.SimpleServerMonitorSimpleServerMonitor是一款成本合理…

    2022年6月13日
    92
  • html字体属性控制,水平线,上下标,插入图片

    html字体属性控制,水平线,上下标,插入图片

    2021年9月9日
    87
  • Vue 后台管理系统 Demo

    Vue 后台管理系统 DemoGITHUB 原文地址 https github com lin xin vue manage system 前言该方案作为一套多功能的后台框架模板 适用于绝大部分的后台管理系统 WebManagemen 开发 基于 vue js 使用 vue cli3 脚手架 引用 ElementUI 组件库 方便开发快速简洁好看的组件 分离颜色样式 支持手动切换主题色 而且很方便

    2026年2月1日
    0
  • openCV人脸识别简单案例[通俗易懂]

    openCV人脸识别简单案例[通俗易懂]1基础我们使用机器学习的方法完成人脸检测,首先需要大量的正样本图像(面部图像)和负样本图像(不含面部的图像)来训练分类器。我们需要从其中提取特征。下图中的Haar特征会被使用,就像我们的卷积核,每一个特征是一个值,这个值等于黑色矩形中的像素值之后减去白色矩形中的像素值之和。Haar特征值反映了图像的灰度变化情况。例如:脸部的一些特征能由矩形特征简单的描述,眼睛要比脸颊颜色要深,鼻梁两侧比鼻梁颜色要深,嘴巴比周围颜色要深等。Haar特征可用于于图像任意位置,大小也可以任意改变,所以矩形特征值是

    2022年5月28日
    51
  • 进程池及回掉函数[通俗易懂]

    进程池在说进程池之前先来说一个概念:数据共享数据共享1.进程间的通信应该尽量避免共享数据的方式2.进程间的数据是独立的,可以借助队列或管道实现通信,二者都是基于消息传递的。虽然进程间数据独立

    2022年3月29日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号