首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >bigtable需要锁定吗?

bigtable需要锁定吗?
EN

Stack Overflow用户
提问于 2010-06-21 09:49:32
回答 2查看 811关注 0票数 2

在GAE中,我使用任务队列进行某些数据更新。

我的queue.xml文件如下所示

代码语言:javascript
复制
  <queue> 
    <name>data-processing</name> 
    <rate>20/s</rate> 
  </queue> 

我的队列处理servlet使每个任务的信用减少了1。在处理过程中,它需要检查信贷可用性,只有在信贷可用的情况下才能进一步进行。

信用被存储在一个表中,并在任务完成时得到更新。

我把任务看作线程,并担心同步问题。

如果两个或多个任务同时查询/更新信用表,怎么办?我需要创造一些锁定机制吗?如果是,那怎么做?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-06-21 10:03:29

是的,你确实需要同步。您通常会更新读-修改-写入方案中的学分:首先读取可用的学分,减去一个,然后将其余的学分写回去。如果两个任务同时执行,一个任务可能会覆盖另一个任务的结果,从而导致存储一个不正确的信用计数。(除非存在用于Memcache的原子指令,但对我认为的数据存储没有原子指令)。

您可以使用事务来解决这个问题,请参阅http://code.google.com/appengine/docs/java/datastore/transactions.html

票数 5
EN

Stack Overflow用户

发布于 2010-06-21 11:31:09

App任务队列负责计算执行率本身。除了配置queue.xml之外,您不需要做任何事情,就像您已经做的那样。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3083591

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档