VBScript
VBScript
SSH Parallel Remote Commands on Multiple Servers
See more SSH Examples
Shows how to execute a command in parallel on multiple servers.Chilkat VBScript Downloads
Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
'Create a Unicode (utf-16) output text file.
Set outFile = fso.CreateTextFile("output.txt", True, True)
success = 0
' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
' Executing a command on multiple servers simultaneously is straightforward.
' It's just a matter of using one SSH object per server..
set ssh1 = CreateObject("Chilkat.Ssh")
set ssh2 = CreateObject("Chilkat.Ssh")
set ssh3 = CreateObject("Chilkat.Ssh")
port = 22
success = ssh1.Connect("ssh-server1.com",port)
If (success <> 1) Then
outFile.WriteLine(ssh1.LastErrorText)
WScript.Quit
End If
' Authenticate using login/password:
success = ssh1.AuthenticatePw("sshLogin1","sshPassword1")
If (success <> 1) Then
outFile.WriteLine(ssh1.LastErrorText)
WScript.Quit
End If
' Connect and authenticate with 2 more servers.
' For brevity, the success/failure won't be checked...
success = ssh2.Connect("ssh-server2.com",port)
success = ssh2.AuthenticatePw("sshLogin2","sshPassword2")
success = ssh3.Connect("ssh-server3.com",port)
success = ssh3.AuthenticatePw("sshLogin3","sshPassword3")
' Note: If we wanted, we could've used ConnectAsync and AuthenticatePwAsync
' to do the connecting and authenticating in parallel...
' The command to be run on each SSH server will sleep for 5 seconds,
' and then show the current system date/time.
cmd = "sleep 5; date"
' Start each command
ssh1Channel = ssh1.QuickCmdSend(cmd)
If (ssh1Channel < 0) Then
outFile.WriteLine(ssh1.LastErrorText)
WScript.Quit
End If
' For brevity, we're not checking the return values here:
ssh2Channel = ssh2.QuickCmdSend(cmd)
ssh3Channel = ssh3.QuickCmdSend(cmd)
' OK, at this point the command is running simultaneously on each server.
' Now collect the results of each command.
pollTimeoutMs = 50
numFinished = 0
' Note: You would rewrite this code to use arrays.
ssh1Finished = 0
ssh2Finished = 0
ssh3Finished = 0
Do While numFinished < 3
' Check to see if anything has finished.
' QuickCmdCheck returns -1 if there are no errors and nothing else finished
' QuickCmdCheck returns -2 if there was an error (such as a lost connection)
' QuickCmdCheck returns a channel number if a channel finished.
If (ssh1Finished <> 1) Then
channel = ssh1.QuickCmdCheck(pollTimeoutMs)
If (channel = -2) Then
outFile.WriteLine(ssh1.LastErrorText)
WScript.Quit
End If
If (channel = ssh1Channel) Then
outFile.WriteLine("---- ssh1 channel " & channel & " finished ----")
outFile.WriteLine(ssh1.GetReceivedText(channel,"ansi"))
numFinished = numFinished + 1
ssh1Finished = 1
End If
End If
If (ssh2Finished <> 1) Then
channel = ssh2.QuickCmdCheck(pollTimeoutMs)
If (channel = -2) Then
outFile.WriteLine(ssh2.LastErrorText)
WScript.Quit
End If
If (channel = ssh2Channel) Then
outFile.WriteLine("---- ssh2 channel " & channel & " finished ----")
outFile.WriteLine(ssh2.GetReceivedText(channel,"ansi"))
numFinished = numFinished + 1
ssh2Finished = 1
End If
End If
If (ssh3Finished <> 1) Then
channel = ssh3.QuickCmdCheck(pollTimeoutMs)
If (channel = -2) Then
outFile.WriteLine(ssh3.LastErrorText)
WScript.Quit
End If
If (channel = ssh3Channel) Then
outFile.WriteLine("---- ssh3 channel " & channel & " finished ----")
outFile.WriteLine(ssh3.GetReceivedText(channel,"ansi"))
numFinished = numFinished + 1
ssh3Finished = 1
End If
End If
Loop
' --------------
' Sample output:
' ---- ssh2 channel 101 finished ----
' Fri Dec 23 00:25:48 UTC 2016
'
' ---- ssh3 channel 102 finished ----
' Thu Dec 22 18:25:12 CST 2016
'
' ---- ssh1 channel 100 finished ----
' Thu Dec 22 18:25:48 CST 2016
outFile.Close