




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、系统架构优化最正确实践看京东系统架构师如何让笨重的架构变得灵巧目录1、 工程背景32、 系统拆分31、水平扩展32、垂直拆分43、业务拆分44、水平拆分63、 结构演变64、 结语11一、工程背景随着业务的复杂性增大、系统吞吐量增长,所有功能统一部署难度加大,各个功能模块相互影响,使系统变的笨重且脆弱;因此需要对业务进行拆分、对系统进行解耦、对系统内部架构升级,来提升系统容量及健壮性.接下来主要分两局部介绍:系统拆分与结构演变;系统拆分系统拆分从资源角度分为:应用拆分和数据库拆分;从采用的先后顺序可分为:水平扩展、垂直拆分、业务拆分、水平拆分;应用系统数据库潦写分事迎.商品淳庵,膏品写客圈业假
2、设分霹如.高区鼻,订际分座分套.如,订按10分整分黑冷热感器分毒,历史数露别离图1系统分解原那么1、水平扩展水平扩展是最初始的解决的手段,也是系统遇到瓶颈的首选方案,主要从以下两个方面扩展:o应用加实例,搞集群,把系统吞吐量扩上去.o数据库利用主从进行读写别离,数据库其实是系统最应该保护的资源.2、垂直拆分垂直拆分才是真正开始拆分系统,主要是从业务功能角度拆分.如拆出用户系统、商品系统、交易系统等.为了解决拆分后各个子系统之间相互依赖调用的问题,这时会引入效劳调用治理系统复杂度有所加大,但系统根本解耦,稳定性相对提升,做好降级就能防止因其它系统功能异常导致系统崩溃.业务对应的库也会根据对应的业
3、务进行拆分出用户库、商品库、交易库等.3、业务拆分业务拆分主要是针对应用层面按功能特点拆分,如交易拆分出:购物车、结算页、订单、秒杀等系统.然后根据业务的特点,针对性做处理,如秒杀系统,由于同时参加秒杀的商品有限,可以提前把商品信息加载到JVM缓存中,自身减少外部调用提升性能,同时商品系统也减轻压力.数据库拆分也可以分为几步:垂直分表、垂直分库、水平分表、水平分库分表;垂直分表是指大表拆多张小表,可以根据字段更新或查询频次拆分;表商品表拆分前字段面品编云商品名称品牌英目图片a吉雷重量商冢信息产地包装.表,商品拆分后字段说明商品主表商品扩展表表字殿字段说明表字殿字段说明商品编号唯一标识商品编号常
4、标识商品名称常更新重量查询较少品牌查询多产地查询较少类目查询至一包装查询技少图片常更新F语格更新商豕后息图2商品表拆分垂直分库是指按业务拆库,如拆出订单库、商品库、用户库等水平分表是解决数据量大,把一张表拆成多张表;水平分库分表是更进一步拆分表;图3分库分表4、水平拆分效劳分层,系统效劳积木化,拆分功能与非功能系统,以及业务组合的系统,如最近比拟火的大中台或前台拆分;中台为积木组件,承当效劳功能输出.前台更多的是组合积木效劳,及时响应业务开展,如在电商网站单品页能看见主图、价格、库存、优惠券或推荐等信息,都是组合各积木组件呈现.数据库也可以进行冷热数据别离;过期或过季商品可以归档,比方诺基亚3
5、210 ,早已经停产且没有销售;用户查看订单时,更多的只是查看最近1、2年信息,2年前数据查看量少,在存储设计时可以区别处理.三、结构演变序吧结构演变主要是随着系统复杂度增加及对性能要求提升而不得不做的系统内部架构升级;早期系统根本是应用直联数据库,但在系统进行拆分后,功能本系统不能单独完成,需要依赖其它系统,就出现远程调用;DB随着自身系统的业务开展,对性能要求高,而数据库一定程度上成为瓶颈,就会引入缓存及索引,分别解决key-value及复杂检索;索引加缓存现在已经成为解决高并发的根本方案,但在DB图4早期应用结构实施过程会有所区别;14年对3亿热数据的系统升级时,技术选型为solr+re
6、dis,考虑到数据量过大,数据在solr中只存index,而结果只存并返回主键id,再通过id从redis中读取数据,redis也不存放全部数据,数据设置过期时间,假设未命中redis,回源数据库查询并反写redis;主要考虑资源与性能的平衡,solr的存储减少及IO性能提升,结果数据只在redis存放一份,redis的数据经过运行大局部是热数据;当然现在也流行ES+Hbase组合."DBDB图5增加缓存及索引对于频繁使用的数据,从集中缓存读取,不一定到达性能要求,可以考虑把数据入JVM缓存,如类目信息,类目是电商系统根本数据,数据量不多,调用量大;个别情况下,使用ThreadLoc
7、al做线程内缓存也是种有效手段,但需要考虑数据去除及有效性;在修改商品信息时,业务对商品信息的校验有名称长度、状态、库存及各业务模式等,而为了参数的统一校验方法参数为商品编号,导致各校验方法都需要读取一次商品,使用线程缓存可以解决该问题,性能提升了尽20ms,读取商品每分钟减少近万次;Service索引,统一缓存RPCDHDAODB图6增加本地缓存有时所依赖系统性能不太稳定,防止出现因第三方系统影响系统,把依赖的效劳进行数据闭环,与Dao一样当成系统的数据源;如商品系统强依赖商家系统的商家信息效劳,假设商家效劳不稳定,商品系统一半效劳都不稳定,采取对商家信息缓存一份,降低外部风险,把风险限制在自己手上;图7远程效劳进化成数据源用户体验最近越来越重视,系统响应时间性能要求也越来越高,异步化是很好的一种选择:消息中间件;电商下单就是个很好的案例,在用户点击下单时,效劳端不直接保存数据,给订单系统发送消息,就直接返回支付页面,在用户支付过程中,订单系统异步进行数据保存;业务层、数据层的范围越来越宽泛,业务层可以分为根底效劳与组合效劳;数据层分为数据源与索引缓存;依赖的技术或中间件需要有效的结合,用于解决系统所遇到各种问题.数据层r/用nginxi-IK7Jatcache索引thread统一缓DAORPCNosql图8复杂的结构四、结语系
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 医疗器械买卖合同协议书
- 商品房产购销合同
- 2025年春人教版(2024)小学数学一年级下册教学计划
- 2021电力工程继电保护及接线施工作业指导书
- 医院医疗器械买卖合同
- 2025年南昌年货运从业资格证考试试题题库
- 承包搅拌站运输合同
- 2025年鹰潭货运资格证培训考试题
- 户外广告发布合同
- 2025年遵义货运从业资格考试题
- 2024-2025学年高一下学期开学第一节课(哪吒精神)主题班会课件
- 人教版2025-初中物理实验室实验课程安排
- 2024年无锡科技职业学院高职单招语文历年参考题库含答案解析
- 舞蹈艺术赏析课件
- 2025江苏泰州兴化市陈堡镇村级后备干部招聘10人历年高频重点提升(共500题)附带答案详解
- 重庆市2025届高三第一次学业质量调研抽测化学试题 (含答案)
- 室外广告安全生产培训
- 2025中冶建工集团限公司校园招聘114人高频重点提升(共500题)附带答案详解
- (完整版)python学习课件
- CNAS-RL01:2019实验室认可规则
- 2025中国人民解放军空军部队军工厂招聘21人管理单位笔试遴选500模拟题附带答案详解
评论
0/150
提交评论