ECF_JOB_CMD = %ECF_JOB% 1> %ECF_JOBOUT% 2>&1 & |
In the examples below replace the string ?????? with a host name of your choice.
The environment of a task running on a remote host can be different from that of a task running locally. It depends on how your system is set up. The head.h should already be using the correct PATH, to allow child commands to be used. If not add the following line into your head.h file before the call to ecflow_client –init > export PATH=$PATH:/usr/local/apps/ecflow/ |
REMOTE_HOST=?????? ssh $USER@$REMOTE_HOST mkdir -p \$HOME/.ssh cat $HOME/.ssh/id_rsa.pub || ssh-keygen -t rsa -b 2048 cat $HOME/.ssh/id_rsa.pub | ssh $USER@$REMOTE_HOST 'cat >> $HOME/.ssh/authorized_keys' |
Modify the family f5 so that all its tasks will run on another machine in the classroom.
# Definition of the suite test suite test edit ECF_INCLUDE "$HOME/course" edit ECF_HOME "$HOME/course" limit l1 2 family f5 edit HOST ?????? edit ECF_JOB_CMD "ssh %HOST% '%ECF_JOB% > %ECF_JOBOUT% 2>&1 &'" inlimit l1 edit SLEEP 20 task t1 task t2 task t3 task t4 task t5 task t6 task t7 task t8 task t9 endfamily endsuite |
If your login shell is csh, you should define ECF_JOB_CMD as:
edit ECF_JOB_CMD "ssh %HOST% '%ECF_JOB% >& %ECF_JOBOUT%'" |
In python modify the function create_family_f5() created in the earlier page, to add HOST and ECF_JOB_CMD:
#!/usr/bin/env python2.7 import os from ecflow import Defs,Suite,Family,Task,Edit,Trigger,Complete,Event,Meter,Time,Day,Date,Label, \ RepeatString,RepeatInteger,RepeatDate,InLimit,Limit def create_family_f5() : return Family("f5", InLimit("l1"), Edit(SLEEP=20, HOST='?????', ECF_JOB_CMD,"ssh %HOST% '%ECF_JOB% > %ECF_JOBOUT% 2>&1 &'"), [ Task('t{}'.format(i)) for i in range(1,10) ] ) print "Creating suite definition" home = os.path.join(os.getenv("HOME"),"course") defs = Defs( Suite("test", Edit(ECF_INCLUDE=home,ECF_HOME=home), Limit("l1",2), create_family_f5())) print(defs) print("Checking job creation: .ecf -> .job0") print(defs.check_job_creation()) print("Checking trigger expressions") assert len(defs.check()) == 0,defs.check() print("Saving definition to file 'test.def'") defs.save_as_defs("test.def") |
Launch the logserver on a remote machine:
ssh class01 /usr/local/apps/ecflow/4.8.0/bin/start_logserver -d /tmp/$USER -m /tmp/$USER:/tmp/$USER |
Edit the definition file:
HOST=class01 edit ECF_LOGHOST $HOST edit ECF_LOGPORT $(35000 + $(id -u)) edit HOST $HOST edit ECF_OUT /tmp/$USER |
You can test the logserver from the command line, requesting the output from a task:
telnet class01 -p $(35000 + $(id -u)) # get $ECF_JOBOUT # list $ECF_JOBOUT |
|