...
Normally you run the ecFlow server in the background and the stderr and stdout is are redirected to /dev/null by executing the following command in a start-up script:
...
When learning how to use ECF, you may open a window and run ecFlow in that window interactively. Notice that server still writes the log file (into ECF_LOG.)
ecFlow log server
The default behaviour of the GUI client is to access the output file directly (case 1 in Figure 7 2).
When this is not possible, e.g. when the GUI host cannot see the relevant file system, the ecFlow server is asked to request the output (case 2 in Figure 7 2). If the output file is large the ecFlow server will supply the last 10000 lines of the output. You can use the following command to get the relevant file associated with a given node:
...
This will output the file to standard output. This capability uses ecFlow server to get the file. The original file can be located in a directory that is visible to the ECFserver, but not to the client.
To view output from a server where the ecFlow server does not have access to the file systems we can use a log server (case 3 in Figure 7 2).
Using the GUI, you click on the manual, script, output, or job buttons. If you configured your GUI to retrieve files locally (Edit/preferences) it first looks if the required file is directly accessible. If not, it looks into the suite definition for the variables ECF_LOGHOST and ECF_LOGPORT to retrieve the file from the ecFlow log server. If the log server does not respond it contacts the ecFlow server and retrieves the file from it. This consumes available resources for the ecFlow server, so the log server is useful in reducing the ecFlow server load when many users try to get large output files.
Figure 7 2. Accessing job output, using the GUI.
...
Code Block |
---|
telnet <host><port> get_file_path |
The actual log server is a Perl program: ecflow_logsvr.pl, which is run on the remote host.
It needs:
- LOGPORT Typically 9316.
- LOGPATH This is a list of all the ECF_OUT specified in the suite. (these are directories on the remote host) separated by ':'
- LOGMAP This is the mapping: ECF_OUT:ECF_OUT, and then ECF_HOME:ECF_OUT lists,