V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
aiqier
V2EX  ›  Java

更新服务器缓存如何合并相同请求?

  •  
  •   aiqier · 2016-10-08 20:47:14 +08:00 · 2842 次点击
    这是一个创建于 3019 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我们有一个布置了多台的服务,服务从 redis 集群中获取数据,一个 key 对应一个 value ,如果没有,则会从三方接口获取并进行计算后先返回给调用方再写入缓存。三方接口的响应时间大概 2s

    现在有一个问题是,三方接口是收费的,如果此时多个请求同时到达而且计算出来的 key 都相同,会都发现缓存没有,而都会去调用第三方接口。这很浪费资源,因为只需要调用三方接口一次就够了。在服务本身对请求做合并的方式效果并不好,因为服务布了多台。

    如何能 hold 住这些其实在请求一个资源的多个请求链接,只出发一次更新缓存的逻辑,然后在数据返回后,统一还给它们。

    11 条回复    2016-10-09 14:02:27 +08:00
    julyclyde
        1
    julyclyde  
       2016-10-08 20:51:20 +08:00
    自旋锁
    master
        2
    master  
       2016-10-08 20:53:47 +08:00
    key 没有值 但是已经有服务器去要值的时候 可以标记个占坑
    其他服务器看到坑占了 可以等待一定时间再去取 如果坑被占了超过一定时间 还是没有值
    那就当前的机器重新把坑占了(更新占坑的信息) 然后去取值喽
    fwrq41251
        3
    fwrq41251  
       2016-10-08 21:15:03 +08:00
    一个想法。当服务用 key 去取发现没有的时候,先随便往里面写一个值,然后再调第三方接口,等调用完毕再把真实的内容替换之前随便写的值。
    reus
        4
    reus  
       2016-10-08 21:31:40 +08:00
    上锁,刚好有 redis ,可以做分布式锁
    6IbA2bj5ip3tK49j
        5
    6IbA2bj5ip3tK49j  
       2016-10-09 09:08:42 +08:00
    用 futureTask 占坑
    sun1991
        6
    sun1991  
       2016-10-09 10:28:27 +08:00
    不能由 cache 服务去申请付费 API 吗?
    julyclyde
        7
    julyclyde  
       2016-10-09 11:10:52 +08:00
    @sun1991 那无非是把合并动作推到 cache 层去了而已,还是得做的
    aiqier
        8
    aiqier  
    OP
       2016-10-09 11:29:05 +08:00
    @master
    @fwrq41251
    @xgfan
    @reus
    @julyclyde
    合并请求是这个需求的一部分吧,关键是要能够在有数据后唤醒那些 hold 住的链接。
    6IbA2bj5ip3tK49j
        9
    6IbA2bj5ip3tK49j  
       2016-10-09 11:31:39 +08:00
    @aiqier get()阻塞住了,也可以加一个超时。
    chenqh
        10
    chenqh  
       2016-10-09 11:32:27 +08:00
    不懂
    不是
    if not in cache:

    with lock:
    if not in cache:
    get from api
    这种逻辑吗?
    lrh3321
        11
    lrh3321  
       2016-10-09 14:02:27 +08:00
    https://www.v2ex.com/t/308349
    之前看过这么个帖子,和你的需求貌似很相近。

    利用 redis 的 setnx 设置标记,成功设置了标记的线程去调用第三方接口。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1300 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 17:43 · PVG 01:43 · LAX 09:43 · JFK 12:43
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.