gpt4 book ai didi

amazon-web-services - AWS Lambda 作为社交媒体帖子调度程序?每个预定事件触发器具有唯一数据的单一功能?

转载 作者:行者123 更新时间:2023-12-02 04:01:55 25 4
gpt4 key购买 nike

我想使用 AWS Lambda 作为社交媒体帖子调度程序,但我找不到一种优雅的方法来实现这一点。在我们的应用程序中,用户创建社交媒体帖子并设置时间。然后,我们在指定的时间通过社交网络的 API 发布它们。

我需要能够安排 Lambda 在预定时间运行一次并使用唯一数据(即用户的 token 和帖子正文)才能完成此任务。这是一个例子:

John wants to post to Twitter next Thursday at 2pm. He's scheduled a post with the body "Hello world!" for that time via our web app. The app will talk to AWS Lambda via the API and set a Lambda function to fire one time next Thursday at 2pm. That function would fire a request to the Twitter API with John's token and the body ("Hello world!").

希望能够使用 Lambda 实现无服务器功能,但我找不到好方法。如果您可以将 Cloudwatch 计划事件触发器与唯一的负载配对,这可能会起作用,但我认为这是不可能的。否则,这似乎需要为每个帖子创建一个新的 Lambda 函数,并使用硬编码的数据,或者让 Lambda 访问数据库来查找预定的帖子。创建可能数百个定制的 Lambda 函数似乎是一个巨大的困惑,并且在 Lambda 运行时访问数据库似乎对数据库造成了过度的压力,因为我们在安排时已经掌握了所需的所有数据。

对于如何使用 Lambda 实现此目的有什么建议吗?是否还有其他更适合该任务的 AWS 服务?我应该放弃无服务器并只设置另一个 EC2 实例来处理调度程序吗?

最佳答案

您绝对不想为每个计划任务创建一个函数+事件。

执行此操作的可扩展方法是安排一个函数定期运行(例如每小时),并检查数据库以查看是否有任何帖子安排在最后一小时(即自上次运行以来),如果有则执行它们所以。

我建议使用数据库的原因是因为您需要在某个地方管理您的状态(即发布负载/详细信息),而依靠 CloudWatch Events 来实现这一点并不是正确的方法,出于您在问题中列出的所有原因。

数据库的替代方案是将有效负载放入 S3 中,并让计划函数检查特定位置/存储桶中是否有需要处理的有效负载。 Lambda 到 S3 的通信非常快,您无需担心负载或网络传输。

关于amazon-web-services - AWS Lambda 作为社交媒体帖子调度程序?每个预定事件触发器具有唯一数据的单一功能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41516821/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com