Horizontal Navigation Bar |
---|
Button Group |
---|
Button Hyperlink |
---|
title | Previous |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Going+Further |
---|
|
Button Hyperlink |
---|
title | Up |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Going+Further |
---|
|
Button Hyperlink |
---|
title | Next |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Families |
---|
|
|
|
Let’s add another
task named
t2.
You must also create a file t2.ecf in $HOME/course/test
. Simply copy t1.ecf
.
First, modify the suite definition
Text
It is good practice to suspend your suite before you reload any part of it.
Once you made your change(specified below) you can right-click on the suite and “Resume” it.
Code Block |
---|
# Definition of the suite test
suite test
edit ECF_HOME "$HOME/course" # replace '$HOME' with the path to your home directory
task t1
task t2
endsuite |
replace replace $HOME with the real path to your home directory. |
Then you must load the file again:
|
code |
ecflow_client --load =test.def |
Warning |
---|
This will fail because the suite is already loaded |
Because the suite is already defined, you need to delete and reload it first:
|
code |
ecflow_client --delete=_all_
ecflow_client --load=test.def |
Then restart the suite:
Code Block |
---|
|
ecflow_client --begin=test |
Rather than deleting, loading and beginning the suite every time you can replace
all or part of the suite for example to replace whole suite.
|
code |
ecflow_client --replace =/test test.def |
or to replace part of the suite:
Code Block |
---|
|
ecflow_client --replace =/test/t2 test.def |
Python
To delete the suite definition, reload and begin using the Client Server API: First update test.py to add task t2
#!/usr/bin/env python2.7
title | $HOME/course/test.py |
---|
|
import os
|
importfrom ecflow import Defs,Suite,Task,Edit
print |
("Creating suite definition")
home = os.path.join(os.getenv("HOME"), "course")
defs = |
ecflow.)
suite = defs.add_suite("test")
suite.add_variable("ECF_HOME", os.getenv("HOME") + "/course")
suite.add_task("t1")
suite.add_task("t2")
print defs
print
Suite('test',
Edit(ECF_HOME=home),
Task('t1'),
Task('t2')))
print(defs)
print("Checking job creation: .ecf -> .job0" |
(defs.check_job_creation())
print |
("Saving definition to file 'test.def'")
defs.save_as_defs("test.def") |
To delete all suites in the server and reload the modified test.def, we could update client.py
#!usr/bin/env python2.7
("Client -> Server: delete, then load a new definition")
try:
ci = ecflow.Client() |
ci.delete_all() # clear out the server
ci.load("test.def") # load the definition into the server
ci.begin_suite("test") # start the suite
except RuntimeError |
, +str(
Rather than deleting, loading, and beginning the suite every time you can replace
all or part of the suite. (i.e. to replace the whole suite see below)
Additionally, we do not want the suite to start straight away. This can be done
However, we will need to remember to do this, each time. To get round around this we will
#!/usr/bin/env python2.7
Code Block |
---|
language | py |
---|
title | $HOME/course/client.py |
---|
|
import ecflow
print |
("Client -> Server: replacing suite '/test' in the server, with a new definition" |
)
try:
ci = ecflow.Client()
ci.suspend("/test") # so that we can resume manually in |
ecflowviewecflow_ui
ci.replace("/test", "test.def") # replace suite /test with suite of same name in test.def
except RuntimeError |
, "+str(
Note |
---|
For brevity the examples that follow, will not show the loading of the suite. |
What to do
- Suspend the suite using ecflowview ecflow_ui or via python using by modifying your client.py to add ecflow.Client.suspend
- Create the a new task
- Create t2.ecf by copying from t1.ecf
- Update python scripts test.py and client.py or test.def
- Replace the suite
python: python3 test.py | ./test.py
python3 client.py | ./client.py
text: ecflow_client --replace=/test test.def - Resume the the suite using ecflowview ecflow_ui
- In ecflow_ui In ecflowview, watch the two task tasks running. They should run at the same time
...
Horizontal Navigation Bar |
---|
Button Group |
---|
Button Hyperlink |
---|
title | Previous |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Going+Further |
---|
|
Button Hyperlink |
---|
title | Up |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Going+Further |
---|
|
Button Hyperlink |
---|
title | Next |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Families |
---|
|
|
|