ecFlow学习笔记02.3.1 —— 添加另一个任务
该教程的最新版已发布在GitHub上,请访问ecflow-tutorial-cn
这是 ecFlow 教程的一部分,完整教程请参看《ecFlow学习笔记02 —— 教程》
- *我们来添加一个新任务名为t2,需要修改 suite definition 文件并添加一个新的脚本。
在 $HOME/course/test 中创建文件 t2.ecf,直接复制 t1.ecf 即可。
首先修改 suite definition
文本方式
在重新加载 suite 的任何部分前推荐先将 suite 挂起(suspend)。在 ecflowview 中右键点击suite,选择 Suspend。当修改完成后,右键点击 suite,选择 Resume。
挂起后,suite 颜色会改变
恢复 suite
添加新任务t2的 def 文件
注:与之前一样,使用实际的home目录替换 $HOME
在 test 目录下,复制 t1.ecf,创建 task t2 的脚本 t2.ecf。
重新加载 def 文件
已经加载过 def 文件时,上述命令不会成功。
需要删除原有的suite,并重新加载:
接着启动 suite
可以不用删除原来的 suite,替换整个 suite 定义:
可以只替换 suite 的一部分:
替换一部分后的状态
这时可以恢复 suite。
Python方式
使用 Client Server API 删除 suite definition,重载和启动suite:首先更新 test.py
重新生成 def 文件:
删除所有的 suite,重新加载修改后的 def文件,需要修改 client.py:
我们还可以替换全部或部分 suite。
另外,我们不希望 suite 立即运行,可以通过 ecflowview 挂起整个 suite,不过我们每次都需要记得这样做。为了方便,可以使用 Python Client API 挂起 suite。修改上面的 client.py
说明:为了简便,后面的例子我们都不会列出加载 suite 的过程。
任务
- 使用 ecflowview 或 pyhton 的 ecflow.Client.suspend 挂起 suite
- 创建新的 task
- 通过拷贝 t1.ecf 创建 t2.ecf
- 更新python脚本 test.py 和 client.py 或 test.def
- 替换 suite
- 使用 ecflowview 恢复 suite
- 在 ecflowview 中观察两个任务运行情况,它们应该在同一时刻运行。