• 海。
    2018-05-30
    老师,您好
    我个人的想法是可以加入缓存,例如注册后登录这种业务,可以在注册后加入数据库,并加入缓存,登录的时候先查缓存再查库表。
    例如存入redis中并设置十分钟的过期时间。登录的时候先查redis,再查库表,如果redis中没有,说明就是过期的数据,这时候查从机就肯定存在了,希望能得到老师的点评,谢谢。

    作者回复: 赞同,并不是说一有性能问题就上读写分离,而是应该先优化,例如优化慢查询,调整不合理的业务逻辑,引入缓存等,只有确定系统没有优化空间后,才考虑读写分离或者集群

    
     89
  • tangfengr
    2018-07-19
    我认为读写分离适用单机并发无法支撑并且读的请求更多的情形。在单机数据库情况下,表上加索引一般对查询有优化作用却影响写入速度,读写分离后可以单独对读库进行优化,写库上减少索引,对读写的能力都有提升,且读的提升更多一些。
    不适用的情况:1如果并发写入特别高,单机写入无法支撑,就不适合这种模式。
    2 通过缓存技术或者程序优化能够满足要求

    作者回复: 赞同👍

    
     44
  • 性能
    2018-06-03
    我们做网银系统,用redis存了一些不太重要的数据,比如数据字典信息,作为缓存。但是不太敢把用户权限,交易数据等重要信息存在缓存里,因为redis并不保证事务,我们担心一旦缓存服务器宕机或者失败会影响银行业务。所以缓存的作用也不是很大,还是把大部分读数据的压力放到了数据库上,您说我们这种担心有必要吗?如果单库后续扛不住压力,是否读写分离比加缓存更好一些?

    作者回复: 交易型业务缓存应用不多,缓存一般总在查询类业务上,你们的担心有一定必要

    
     18
  • narry
    2018-05-29
    个人感觉,读写分离适合读压力比写压力大很多的业务类型,最终的瓶颈应该是出现在承担写操作的主机上,最大规模和这台主机的iops等能力相关
    
     16
  • LONGER
    2018-06-05
    目前还在用单机一直在扛着,目前数据量在百万万,在不停的优化,建立冗余等方式,还在保持着一个较快的查询速度,因为业务查询的关系,多表之间的关联,聚合,很难避免,一直想引用缓存,但是查询的条件太多,很动态,就不知道如何设计缓存,类似于京东筛选物品,多品类,多维度筛选,不知道大牛有何高见

    作者回复: 按照2-8原则,选出占访问量80%的前20%的请求条件缓存,因为大部分人的查询不会每次都非常多条件,以手机为例,查询苹果加华为的可能占很大一部分

    
     11
  • 侯海佳
    2018-05-29
    我认为读写分离适合类似微博这种业务:读多写少
    
     11
  • rubin
    2018-05-30
    读写分离的前提是并发量大,单机已经不能处理该数量的并发请求了,想要解决问题就得做作拆分,于是有了读写分离,主库负责写,从库负责读,降低了同台机器并发请求,当读越来越多时,可扩充从库,写越来越多时,只好拆分业务或分库分表,如:注册功能,单独出来做一个注册的微服务,但还是会到达一个瓶颈,没做过,不知道能支持多少的并发?

    作者回复: 要具体测试,不同业务复杂度不同

    
     9
  • 合民
    2018-05-31
    读写分离,主从架构,顾名思义,写不变,主要解决高性能读的问题,所以适用场景自然是读多写少的情况。比如类似于博客、中小型朋友圈,这种一般写数据库后基本不变,但是很多人会去访问,频繁的读。我认为如果缓存能支撑的话就没必要上读写分离,相对来说缓存更简单。
    
     8
  • 彡工鸟
    2018-05-30
    是否还应该加上一个,当单机写顶不住压力后,就可以做数据库拆分了,例如业务纵向拆分,连同数据库一起,就变成分布式服务,微服务了:)

    作者回复: 说法没错,但具体实施的时候要注意,不要一有压力就上读者分离,因为很多时候其实是sql语句或者业务逻辑有问题,因此先优化,只有优化后也无法满足要求的时候才考虑读者分离或者集群

    
     7
  • 刘岚乔月
    2018-05-29
    请问 对于主从出现的数据同步延时问题 在实际生产落地 真的只有把重要的查询指向主吗 还有其他真正的落地方案吗

    作者回复: 当然是真的呀,难道我还会骗你不成?😂
    如果不想用这种方式,用缓存是可以规避这个问题的,但其实这时候的方案就不是读写分离了

    
     7
  • 云学
    2018-05-29
    相比于前面的几篇高大上文章,这篇更接地气
    
     7
  • lee
    2019-01-23
    SQL优化——缓存——读写分离——分库分表
    
     6
  • 小喵喵
    2018-06-03
    公司现在的系统时采用读写分离的,是中间层程序封装的api,第一套分两类:1读主库,2.读从库.然后客户端程序通过传递SQL或存储过程和参数的值调用。
    第二套只提供一个api,通过传递一个布尔值来判断是走主库还是从库,这套是供自动调度工具来调用。这两套api都有一个共同点,就程序猿必须手动指定是走主库还是从库。现在出现的问题是大量的SQL应该走从库,结果很多菜鸟都走了主库,导致现在的主库压力很大。听了你的课程后觉得走主库还是从库不应该由程序猿自己指定,而是由中间层来判断。具体如何做呢,请老师指点一下。客户端有时传递一些复杂的SQL,比如,先做更新然后再查。

    作者回复: 默认读走从库,写走主库,特殊情况才由程序员制定,可以代码指定,可以配置指定,这样就不会出现大量sql都走主库了

    
     6
  • @漆~心endless
    2018-05-31
    并非所有系统都需要进行读写分离,正如之前讲得架构三原则,其中根据“合适原则”的规定,先确认系统的业务量是否出现了数据库的性能问题。如果是,首先通过优化MySQL语句等,如果还是达不到要求的性能指标,则需进行读写分离。毕竟读写分离会引入一系列不可预知的问题,如数据不同步。
    
     6
  • null
    2018-05-29
    re: 写操作后的读操作指定发给数据库主服务器

    后端无法知道本次请求是否为写操作之后的读,因此会依赖前端传递一个参数,如 target_db=master / slave,来决定目标数据库。
    所以这种方式,需要在前后端代码实现相关逻辑,代码耦合较大。

    这种解决方案是否只提供了一种思路,实际开发时很少使用这方案,不知道理解是否正确,谢谢!
    展开

    作者回复: 是的,对代码逻辑有要求,

    
     6
  • allen.huang
    2018-08-14
    老师您好,
    像我们数据库服务器只有一台,并且现在业务量也越来越大,尤其是中午,晚上加起来大概是5,6个小时是业务高峰,订餐的量还挺大。前台读写操作都很频繁,
    后来就是要看数据统计啊之类的,客户也是经常在使用。在业务高峰期,他们还要进去看实时交易情况。这样子经常会出现磁盘IO报警。
    我也在尝试规划做读写分离,但是像业务前台做了以后,就会出现数据延时的情况,这样子业务处理就有问题。
    我现在初步规划是前台都用主,后台读写分离,这样子是否合理,有经验的同学也给予我指导谢谢😜

    作者回复: 面向用户的业务读写都用主,面向客户和运营的业务可以读写分离,大部分场景没必要看实时交易情况的

    
     4
  • 老邪
    2018-07-19
    你好,华仔,请问文章内的架构图用的什么软件,谢谢!

    作者回复: Libre office的Draw

    
     4
  • 刘志刚
    2018-05-29
    读写分离比较适用于类似消息记录,对于写和读业务的强实时性要求不到苛刻的地步的情况,而且做的时候这种跟业务量还是有比较大关系的,比如,业务量的订单量每年都不超过1千万,整天去做分库分表倒不如好好优化下sql写法,如果订单量每天都超过好几百万,那这个必要性就很强了!

    作者回复: 赞,先优化

    
     4
  • 马广乐
    2018-05-29
    加个缓存能解决写完立即读的场景吗,老师。

    作者回复: 可以的,但那是另外一个方案了,很多场景就算用了缓存也要读写分离

    
     4
  • 姜泮昌
    2018-05-29
    读写分离适用于单服务器无法满足所有请求的场景,从请求类型的角度对服务器进行拆分,但这样在要求硬件资源能够支撑的同时,对代码实现也有更高的要求。

    作者回复: 天下没有免费的午餐😃

    
     4
我们在线,来聊聊吧