mysql读写分离优点_mysql读写分离

mysql读写分离优点_mysql读写分离什么是读写分离在数据库集群架构中,让主库负责处理事务性查询,而从库只负责处理select查询,让两者分工明确达到提高数据库整体读写性能。当然,主数据库另外一个功能就是负责将事务性查询导致的数据变更同步到从库中,也就是写操作。读写分离的好处1)分摊服务器压力,提高机器的系统处理效率读写分离适用于读远比写的场景,如果有一台服务器,当select很多时,update和delete会被这些select访问…

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

什么是读写分离

在数据库集群架构中,让主库负责处理事务性查询,而从库只负责处理select查询,让两者分工明确达到提高数据库整体读写性能。当然,主数据库另外一个功能就是负责将事务性查询导致的数据变更同步到从库中,也就是写操作。

读写分离的好处

1)分摊服务器压力,提高机器的系统处理效率

读写分离适用于读远比写的场景,如果有一台服务器,当select很多时,update和delete会被这些select访问中的数据堵塞,等待select结束,并发性能并不高,而主从只负责各自的写和读,极大程度的缓解X锁和S锁争用;

假如我们有1主3从,不考虑上述1中提到的从库单方面设置,假设现在1分钟内有10条写入,150条读取。那么,1主3从相当于共计40条写入,而读取总数没变,因此平均下来每台服务器承担了10条写入和50条读取(主库不承担读取操作)。因此,虽然写入没变,但是读取大大分摊了,提高了系统性能。另外,当读取被分摊后,又间接提高了写入的性能。所以,总体性能提高了,说白了就是拿机器和带宽换性能;

2)增加冗余,提高服务可用性,当一台数据库服务器宕机后可以调整另外一台从库以最快速度恢复服务

什么是  Mycat

是一个开源的分布式数据库系统,但是因为数据库一般都有自己的数据库引擎,而Mycat并没有属于自己的独有数据库引擎,所有严格意义上说并不能算是一个完整的数据库系统,只能说是一个在应用和数据库之间起桥梁作用的中间件。

在Mycat中间件出现之前,MySQL主从复制集群,如果要实现读写分离,一般是在程序段实现,这样就带来了一个问题,即数据段和程序的耦合度太高,如果数据库的地址发生了改变,那么我的程序也要进行相应的修改,如果数据库不小心挂掉了,则同时也意味着程序的不可用,而对于很多应用来说,并不能接受;

引入Mycat中间件能很好地对程序和数据库进行解耦,这样,程序只需关注数据库中间件的地址,而无需知晓底层数据库是如何提供服务的,大量的通用数据聚合、事务、数据源切换等工作都由中间件来处理;

Mycat中间件的原理是对数据进行分片处理,从原有的一个库,被切分为多个分片数据库,所有的分片数据库集群构成完成的数据库存储,有点类似磁盘阵列中的RAID0.

实现读写分离

准备工作

步骤一:创建数据库

#创建数据库

CREATE DATABASE weibo_simple

步骤二:创建用户表

48304ba5e6f9fe08f3fa1abda7d326ab.png

