[ https://issues.apache.org/jira/browse/CRUNCH-405?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=14065391#comment-14065391 ]
Micah Whitacre commented on CRUNCH-405: --------------------------------------- Yeah looks like PCollectionImpl + executor have references to pipeline. So we could move the logic there. {quote} We might need some sync logic in there to make sure two identical plans weren't executed simultaneously-- there would need to be a way for the execution of one plan to invalidate the execution of any others that were created. {quote} The concern here is the following flow: {code} //do something pipeline.runAsync(); //do something pipeline.runAsync(); {code} And the first flow either materializes or writes output that you'd want to make use of during the second async? Or that the second async doesn't fire off a job that causes the first to fail b/c of output conflict? > Explore adding support for idempotent MRPipeline.plan() > ------------------------------------------------------- > > Key: CRUNCH-405 > URL: https://issues.apache.org/jira/browse/CRUNCH-405 > Project: Crunch > Issue Type: Improvement > Components: Core > Reporter: Micah Whitacre > Assignee: Micah Whitacre > Attachments: CRUNCH-405_v1.patch > > > Talking through a use case with a consumer, they were interested in having > the ability to run the MRPipeline.plan() method one to many times prior to > ever calling the Pipeline.run/done methods. The reason for this was they > were looking at pulling information off the MRExecutor to tweak settings > inside of their DoFns. > Currently the MRPipeline implementation however does not have an idempotent > plan() method as it alters the state of internal values therefore affecting > the full run once done() is called. > It would be nice if we added an idempotent plan() method that could be gather > this information or perhaps a reset option. -- This message was sent by Atlassian JIRA (v6.2#6252)