- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 Python GAE SDK。
我有一些处理需要在 6000 多个 MyKind
实例上完成。在单个请求中完成它太慢了,所以我正在使用任务队列。如果我让单个任务只处理一个实体,那么它应该只需要几秒钟。
documentation表示只能在“批处理”中添加 100 个任务。 (这是什么意思?在一个请求中?在一项任务中?)
因此,假设“批处理”表示“请求”,我试图找出为数据存储区中的每个实体创建任务的最佳方法。你怎么看?
如果我可以假设 MyKind
的顺序永远不会改变,那就更容易了。 (处理永远不会真正改变 MyKind
实例 - 它只会创建其他类型的新实例。)我可以做一堆任务,给每个任务一个开始位置的偏移量,间隔小于相隔100。然后,每个任务都可以创建执行实际处理的单独任务。
但是如果实体太多,原始请求无法添加所有必要的调度任务怎么办?这让我觉得我需要一个递归解决方案——每个任务都会查看给定的范围。如果范围内只有一个元素,它会对其进行处理。否则,它将范围进一步分割为后续任务。
如果我不能指望使用偏移量和限制来识别实体(因为不能确保它们的顺序是恒定的),也许我可以只使用它们的键?但是我可能会发送 1000 个 key ,这看起来很笨重。
我走的这条路是正确的,还是我应该考虑另一种设计?
最佳答案
当你运行像 taskqueue.add(url='/worker', params={'cursor': cursor})
这样的代码时,你正在排队一个任务;使用您提供的参数安排带外执行请求。您显然可以在一次操作中安排多达 100 个这样的操作。
不过,我认为您不想这样做。任务链将使这变得简单得多:
你的工作任务会做这样的事情:
运行查询以获取一些记录进行处理。如果在任务参数中提供了游标,请使用它。将查询限制为 10 条记录,或者您认为可以在 30 秒内完成的任何记录。
处理您的 10 条记录
如果您的查询返回 10 条记录,请将另一个任务加入队列并将查询中更新的游标传递给它,以便它可以从您离开的地方继续。
如果您得到的记录少于 10 条,您就完成了。万岁!发送电子邮件或其他内容然后退出。
此路由只需要启动第一个任务,其余的自行添加。
请注意,如果任务失败,App Engine 将重试直到成功,因此您无需担心数据存储中断导致任务超时并中断链。
编辑:
上述步骤并不能保证一个实体只会被处理一次。任务通常应该只运行一次,但 Google 确实建议您进行幂等性设计。如果这是一个主要问题,这里有一种处理方法:
在每个要处理的实体上放置一个状态标志,或创建一个互补实体来保存该标志。它应该具有类似于待处理、处理中和已处理的状态。
当您获取要处理的新实体时,事务性地锁定并递增处理标志。仅运行处于待处理状态的实体。处理完成后,再次增加标志。
请注意,在开始之前,并非绝对有必要将处理标志添加到每个实体。您的“待定”状态可能仅表示该属性(property)或相应的实体尚不存在。
关于python - 谷歌应用引擎 : How to use the task queue for this processing?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3225470/
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 5年前关闭。 Improve t
我是一名设计老师,试图帮助学生应对编程挑战,所以我编码是为了好玩,但我不是专家。 她需要找到 mode (最常见的值)在使用耦合到 Arduino 的传感器的数据构建的数据集中,然后根据结果激活一些功
我正在开发一个应用程序,该应用程序提供 CPU 使用率最高的 5 个应用程序名称。目前,我通过以下代码获得了排名前 5 的应用程序: var _ = require('lodash');
互联网上很少有例子涉及这个问题的所有三个问题——即 set-process-sentinel ; set-process-filter ;和 start-process . 我尝试了几种不同的方法来微
如 this post 中所述,在 C# 中有两种调用另一个进程的方法。 Process.Start("hello"); 和 Process p = new Process(); p.StartInf
我试图让我的桨从白色变为渐变(线性),并使球具有径向渐变。感谢您的帮助!您可以在 void drawPaddle 中找到桨的代码。 这是我的目标: 这是我的代码: //球 int ballX = 50
考虑:流程(a)根据我的文字: A process is first entered at the time of simulation, at which time it is executed u
我真的希望 Processing 有用于处理数组的 push 和 pop 方法,但由于它没有,我不得不试图找出删除数组中特定位置的对象的最佳方法。我相信这对很多人来说都是基本的,但我可以使用一些帮助,
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
以编程方式,我如何确定 Windows 10 中的 3 个类别 应用 后台进程 Windows 服务 就像任务管理器一样? 即我需要一些 C# 代码,我可以确定应用程序列表与后台进程列表。检查 Win
当我导入 node:process它工作正常。但是,当我尝试要求相同时,它会出错。 这工作正常: import process from 'node:process'; 但是当我尝试要求相同时,它会引
我正在上一门使用处理的类(class)。 我在理解 map() 函数时遇到问题。 根据它的文档( http://www.processing.org/reference/map_.html ): Re
我试图执行: composer.phar update 并收到: Fatal error: Allowed memory size of 94371840 bytes exhausted (tried
给定一堆二维图像,如何使用 Processing/Processing.js 产生体积渲染效果? 目前我的想法是使用 java(类似于 imageJ)进行体积渲染 -> 获取体积渲染图像的面作为单独的
这是代码示例 var startInfo = new ProcessStartInfo { Arguments = commandStr, FileName = @"C:\Window
当我在 Processing(草图 > 导入库 > 添加库)中添加库时,它安装在哪里? 最佳答案 它们安装在您的 中速写本位置 . 您可以通过转到"file">“首选项”来查看和更改您的速写本位置。草
无聊的好奇... 我正在查看当前进程的一些属性: using(Process p = Process.GetCurrentProcess()) { // Inspect properties
我正在尝试在同一页面上运行多个草图。 初始化脚本指定: /* * This code searches for all the * in your page and loads each scrip
Process.Kill 后是否需要使用 Process.WaitForExit? 如果调用进程在调用 Process.Kill 后立即退出怎么办? 这会导致 Process.Kill 失败吗? 编辑
我尝试使用处理从麦克风获取频率。我混合了文档中的两个示例,但“最高”并不是真正的赫兹(a 是 440 赫兹)。 你知道如何拥有比这更好的东西吗? import ddf.minim.*; import
我是一名优秀的程序员,十分优秀!