我正在评估Amazon SWF作为构建分布式工作流系统的选项。主要语言是Java,因此Flow框架是一个显而易见的选择。在我推荐它作为我们架构中的关键组件之前,只有一件事令我困惑,我会得到一些其他意见:
这些例子都是关于在确定的,相对较短的时间段(即几分钟后)之后产生结果的任务。在我们现实生活中的业务工作流程中,问题看起来不同,这里我们的任务可能需要数周才能完成。我已经检查了计算器,有30天左右的工作流程不会导致成本爆炸,所以看起来他们已经计入了这种可能性。
有没有人使用SWF这样的场景并且可以分享任何经验?是否有任何建议,最佳实践如何设计这样的工作流程? Flow是正确的选择吗?
在我看来,Activity实现最终会同步返回一个值,但是,对于长时间运行的事务,我们宁愿使用消息来异步发回工作结果。
感谢任何有用的反馈。
答案 0 :(得分:3)
从Amazon Simple Workflow Service的角度来看,活动执行是一对API调用:PollForActivityTask
和RespondActivityTaskCompleted
共享任务令牌。这些调用不需要来自同一个线程,进程甚至主机。
默认情况下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
实现活动是一个实现细节。工作流代码通过相同的接口调用它,并且不会与任何同步实现的活动区别对待。