- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在评估 Amazon SWF 作为构建分布式工作流系统的选项。主要语言将是 Java,因此 Flow 框架是一个显而易见的选择。只有一件事让我感到困惑,在我推荐它作为我们架构中的关键组件之前,我会得到一些其他的意见:
这些示例都是关于在确定的、相对较短的时间(即几分钟后)后产生结果的任务。在我们现实生活中的业务工作流程中,事情看起来有所不同,这里我们的任务可能需要数周才能完成。我已经检查了计算器,工作流程持续 30 天左右不会导致成本爆炸,所以他们似乎已经考虑到了这种可能性。
有人在这样的场景中使用过 SWF 并且可以分享任何经验吗?是否有任何建议,最佳实践如何设计这样的工作流程? Flow在这里是正确的选择吗?
在我看来,Activity 实现最终有望同步返回一个值,但是,对于长时间运行的事务,我们宁愿使用消息异步发回工作人员结果。
任何有用的反馈表示赞赏。
最佳答案
来自 Amazon Simple Workflow Service一个事件执行的观点是一对 API 调用:PollForActivityTask
和 RespondActivityTaskCompleted
共享一个任务 token 。这些调用不需要来自同一个线程、进程甚至主机。
默认 AWS Flow Framework同步执行一个事件。使用@ManualActivityCompletion
注释以指示在事件方法返回时事件未完成。此类事件应使用提供的 ManualActivityCompletionClient
明确完成(或失败)。 .
以下是取自 AWS Flow Framework Developer Guide 的示例:
@ManualActivityCompletion
public String getName() {
ActivityExecutionContext executionContext = contextProvider.getActivityExecutionContext();
String taskToken = executionContext.getTaskToken();
sendEmail("abc@xyz.com",
"Please provide a name for the greeting message and close task with token: " + taskToken);
return "This will not be returned to the caller";
}
public class CompleteActivityTask {
public void completeGetNameActivity(String taskToken) {
AmazonSimpleWorkflow swfClient = new AmazonSimpleWorkflowClient(…); //pass in user credentials
ManualActivityCompletionClientFactory manualCompletionClientFactory = new ManualActivityCompletionClientFactoryImpl(swfClient);
ManualActivityCompletionClient manualCompletionClient
= manualCompletionClientFactory.getClient(taskToken);
String result = "Hello World!";
manualCompletionClient.complete(result);
}
public void failGetNameActivity(String taskToken, Throwable failure) {
AmazonSimpleWorkflow swfClient
= new AmazonSimpleWorkflowClient(…); //pass in user credentials
ManualActivityCompletionClientFactory manualCompletionClientFactory
= new ManualActivityCompletionClientFactoryImpl(swfClient);
ManualActivityCompletionClient manualCompletionClient
= manualCompletionClientFactory.getClient(taskToken);
manualCompletionClient.fail(failure);
}
}
@ManualActivityCompletion
实现事件是一个实现细节。工作流代码通过相同的接口(interface)调用它,并且与同步实现的任何事件没有区别。
关于amazon-swf - 适用于长期运行的业务工作流程的 Amazon SWF,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14063757/
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 5年前关闭。 Improve this
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我试图弄清楚如何基于 JSESSIONID cookie 为具有长期交互式用户 session 的 web 应用程序提供零停机滚动更新,这些 session 应该是粘性的。 出于这个(和其他)原因,我
这更像是一个“你能给我指出正确的方向吗”类型的问题。 基本上,我想为客户提供一种“保存”购物车的方法,也许以后可以与亲戚一起查看(这是摄影师客户的“照片篮”)。 当使用我的“照片篮”时,它会创建一个篮
我正在编写一个使用商店的网络应用程序。如果客户端在30秒内没有收到响应,则认为该请求已失效,并给出超时错误。 我正在尝试让 MongoDB 做同样的事情。例如,如果连接断开 1 分钟,驱动程序将尝试重
我多年来一直在开发和管理 Oracle 数据库应用程序,并且想学习 SQL Server。有没有人有任何书籍推荐(最好是电子版)。当然,我已经对 SQL 了如指掌,所以我想避免任何介绍性的内容,直接进
我是一名优秀的程序员,十分优秀!