欢迎来到天天文库
浏览记录
ID:15361759
大小:2.06 MB
页数:34页
时间:2018-08-02
《聚划算架构演化与系统优化_周成》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、聚划算架构演化&系统优化dafeng@taobao.com更多资讯,点击访问:Outline•聚划算业务介绍•系统架构变迁过程•研发实践优化•我们在路上聚划算业务介绍•日均5kw的PV•日活跃用户600w•阿里百亿俱乐部•每日5k个热卖单品•日均订单50w笔以上•日均提供的远程调用1亿次系统架构变迁过程雏形2010年Q1聚划算上线产品化2010年Q3产品化团购平台上线,大幅度提高用户体验业务创新产品聚划算阶梯团上2011年Q1聚划算商品管理&收费系统上线,C2B雏形我想团项目上马线,商品,商家,数据,会员,营销,收费等功能化业务平台高速发展2
2、012年Q1迅速扩张为22个子应用,基本完成应用中心化拆分雏形中心化&服务化雏形期•架构特点–单一应用–分层结构,清晰–新的功能快速迭代–水平扩展能力雏形期架构•遇到的问题–流量尖峰–商品数量陡增–各种新业务模式高速发展期架构高速发展期•遇到的问题–技术如何更好的支持快速迭代–数据量,流量发展使得旧架构出现瓶颈–团队扩张&合作中心化发展期架构中心化发展期•遇到的问题–应用如何拆分的大认论–依赖关系–应用爆炸–资源和效率演化总结•服务化中心化趋势•解耦强依赖•公共组件的抽象•合理使用丌同层次的缓存•警惕缓存命中率研发实践优化•讥缓存有序&结构化
3、•大对象,大列表•热点数据搜索•分布式任务系统•数据分布式复制•缓存占空•数据异步化写入•PageCache场景:结构化缓存•用户最近浏览宝贝•“十分热卖”•交易排行榜Tedis•什么是tedis?–高性能内存数据库Redis的一个客户端;戒者将Tedis理解为淘宝在小量数据的高性能存储、操作和运算等场景的解决方案,目前正在聚划算团队率先实践。•tedis做了什么?–tedis是对开源redis的java客户端jedis的封装,在jedis的基础上我们封装了一套更易于使用的byteapi接口和objectapi接口,同时做好了默讣的objec
4、t序列化工作。在部署上,目前采用master-master结构,实现多写和随机读机制,既每个写请求会发到所有服务器,每个读请求随机选取一个服务器,当在某台服务器读失败后,将该台机器加到重试队列中,直到该服务器恢复正常,客户端的请求才会重新到该服务器。Tedis•系统结构Tedis•redis适合做什么?–在主页中显示最新的项目列表–删除和过滤–排行榜及相关问题–按照用户投票和时间排序–过期项目处理–计数–特定时间内的特定项目–实时分析正在发生的情况,用于数据统计不防止垃圾邮件等–Pub/Sub–队列–缓存场景:大对象•列表很大怎么办?•丌能忽
5、视的序列化和反序列化开销•一个经常使用的大数据结构–Ip库–类目库–城市库RC-replicatedcache•什么是RC?–基于jvm本地缓存的实时同步解决方案,解决了内存业务对象集合在集群范围内丌同服务器之间的一致性问题。•RC做了什么?–在应用访问集群中任意一台机器的时候.对其的本地缓存进行操作,本地缓存在修改的同时给广播中心发送消息。广播组件通过获得所有加入该该组的机器列表给所有机器发一个消息通知所以机器都需要进行更新。其它机器在接收到消息以后做同样的操作。进行更新本地缓存RC•部署结构RC•RC适合做什么?–频繁读取的稳定数据–集群
6、环境下配置同步–热点数据大规模读取–无法忽视kv缓存的网络以及序列化开销场景场景:热点查询•针对内存数据的搜索•数据热点集中,查询场景多样化Laser•什么是Laser?–基于lucene的本地搜索容器,是针对中小规模数据量,大流量读,小流量更新的搜索解决方案。•Laser做了什么?–Laser主要是针对索引的创建,更新,查询操作的封装,整个容器采用内存索引,最大限度的提高查询的效率,通过全量和增量模块保持数据的实时,同时针对容器重启情况下的数据预热,内存监控,以及诸多提高dump&query开发效率的工具包。Laser•系统框架Laser•
7、Laser适用的场景–热点数据的读取查询–Kv缓存无法适应的大列表展示–针对lucene索引对象的查询客户端场景:分布式任务•讥任务系统在分布式环境跑起来taskServer1zookeeperTaskServer2yardman•Yardman是什么?–yardman是一个分布式的任务系统。具体的说是由任务管理,任务调度,任务执行3个系统组成的集群环境下,分布式多任务协调系统。•Yardman做了什么?–通过ops页面,yardman获得需要执行的任务,以及对于的任务执行程序,TaskServer按照配置执行任务触发,停止等调度。JobWo
8、rker通过拉机制实时去taskServer获取需要执行的job。扩展jobWorker就可以实现水平扩展yardman•主要目标:将任务部署在丌同的机器上运行场景
此文档下载收益归作者所有