58到家入驻微信钱包的技术优化

1、需求缘起css

大伙打开微信钱包,会发现58到家入驻了微信钱包的一级入口(以下图),这个入口流量极大,微信要求被接入的H5必须能抗住n万的qps(58到家的系统是偏交易的系统,虽然一天100w订单其实也没多少请求),这是以前的业务系统没有遇到过的,要抗住这个n万的qps的优化思路是怎么样的呢?html


这里作一个思路分享,但愿能对业界同仁有启示做用。mysql

 

2、业务分析nginx

在微信钱包里,点击进入58到家,会发现实际上是一个类别落地页,根据不一样城市开通的服务类别,展现不一样类别的入口(以下图)。web


很容易想到,整个架构与流程是这样滴:sql


架构分层:数据库

(1)微信钱包端,嵌有到家H5页面apache

(2)web-server层,生成H5页面缓存

(3)service层,提供“城市开通了哪些核心服务”的接口tomcat

(4)数据库层,存储了“城市开通了哪些核心服务”的数据

核心流程:

步骤一:微信端经过native的GPS定位或者微信的js-sdk获取用户当前所在城市,并往web-server发送http请求

步骤二:web-server收到http请求,调用service层,获取当前城市开通了哪些核心服务的数据,以瓶装返回html

步骤三:service收到RPC请求,调用mysql,获取真正的数据

步骤四:mysql返回service,service返回web-server,web-server拼装html,返回微信钱包

 

潜在的问题

每秒钟n万的qps数据库扛不住

 

3、优化分析

看到这里,不少读者就笑了,这个场景加个缓存不就搞定了么,好吧,是能够,但本文的重点并非加一个缓存,还有其余的梗等着你。

 

场景分析:这个“城市开通了哪些核心服务”是一个几乎只读的场景,由于城市要开通新的服务是很低频的,因此一大早就想到了cache的优化(cache要注意高可用),优化后的架构分层以下:


cache存储城市开通的核心服务列表,key value创建的是一个city-id到list<service-id>的映射关系。

几乎100%的请求会命中缓存。

 

潜在的问题:服务与缓存之间的带宽会不会成为瓶颈呢?

由于几乎是只读的请求,很容易想到将分布式缓存优化为服务内存缓存,优化后的架构分层以下:


每个服务内部都有一个map,存储city-id到list<service-id>的映射关系,而不用经过cache来读取数据。

 

还能不能进一步优化,例如进一步下降网络交互呢?

是能够的,服务层能够作数据的缓存map<cityid, list<sid>>,web-server层能够进一步作页面缓存优化,架构图以下:


每个站点层,直接作页面缓存,上游传入一个city-id,就直接将提早拼装好的页面返回,获得很高的性能。

 

有甚者,经过nginx/varnish/squid针对性的作一些“页面静态化的优化”,直接每一个city有一个对应的html,能极大的提升吞吐量:


 

4、页面静态化的适用场景

在作站点架构的过程当中,“动静分离”是一项很常见的优化手段:

(1)对于不变的首页、js、jpg、css,能够用专门的file-server来针对性优化(cdn/nginx/varnish/squid)提供高速访问

(2)对于动态的页面,有专门的tomcat/apache/iis/lighttpd集群来提供动态站点生成

通常来讲动态站点时延会大大高于静态站点,应为每次生成动态站点须要访问服务(屡次网络传输)、访问数据库(可能有很慢的磁盘io),而且还有大量的计算逻辑,而静态文件则能够直接返回。

 

“页面静态化”是一种将本来须要动态生成的站点提早生成静态站点的优化技术,什么样的业务场景能够进行“页面静态化”优化呢?

解答:总数据量不大,生成静态页面数量很少的业务,很是适合于“页面静态化”优化

 

<广告>

若是你读到了这里,说明对微信平台仍是有点兴趣的,58到家微信平台团队目前只有一个女生负责(技术圈混,毫不骗人),奇缺人,欢迎有志之士加入

一些说明:base北京,核心团队,技术导向,Java方向,和58沈剑一个团队

加入方式:(1)直接在文章下面留言(2)在公众号回复“招聘”获取加盟密钥

</广告完毕>

 

例如:到家开通的城市只有几百个,那只需提早生成几百个城市的“静态化页面”便可

又例如:一些二手车业务,整个公司可能只有几万量二手车库存,也能够提早生成这几万量二手车的静态页面

再例如:像58同城这样的信息模式业务,又几十亿的帖子量,就不太适合于静态化

 

5、总结

“页面静态化”是一种将本来须要动态生成的站点提早生成静态站点的优化技术,总数据量不大,生成静态页面数量很少的业务,很是适合于“页面静态化”优化

 

以上内容均来自微信公众号“架构师之路”胡剑老师的文章,欢迎关注。

相关文章
相关标签/搜索