亿万级别商品详情页面设计

蔚落 2023-05-22 22:11 35阅读 0赞

商品详情页面架构图

图片来自每特教育

商品详情页面设计存在的问题

  1. mysql与es如何保持数据同步的问题
    解决方案:

    1、每次发布商品的时候,调用ES接口实现数据的同步
    2、使用canal解决

  2. 在商品详情页面中除了价格和库存经常发生变化以外,其他数据很少发生变化,所以需要将商品详情页面设计成静态化形式;页面静态化(java语言中的静态化技术:ftl(FreeMarker)等)的好处:

    1、访问速度非常快,不需要查询数据库获取数据,从而减轻我们数据库的压力
    2、对SEO搜索非常友好

  3. 采用nginx或者CDN直接缓存我们的商品详情页面:

    nginx缓存我们的商品详情页面的原理:
    直接将商品详情页面源代码缓存到nginx目录中,缓存key是商品详情的url路径地址。
    nginx缓存和mysql数据如何保持一致性:
    1、直接清除nginx目录中的缓存(不太现实)
    2、在url后面加上最新更新商品的时间(例如:https://editor.csdn.net/md?articleId=105598663&t=20200418)

商品详情页面中频繁发生变化的是价格和库存,在一个商品详情页面中价格和库存不能放入缓存中,需实时读取,其他可以直接作为静态页面存放。每次在发布商品的时候,使用FreeMarker技术重新生成静态详情页面,然后放入到nginx的目录中。也可以将静态html页面放入到第三方CDN中,遵循就近原则访问,可以减少带宽距离的传输,从而提高整个页面的访问效率。

基于openResty+lua实现亿级别商品详情页

openResty+nginx+lua 设计的原理

1、后台每次在更新商品详情页面的时候,会直接生成对应的商品详情页面的模板页面并放入到nginx中,同时采用lua脚本读取mysql/es/接口拿到数据源,再渲染给客户端。
2、可以灵活扩展的操作nginx、减轻后台访问压力

发表评论

表情:
评论列表 (有 0 条评论,35人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Elasticsearch亿级别查询

    这个问题说白了,就是看你有没有实际用过 ES,因为啥?其实 ES 性能并没有你想象中那么好的。 很多时候数据量大了,特别是有几亿条数据的时候,可能你会懵逼的发现,跑个搜索怎么