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)
上一篇 2022年4月17日 下午10:20
下一篇 2022年4月17日 下午10:20


相关推荐

  • 移动端页面适配方案(viewport)[通俗易懂]

    移动端页面适配方案(viewport)[通俗易懂]通过<metaname=”viewport”>给视口设置固定的宽度,浏览器对页面自动缩放来实现页面的适配效果优点是可以使用px布局,不用额外进行rem或者vw等等单位的换算了缺点是如果是无滚动条的页面在某些设备上(例如平板这种宽高3比4的,折叠屏8比7的)由于宽高比不同有些区域会被挤到视口之外从而导致一些体验上的问题,不过demo2也给出了解决方案;这里给两个demo,demo1是有滚动条页面的示例,demo2是无滚动条页面的示例;新建一个html文件将demo复制过去在浏览器.

    2022年6月28日
    32
  • mysql字符串拼接有空值_MySQL字符串拼接「建议收藏」

    mysql字符串拼接有空值_MySQL字符串拼接「建议收藏」concat()函数拼接时不会忽略空格,但如果有值是null,则结果为nullselectconcat(‘My’,’S’,’Q’,’L’);->MySQLSELECTCONCAT(‘c’);->cSELECTCONCAT(id,name)fromuser2;->1张三2李四concat_ws()函数拼接时不会忽略空格,但会忽略nullselectconcat_…

    2026年4月18日
    6
  • 腾讯发布 Agent 最新BenchMark:C3-Bench

    腾讯发布 Agent 最新BenchMark:C3-Bench

    2026年3月16日
    1
  • Web容器是什么?

    Web容器是什么?在学习之前 我们想想什么是 Web 容器 以及怎么学习 Web 容器 在学习一门技术之前 想想这两个问题 可以达到事半功倍的效果 让我们回顾一下 web 技术的发展历史 可以帮助你理解 web 容器的由来 早期的 web 应用主要应用于浏览静态网页 HTTP 服务器 比如 Apache Nginx 向浏览器返回静态 HTML 浏览器负责解析 HTML 将结果呈现给用户 随着互联网发展 我们已不满足于仅仅浏览静态网页 还希望通过一些交互操作来获取动态结果 因此也就需要一些扩展机制能够让 Http 服务器调用服务端程序

    2026年3月16日
    2
  • 关系图谱在贝壳的构建和应用

    关系图谱在贝壳的构建和应用分享嘉宾:周玉驰贝壳资深算法工程师文章整理:许继瑞内容来源:贝壳找房知识图谱技术大会出品平台:DataFun注:欢迎转载,转载请在留言区留言。导读:贝壳找房积累了大量房、客、人的行为…

    2022年6月26日
    31
  • quotename()函数 

    quotename()函数 请教quotename函数的理解,我已经看了很多帮助,储如以下示例 QUOTENAME(Transact-SQL)返回带有分隔符的Unicode字符串,分隔符的加入可使输入的字符串成为有效的MicrosoftSQLServer2005分隔标识符。Transact-SQL语法约定语法QUOTENAME(‘character_string'[,’q…

    2022年7月25日
    14

发表回复

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

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