目前,我正在研究一个脚本来自动执行Data Collector流程。通过长期运行,我将这些Collector脚本分为四个部分。现在,我想同时启动这些Collectorscripts,但我不知道该怎么做。我的代码专家工作:
package require Expect
log_user 0
set timeout 10200
spawn ./Log.tcl 2 5 1; set spawn1 $spawn_id
spawn ./Log.tcl 3 4 2; set spawn2 $spawn_id
spawn ./Log.tcl 7 8 2; set spawn3 $spawn_id
spawn ./Log.tcl 6 9 3; set spawn4 $spawn_id
expect -i $spawn1 eof {wait ; puts "--- 2,5 fertig ---"}
expect -i $spawn2 eof {wait ; puts "--- 3,4 fertig ---"}
expect -i $spawn3 eof {wait ; puts "--- 7,8 fertig ---"}
expect -i $spawn4 eof {puts "--- 6,9 fertig ---"}
这是运行和制造的东西。但是,如果一项工作在另一项工作之前已经准备好,它将产生僵尸。有可能使它变得简单而美丽吗?我尝试了一些带有while循环的exp_after,exp_background,$ any_spawn_id。但是没有任何效果。期望永远不会得到成功。
如果您需要知道生成的命令的完成顺序,则很难等待,但是expect
会接受一个生成ID的列表以同时收听。例如,
spawn sleep 2
lappend allids $spawn_id
set cmd($spawn_id) "sleep 2"
spawn sleep 1
lappend allids $spawn_id
set cmd($spawn_id) "sleep 1"
while { [llength $allids]>0 } {
expect -i "$allids" eof {
puts "eof on $expect_out(spawn_id) from cmd $cmd($expect_out(spawn_id))"
set idx [lsearch -exact $allids $expect_out(spawn_id)]
set allids [lreplace $allids $idx $idx]
}
}
这将运行2个命令,sleep 2
并且sleep 1
将每个生成ID附加到list中allids
。为方便起见,该命令还应在该cmd
命令的生成ID索引的数组中注明。
然后将所有衍生ID的列表提供给expect eof
using -i
。当eof匹配时,全局变量$expect_out(spawn_id)
包含导致匹配的进程的生成ID。在cmd
数组中索引此值后,将显示一条消息。
最后,从列表中删除带有eof的生成ID,并重复循环,直到列表为空。
请注意,您不能使用它exp_continue
来继续Expect循环,因为-i
似乎没有重新评估该值。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句