ecFlow's documentation is now on readthedocs!

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 2 Next »

To start a job, ECF uses the content of the ECF_JOB_CMD variable.
By modifying this variable, it is possible to control where and how a job file will run.
The command should be used in conjunctions with the variable ECF_JOB and ECF_JOBOUT.
ECF_JOB contains the name of the file containing the job file, and ECF_JOBOUT contains
the name of the file that should contain the output.

Note

The default command ECF_JOB_CMD = %ECF_JOB% 1> %ECF_JOBOUT% 2>&1 &

Let us run the tasks on a remote machine. For that we could use the unix command rsh.
We would like the name of the host to be defined by an variable called HOST.
We assume that all the files are visible on all the hosts, i.e. using NFS.

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 f1

     edit SLEEP 20

     task t1

         meter progress 1 100 90

     task t2

         trigger t1 eq complete

         event a

         event b

     task t3

         trigger t2:a

     task t4

         trigger t2 eq complete

         complete t2:b

     task t5

         trigger t1:progress ge 30

     task t6

         trigger t1:progress ge 60

     task t7

         trigger t1:progress ge 90

 endfamily

 family f2

     edit SLEEP 20

     task t1

         time 00:30 23:30 00:30

     task t2

         day  sunday

     task t3

         date 01.*.*

         time 12:00

     task t4

         time +00:02

     task t5

         time 00:02

 endfamily

 family f3

     task t1

         label info ""

 endfamily

 family f4

     edit SLEEP 2

     repeat string NAME a b c d e f

     family f5

         repeat integer VALUE 1 10

         task t1

             repeat date DATE 19991230 20000105

             label info ""

     endfamily

 endfamily

 family f5

     edit HOST ??????

     edit ECF_JOB_CMD "rsh %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

In python modify the function create_family_f5() created in the earlier page:

#!/usr/bin/env python2.5

import os

import ecflow



def create_family_f5() :

    f5 = ecflow.Family("f5")

    f5.add_inlimit("l1")

    f5.add_variable("HOST","??????")

    f5.add_variable("ECF_JOB_CMD","rsh %HOST% '%ECF_JOB% > %ECF_JOBOUT% 2>&1 &'")

    f5.add_variable("SLEEP",20)

    for i in range(1,10):

        f5.add_task( "t" + str(i) )

    return f5

          

defs = ecflow.Defs("test.def")

suite = defs.add_suite("test")

suite.add_variable("ECF_INCLUDE",os.getenv("HOME") + "/course")

suite.add_variable("ECF_HOME   ",os.getenv("HOME") + "/course")



suite.add_limit("l1",2)

suite.add_family( create_family_f5() )

You have to replace the string ?????? with a host name of your choice.

Note

The environment you get when submitting tasks remotely is different from that when submitting locally. This depends on how your system is set up. Here we need to set PATH, to allow child command‘s to be used. So add the following line into your head.h file before the call to ecf_client –init

> export PATH=$PATH:/usr/local/bin

You may experience other problems using rsh, caused by standard unix issues.
Make sure that the file $HOME/.rhosts contains a line with your user ID and
the machine where your server is running.

If your login shell is csh, you should define ECF_JOB_CMD as:

edit ECF_JOB_CMD "rsh %HOST% '%ECF_JOB% >& %ECF_JOBOUT%'"

What to do:

  1. Change the suite definition
  2. Load and begin the suite
  3. It may not work immediately. Have a look in the file $HOME/course/host.port.ecf.log to see why.
  4. What do you need to do in order to have the task /test/f5/t9 run on even another machine? Try your solution.
  • No labels