shell script remote execution using python

2019-03-28 02:14发布

Is there a way that I can use Python on Windows to execute shell scripts which are located on a remote Unix machine?

P.S: Sorry about the late edit. I do know of Paramiko, but I wanted to know if there is way of doing it without it. For starters, could it be done with subprocess()?

7条回答
Melony?
2楼-- · 2019-03-28 02:57

I'd do this with Pexpect and Plink.

查看更多
我欲成王,谁敢阻挡
3楼-- · 2019-03-28 02:57

You will either need to run some sort of server on the remote machine, or ssh in and do it yourself. It would not be difficult to use one of the many pre-written Python servers to listen for a client and kick off a shell script.

Authentication may or may not be a problem for you; be aware that anyone else can follow the same steps you do and possibly get the same result. You don't want to allow anyone on the intarwubs to start your scripts!

查看更多
不美不萌又怎样
4楼-- · 2019-03-28 02:59

You will need to ssh into the remote machine and if you have appropriate credentials, you can invoke the shell scripts.

For using ssh, you can easily use paramiko module that provides ssh automation

A typical example:

import paramiko
import sys
import os
import os.path
passwd = ""
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect('servername', username, password=passwd)
stdin, stdout, stderr = ssh.exec_command('df -h')
x = stdout.readlines()
print x
for line in x:
    print line
ssh.close()

Replace "df -h" command with the your shell script.

查看更多
\"骚年 ilove
5楼-- · 2019-03-28 03:03

There is not any 'batteries included' module for remote shell execution in python. I'd suggest looking into Fabric , which provides a really nice interface for working through SSH on remote machines, probably a bit nicer than paramiko. You can even install Fabric on windows...

查看更多
叛逆
6楼-- · 2019-03-28 03:07

Sure, typically via the ssh protocol (for "secure shell") as supported for Python e.g. by the paramiko third-party extension.

查看更多
Fickle 薄情
7楼-- · 2019-03-28 03:10

I've got one with multiprocessing and subprocess that i haven't tested but should work based on docs...

Server:

import subprocess
from multiprocessing.managers import BaseManager
def get_subprocess_module():
    return subprocess
class MyManager(BaseManager):
    pass
MyManager.register( 'subprocess', get_subprocess_module )
MyManager(address=('', 50000), authkey='makecrazy').get_server().serve_forever()

Remote Client:

from multiprocessing.managers import BaseManager
class MyManager(BaseManager):
    pass
MyManager.register('subprocess')
manager = MyManager(address=('dns.of.remote.server',50000),authkey='makecrazy')
manager.connect()
remoteSubprocess = manager.subprocess()
rc = remoteSubprocess.call(['ls', '-aplh'])
查看更多
登录 后发表回答