当前位置: 首页 > news >正文

卖家如何做阿里巴巴国际网站高端响应式网站设计

卖家如何做阿里巴巴国际网站,高端响应式网站设计,网站概念设计,手机麻将app制作开发转载自 数据库的这些性能优化#xff0c;你做了吗 在互联网项目中#xff0c;当业务规模越来越大#xff0c;数据也越来越多#xff0c;随之而来的就是数据库压力会越来越大。 我们可能会采取各种方式去优化#xff0c;比如之前文章提到的缓存方案#xff0c;SQL优化…转载自   数据库的这些性能优化你做了吗 在互联网项目中当业务规模越来越大数据也越来越多随之而来的就是数据库压力会越来越大。 我们可能会采取各种方式去优化比如之前文章提到的缓存方案SQL优化等等除了这些方式以外这里再分享几个针对数据库优化的常规手段「数据读写分离」与「数据库Sharding」。这两点基本上是大中型互联网项目中应用的非常普遍的方案了。 下面我们来详细看一看 一、从读写分离到CQRS 图片来源阿里云 由于互联网业务场景大多数是读多写少因此进行数据库的读写分离是一件非常简单且有效率的方案。 读写分离简单点来说就是把对数据的读操作和写操作进行分开来让这两种操作去访问不同的数据库这样的话就可以减轻数据库的压力了。 例如上图中数据库会有一个「主实例」这个主要用来提供写操作的偶尔也会承担一点读操作除了「主实例」以外还会有多个「从实例」在图中显示的是 只读实例「从实例」的功能只是用来承担读操作的。 那上面就出现了多个数据库了在多个数据库之间的数据是怎么保证一致性的呢 其实我们常用的数据库就自带这类同步功能比如 Mysql它自己有一个master-slave功能可以实现主库与从库数据的自动同步是基于二进制日志复制来实现的。在主库进行的写操作会形成二进制日志然后Mysql会把这个日志异步的同步到从库上从库再自动执行一遍这个二进制日志那么数据就跟主库一致了。 除了Mysql以外像Oracle等商业数据库都有类似的功能甚至是网络上还有很多开源的第三方数据同步工具也有很多成熟好用的。 好了「主实例」与「从实例」之间的数据同步问题解决了那现在还有一个问题就是项目中是怎样让 写请求 去访问「主实例」让 读请求 去访问「从实例」的这个路由规则是怎么实现的呢 常规的有2种方式 使用编码方式 这个方式主要是靠开发同学在编码的时候根据读写不同的操作需求去调用不同的数据源。例如在数据操作层DAO层将读数据与写数据分开为两个方法函数然后为这两个方法分别指定不同的数据库即可。 但是这种方式有点硬编码的味道了而且对开发同学而言还得额外关注这个事情多了一个编码成本且容易不小心忽略掉。 使用中间件 这种方式就是在后端数据库的前面前置一个 数据库代理服务如下图的MySQL-Proxy 是Mysql提供的一个中间件用于实现读写分离请求但这个组件实际用的人不多我们可以选择其它的一些开源的组件替代例如MyCat、ProxySQL 等等但大致的原理比较类似通过这个图很容易理解这个模式。 好了基础的读写分离就讲完了但感觉这个方式虽然实用是实用就是不怎么有逼格。 OK想要有逼格是吧满足你那我们就来聊一聊另一个有逼格的读写分离概念: 「 CQRS 」 CQRSCommand Query Responsibility Segregation命令增删改和查询的责任分离 我们还是先看图通过上图可以简单的理解一下CQRS CQRS 重点强调的就是 Query读 和 Command写的分离在业务上将职责分离清晰Command 主要做业务逻辑的执行Query来负责数据查询和展示。同时 这两种操作是基于不同的数据源甚至是一个是数据库另外一个是NoSQL都可以Query去查询的数据源可以直接按照领域模型进行存储而并不是按照数据模型去存储这样查询出来就立即可以展示而不用转换且查询效率高。 其实CQRS是由鼎鼎大名的 Martin Fowler 提出搞计算机的应该都认识。想要更深入的去学习CQRS可以翻看Martin Fowler公开的资料。 二、Sharding分库分表 上面讲完了数据库的读写分离现在我们来聊一下数据库的Sharding。 随着数据库里的数据越来越大单表查询的性能已经不能满足业务要求了这个时候就需要进行分表处理了将大表拆分为若干个小表不同的分表中数据也不一样这样可以分散查询压力提高处理效率。 然而当表越来越多所有的数据都在一个数据库上时网络IO以及文件IO也都会集中在一个数据库上可能会超过单台服务器的容量 CPU、内存、文件IO、网络IO 都会成为系统的瓶颈QPS/TPS也会超过单数据库实例的处理极限。那么这个时候就需要对数据库进行分片处理。 因为分表和分库的思路类似因此下面统一来聊技术方案。 其实分库分表只是我们通俗的便于理解的说话正确的描述应该是数据分片 数据的分片主要有2种模式 垂直拆分 水平拆分 两种拆分应用的场景是不同的 垂直拆分是指按照业务模块进行拆分。简单来讲就是把业务紧密的模块的字段/表放在一起放在同一个数据库或者服务器上。将不同业务的字段/表进行独立拆到不同的数据库或者服务器上。比如一个游戏系统中可以将玩家基本信息与道具公会等信息进行拆分。 如图示例 图片来源网络 水平拆分是指纯粹的按照某种数据规则/格式进行拆分。例如 按照数据唯一ID的哈希散列拆分、按照数据的日期拆分、按照某种范围拆分等等。水平拆分需要注意的是随着数据动态的变化分片数量可能需要随之动态调整另外就是水平分片是没有考虑业务特征的因此在进行业务汇总查询或者分片中事物处理的时候就比较麻烦一些。 如图示例 另外在实际应用中两种拆分模式一般会结合在一起使用效果更佳。 以上就是数据库性能优化之「数据读写分离」与「数据库Sharding」方法欢迎大家一起交流。
http://www.pierceye.com/news/97019/

