加入收藏 | 设为首页 | 会员中心 | 我要投稿 焦作站长网 (https://www.0391zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 安全 > 正文

京东活动系统亿级流量应对之术

发布时间:2021-01-08 07:08:08 所属栏目:安全 来源:网络整理
导读:《京东活动系统亿级流量应对之术》要点: 本文介绍了京东活动系统亿级流量应对之术,希望对您有用。如果有疑问,可以联系我们。 作者:干天星 ,2012年初加入京东,先后在京东审计、搭配购、jshop活动系统等项目从事系统研发和架构工作.目前主要负责jshop活动

为了解决这个问题,view工程每隔指定时间,向engine发起重新渲染请求-最新内容放入redis.下一次请求到来时即可获取到新内容.由于活动很多,也不能确定哪些活动在被访问,所以不建议使用timer.通过加一个缓存key来实现,处理逻辑如下.

好处就是,只对有访问的活动定时重新发起渲染.

新架构讲解

*整理架构(不包含业务)

view工程职责:

直接从缓存或者硬盘中获取静态HTML返回,如果没有返回错误页面(文件系统的存取性能比较低,超过100ms级别,这里没有使用);

根据缓存key2是否过期,判断是否向engine重新发起渲染(如果你的项目外面接口都支持mq,这个功能就不需要了).

engine工程职责:

渲染活动页面,把结果放到硬盘、redis.

publish工程、mq职责:

页面发生变化,向engine重新发起渲染,具体的页面逻辑,这里不做讲解.

Engine工程的工作就是当页面内容发生变化时,重新渲染页面,并将整页内容放到redis,或者推送到硬盘.

* view工程架构(redis版)

View工程的工作,就是根据链接从redis中获取页面内容返回.

* view工程架构 (硬盘版)

两个版本对比

Redis版

优点:接入简单、性能好,尤其是在大量页面情况下,没有性能抖动.单个dockertps达到700;

缺点:严重依赖京东redis服务,如果redis服务出现问题,所有页面都无法访问.

硬盘版

优点:不依赖任何其他外部服务,只要应用服务不挂、网络正常就可以对外稳定服务;在页面数量不大的情况下,性能优越.单个dockertps达到2000;

缺点:在页面数据量大的情况下(系统的所有活动页有xx个G左右),磁盘io消耗增加(这里采用的javaio,如果采用nginx+lua(OpenResty),io消耗应该会控制在10%以内).

解决方案

对所有页面访问和存储采用urlhash方式,所有页面均匀分配到各个应用服务器上;

采用nginx+lua(OpenResty)利用nginx的异步io,代替javaio.

*Openresty+硬盘版

(编辑:焦作站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读