Currently I am reading in host names from a file using a foreach command and using this hostname to connect to the device. All this is done within my TCL script. Is there a way I can run multiple instances of the script so that each device is queried separately? Something like a bash script similar to:
for hostname in file;
do
log.tcl $hostname &
done
I believe this is similar to multi threading.
Another question I have is that, when running multiple instances of a script, and each script writes to the same file, will all the logs be jumbled up?
There are several options to archive this:
1. Execute the script for each hostname:
foreach hostname $hosts {
exec log.tcl $hostname &
}
This is like the bash solution.
2. Use threads
package require Thread
set pool [tpool::create]
set jobs {}
foreach hostname $hosts {
lappend jobs [tpool::post -nowait $pool [list apply {{host} {
set argv0 log.tcl
set argv [list $host]
source $argv0
} $hostname]]
}
while {[llength $jobs]} {
tpool::wait $pool $jobs jobs
}
Note that expect does not work nicely with threads.
For the other question regarding writing to the same file from multiple scripts: It depends. If you have a POSIX compliant system and open the files with a
, then it might work.