- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
从文档中:
This may also result in multple invocations for a single event, so for the highest quality functions ensure that the functions are written to be idempotent.
/counters/{type}/count
。
最佳答案
这个问题的答案将取决于您如何使用集合的不同方面,以及“完全计数”对您而言意味着什么。
前言
首先,由于Cloud Function调用与写入异步,因此将导致计数器稍微落后于集合的真实计数。我认为这还可以。
即使您通过阅读每个文档来对集合进行计数,但由于计数时可能已插入或删除了文档,因此计数仍然过时。
费用表
您提到“不要太贵”。在这里,我们需要了解读取计数的频率与添加或删除文档的频率。为了维护一个单独的计数器,您将在每次文档计数更改时对其进行读取/写入。由于写入的价格是读取价格的3倍,因此这意味着您需要对每个文档进行4次或更多次计数才能收回保持计数的成本。这里某处存在一个公式,该公式考虑了文档生命周期内的平均计数,但是我将其留给读者练习。
幂等计数器
这是一个有趣的问题,这是分布式系统中另一个熟悉的问题。如果客户端请求添加+1计数器,并且请求超时(服务器永不响应),再次请求是否安全?如果服务器确实应用了增量但又遇到网络问题怎么办?如果没有呢?
下面,我将回答一些解决这种情况的方法。
幂等计数器-交易ID
一种解决方法是发送带有增量请求的唯一事务ID(txid)。如果服务器之前已经处理过txid,则它知道它是重复请求,并且可以响应它已经完成了该请求。
在您的用例中,如果您从不删除文档,则可以将文档ID用作txid。 +1时,在计数器中,将文档ID添加到经过处理的增量数组中。在执行此操作之前,请检查它在数组中是否不存在(表明它已被处理)。
上面的一个明显问题是阵列将继续增长,最终变得太大。因此,我们将希望限制跟踪旧ID的时间。您可以使用时间戳记并删除所有早于'X'的内容,也可以将数组视为循环缓冲区以将其固定为最大大小。
这两种方法对于较低的写入速度都是合理的,但对于更快的写入速度是不够的。例如,以每秒1000次写入的速度,这将是5000个文档ID,仅覆盖5秒钟(我们在我们的限制文档中提到,函数可能需要5秒钟以上的时间才能执行)。
输入健忘的布隆过滤器
幂等计数器-健忘的布隆过滤器
此方法为您提供了更高的写入速率支持,以换取您以为您以前看过文档ID的可能性很小。
我不会在此处详细介绍其实现,但是此博客对此有一个很好的概述:Counters, Idempotence And Forgetful Bloom Filters
幂等计数器-删除
另一个复杂性是处理删除。如果您使用唯一的ID,并且确定不会重复使用(例如,我们的 native Auto ID支持),则添加起来并不难。只需在单独的列表/字段中重复添加操作即可,并确保同时检查两个列表。
要考虑的一件小事是Cloud Functions不能保证执行顺序。这意味着如果插入发生得足够近,您可能会在插入之前看到一个删除。
我的建议是,如果您在插入之前看到一个删除,请提前递减计数器,因为它知道很快就会被处理,并且如果您在删除之后看到一个插入,请执行递增操作。这是因为您只保留了这么多的历史记录,所以您无法分辨出插入和删除是否乱序,或者删除是否在插入之后太远。
其他方法
根据集合的大小,需要的准确性以及使用计数的频率,您可以定期调用Cloud Function来计算计数并将其存储在文档中。您可以根据集合的大小动态缩放此比例,以最大程度地减少延迟。对于非常小的收藏集,经常这样做,对于较大的收藏集,则很少这样做。
如果您具有确定已经计算过的文档的机制,那么您也可以在此处应用成本优化(因此您只需要计算新的)。如果很少删除,则可以添加一个事件以减少删除计数器。
关于database - Firebase Firestore的幂等计数器实现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46791335/
我正在尝试为我的 Firestore 设置一个数据库,但是我尝试重新安装 pod 和许多其他东西,但我仍然无法让它工作,因为它显示了这个错误: Type 'Firestore' has no memb
我需要更改我的项目 ID,因为要验证的 Firebase 身份验证链接在链接上显示了项目 ID,并且由于品牌 reshape ,项目名称已更改。根据我发现的信息,更改项目 ID 似乎不太可能。我正在考
快速提问。长话短说,我在我的谷歌云功能日志中收到此错误: Firestore (4.10.1):无法到达 Firestore 后端。 这是我的函数文件中的代码: // pull in firebas
我正在从事 Angular 6 项目。这是我使用 --prod 构建时遇到的错误标记、主持和运行。我已经坐了很长时间了。最初认为这可能是 firestore 包的问题,我等了。但是现在更新到fir
我正在开发一个 React 项目,这是我的第一个 React 项目。此代码部署成功。但在使用 postman 测试时出现一些错误。我“发布”“createScream”函数的 URL 并发送它。然后我
我有一个包含两个集合的 Firestore 数据库:用户和锦标赛。用户具有“参与者”角色和“管理员”角色,并在用户文档中由“isParticipant”和“isAdmin” bool 值指示: /us
Firebase 数据库根据他们的文档提供了 10 MB 的离线数据库缓存限制,但没有提到 的离线数据限制。 Firestore 数据库。 Firestore 的离线数据保存限制是多少? 最佳答案 根
我正在尝试评估 string在 Firestore 安全规则 基于 matches正则表达式功能 我的代码是 username.matches('^(?!\.)(?!_)(?!.*\.$)(?!.*?
是否可以在 Firestore 中定义具有唯一约束的索引?如果没有,如何在文档字段上强制执行唯一性(不使用文档 ID)? 最佳答案 是的,这可以通过结合使用两个集合、Firestore 规则和批量写入
我正在学习 GCP,在他们的 Firestore 中,我对 Admin.firestore 和 Firebase.firestore 的区别感到困惑。 这是管理员的代码: const admin =
使用带有自定义声明的 firestore 在线安全模拟会导致错误,但它在部署时可以完美运行(同时实际处理真实请求)。错误是: Error: simulator.rules line [5], colu
所以,我知道有一些类似命名的问题,但这是不一样的。 我很想知道是否有人可以解释缺少 increment 的原因。哨兵,类似于delete一。 据我所知,字段删除与文档更新没有什么不同。意思是,我只能
我想创建两个带有分页选项的查询。在第一个记录中,我想获取前十条记录,在第二个记录中,我想获取其他所有记录: .startAt(0) .limit(10) .startAt(9) .limit(null
我正在努力为我的应用寻找最佳架构。我应该使用顶级集合、子集合、数组等吗? 设置: 我的应用程序将有许多用户将参与的测验。 每个测验都会有多个问题。 每个问题都有多个答案,只能选择一个。 每个用户只能回
我正在努力为我的应用寻找最佳架构。我应该使用顶级集合、子集合、数组等吗? 设置: 我的应用程序将有许多用户将参与的测验。 每个测验都会有多个问题。 每个问题都有多个答案,只能选择一个。 每个用户只能回
我无法在任何地方找到我可以在一个Collection中获得的文档数量的限制。假设我有1,000,000,000个文档...那有可能吗?如果我想把它们全部都拿走,实际上会给我十亿吗? 最佳答案 可以存储
假设我有一个集合 mycollection有 1,000,000 条记录。 此查询将返回多少条记录? const query = firestore.collection('mycollection'
这是错误消息:@firebase/firestore: Firestore (4.12.1): Could not reach Firestore backend 我正在构建一个网络应用程序,它今天运
我在编写和测试我的 Firestore 规则时遇到了一个奇怪的问题。这是我想要实现的目标: 当应用程序启动时,用户会匿名登录。这用户开始新游戏。 我创建了一个基本上只包含时间戳的“ session ”
我是云函数的新手。我有一些困惑。 admin.firestore 和functions.firestore? admin.database 是实时数据库吗? 因此,如果云函数基本上是用 JavaScr
我是一名优秀的程序员,十分优秀!