Chilkat2-Python
Chilkat2-Python
SSH Parallel Remote Commands on Multiple Servers
See more SSH Examples
Shows how to execute a command in parallel on multiple servers.Chilkat Chilkat2-Python Downloads
import sys
import chilkat2
success = False
# 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..
ssh1 = chilkat2.Ssh()
ssh2 = chilkat2.Ssh()
ssh3 = chilkat2.Ssh()
port = 22
success = ssh1.Connect("ssh-server1.com",port)
if (success != True):
print(ssh1.LastErrorText)
sys.exit()
# Authenticate using login/password:
success = ssh1.AuthenticatePw("sshLogin1","sshPassword1")
if (success != True):
print(ssh1.LastErrorText)
sys.exit()
# 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):
print(ssh1.LastErrorText)
sys.exit()
# 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 = False
ssh2Finished = False
ssh3Finished = False
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 != True):
channel = ssh1.QuickCmdCheck(pollTimeoutMs)
if (channel == -2):
print(ssh1.LastErrorText)
sys.exit()
if (channel == ssh1Channel):
print("---- ssh1 channel " + str(channel) + " finished ----")
print(ssh1.GetReceivedText(channel,"ansi"))
numFinished = numFinished + 1
ssh1Finished = True
if (ssh2Finished != True):
channel = ssh2.QuickCmdCheck(pollTimeoutMs)
if (channel == -2):
print(ssh2.LastErrorText)
sys.exit()
if (channel == ssh2Channel):
print("---- ssh2 channel " + str(channel) + " finished ----")
print(ssh2.GetReceivedText(channel,"ansi"))
numFinished = numFinished + 1
ssh2Finished = True
if (ssh3Finished != True):
channel = ssh3.QuickCmdCheck(pollTimeoutMs)
if (channel == -2):
print(ssh3.LastErrorText)
sys.exit()
if (channel == ssh3Channel):
print("---- ssh3 channel " + str(channel) + " finished ----")
print(ssh3.GetReceivedText(channel,"ansi"))
numFinished = numFinished + 1
ssh3Finished = True
# --------------
# 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