CREATE TABLE `t_users` (

`user_id` varchar(64) NOT NULL COMMENT ‘注册用户ID’,

`user_email` varchar(64) NOT NULL COMMENT ‘注册用户邮箱’,

`user_password` varchar(64) NOT NULL COMMENT ‘注册用户密码’,

`user_nikename` varchar(64) NOT NULL COMMENT ‘注册用户昵称’,

`user_creatime` datetime NOT NULL COMMENT ‘注册时间’,

`user_status` tinyint(1) NOT NULL COMMENT ‘验证状态 1:已验证 0:未验证’,

`user_deleteflag` tinyint(1) NOT NULL COMMENT ‘删除标记 1:已删除 0:未删除’,

PRIMARY KEY (`user_id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

48304ba5e6f9fe08f3fa1abda7d326ab.png

步骤三:创建微博表

48304ba5e6f9fe08f3fa1abda7d326ab.png

CREATE TABLE `t_message` (

`messages_id` varchar(64) NOT NULL COMMENT ‘微博ID’,

`user_id` varchar(64) NOT NULL COMMENT ‘发表用户’,

`messages_info` varchar(255) DEFAULT NULL COMMENT ‘微博内容’,

`messages_time` datetime DEFAULT NULL COMMENT ‘发布时间’,

`messages_commentnum` int(12) DEFAULT NULL COMMENT ‘评论次数’,

`message_deleteflag` tinyint(1) NOT NULL COMMENT ‘删除标记 1:已删除 0:未删除’,

`message_viewnum` int(12) DEFAULT NULL COMMENT ‘被浏览量’,

PRIMARY KEY (`messages_id`),

KEY `user_id` (`user_id`),

CONSTRAINT `t_message_ibfk_1` FOREIGN KEY (`user_id`) REFERENCES `t_users` (`user_id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

48304ba5e6f9fe08f3fa1abda7d326ab.png

安装mycat

步骤一:解压mycat,不要放在有中文目录的文件夹下

a3b94156ebdee87ee1d077ffb876b076.png

步骤二:修改mycat目录下的conf文件夹中的server.xml文件,配置账户

48304ba5e6f9fe08f3fa1abda7d326ab.png

mycat_master

mycat

mycat_slave

mycat

true

48304ba5e6f9fe08f3fa1abda7d326ab.png

步骤三:配置schema.xml文件

48304ba5e6f9fe08f3fa1abda7d326ab.png

writeType=”0″ dbType=”mysql” dbDriver=”native” switchType=”1″

slaveThreshold=”100″>

select user()

48304ba5e6f9fe08f3fa1abda7d326ab.png

步骤四:配置rule.xml文件

48304ba5e6f9fe08f3fa1abda7d326ab.png

user_id

func1

autopartition-long.txt

48304ba5e6f9fe08f3fa1abda7d326ab.png

步骤五:配置启动日志文件log4j.xml

步骤六:启动mycat,默认端口为8066

master

1a9e78da4354cd679b1eba3ce1974aea.png

master机器上可以进行读写操作

886560d28850f5632765981770f9a990.png

slave

6c7747542ff8c303f5496f7cdb7a2fc4.png

slave机器上可以进行读操作,进行写操作时会报错

5fbd5adf96de4e9fe4479fd7996ca3f3.png

注意注意注意特别注意

1.在使用mycat连接SQLyog时,SQLyog版本不能太低,版本不能太低,不能太低,需要高版本!!!

2.在双击启动mycat时,如果控制台一闪而过,参考方案如下

修改startup_nowrap.bat启动文件,内容如下

“%JAVA_CMD%” -server -Xms512M -Xmx600M -XX:MaxPermSize=64M -XX:+AggressiveOpts -XX:MaxDirectMemorySize=1G -DMYCAT_HOME=%MYCAT_HOME% -cp “..\conf;..\lib\*” org.opencloudb.MycatStartup

好文要顶 已关注 收藏该文

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/130394.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • linux常用命令vi 退出_vi命令退出

    linux常用命令vi 退出_vi命令退出进入编辑模式,按o进行编辑编辑结束,按ESC键跳到命令模式,然后输入退出命令::w保存文件但不退出vi编辑:w!强制保存,不退出vi编辑:wfile将修改另存到file中,不退出vi编辑:wq保存文件并退出vi编辑:wq!强制保存文件并退出vi编辑q:不保存文件并退出vi编辑:q!不保存文件并强制退出vi编辑:e!放弃所有修改,从上次保…

  • pycharm怎么导入数据库_pycharm导入python

    pycharm怎么导入数据库_pycharm导入python记录一下自己最近一段时间可能用不上的代码,免得以后再找起来麻烦。pycharm连接数据库首先在找到Database,选择连接自己下载的数据库软件。填写完自己的数据库密码后,如果正确的话,就会出现下面这张图。点下“刷新”按钮后即可连接数据库。测试是否连接成功。到这里基本完成了外部数据导入步骤。2.代码importpymysqlimportmath#用来操作数据库的类classclimb_test_DataInput(object):#…

  • GSLB相关知识点

    GSLB相关知识点摘要GSLB是GlobalServerLoadBalance的缩写,即全局负载均衡。本文首先介绍了什么是负载均衡SLB,以及为什么要使用SLB。接着引出全局负载均衡GSLB的概念和作用。为此介绍了其基于DNS进行解析和分配负载的实现,包括DNS的原理简介、应用部署中的基本概念、分配负载的决策条件等内容。以外,本文还简单介绍了通过HTTP和IP…

  • Android EdtiText 添加表情

    Android EdtiText 添加表情

  • 精进Quartz—SSMM(Spring+SpringMVC+Mybatis+Mysql)和Quartz集成详解(四)

    当任何时候觉你得难受了,其实你的大脑是在进化,当任何时候你觉得轻松,其实都在使用以前的坏习惯。SSMM(Spring+SpringMVC+Mybatis+Mysql)和Quartz集成详解

  • Vim简明教程【CoolShell】

    Vim简明教程【CoolShell】

    2021年12月17日

发表回复

您的电子邮箱地址不会被公开。

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