我需要在两到四个不同的服务器上执行时间密集型任务。
服务器数量可能会有所不同。
我需要在大约相同的时间在每台机器上执行相同的任务,否则它会使此过程花费的时间增加四倍。
到目前为止,我已经能够想出这个:
public partial class Form_main : Form
{
list<string> vms = new list<string>;
///Fill in vms...
private void startTest()
{
///prevents GUI from hanging
ThreadPool.QueueUserWorkItem(new WaitCallback(runTests));
}
pirvate void runTests()
{
///Some setup stuff (~1 min)
foreach(string vm in vms)
{
ThreadPool.QueueUserWorkItem(new WaitCallback(testProcedure), new object[] {vm});
}
}
}
这适用于一次运行所有内容,但问题是如果GUI被杀死,线程不会随之被杀死。我想它会杀死runTests线程,但不会杀死testProcedures线程。
如何在关闭GUI时使testProcedures线程被杀死?