相关文章:

  • 做导航网站赚钱吗建立网站需要多少钱费用
  • 大同网站建设哪家好网站后台登录模板html
  • 网站建设过程中准备的工作手机制作网站
  • 做专业网站设计多少钱代理小企业网站建设
  • 怎样提升网站关键词免费的html模版下载
  • 栖霞网站定制三合一建站网站
  • 免费建立一个个人网站设计官网登录入口
  • 门户网站模板之家北京网上服务平台
  • 合肥网站优化方案东莞做网站那家好
  • 个人备案网站可以做论坛吗山东住房建设厅官网站首页
  • 寺院网站模板网站策划制作公司 北京
  • 昆山教育云平台网站建设宁晋县建设局网站
  • 廊坊网站公司dw做网站背景音乐
  • 阜南做网站搜索引擎优化seo多少钱
  • 贵州建设厅网站怎样查询电工证天津网站备案
  • 常州做网站的公司在盐城做网站的网络公司电话
  • seo站外推广如何用wampp 做网站
  • 怎样用手机做网站中企动力百度百科
  • 哪些网站可以做任务挣钱免费app软件
  • 国内简约网站平潭县机场建设网站
  • wordpress 全站通知wordpress怎样打开速度快
  • 广州市建设职业培训学校网站移除wordpress版本
  • 如何申请一个网站 新网动画制作大师
  • 动易后台 网站统计调查 报表类型怎样使用手机相册备份网站源码
  • 做网站放到百度上需要什么查看wordpress使用什么主题
  • 深圳企业网站seo郑州汉狮专业做网站公司
  • 广东网站建设多少钱辛集专业网站建设
  • 怎样做网站公司的销售小程序推广计划怎么赚钱
  • 网站开发文档编写wordpress小说站群
  • 南宁网站开发推广网站html模板下载