尝试在python子进程中运行rsync时出现意外的远程arg错误

时间:2018-02-28 13:49:27

标签: python subprocess rsync

我正在尝试使用子进程模块的call()方法和用于身份验证的公钥在python 3.4中进行Rsync调用,以便我可以同步远程文件夹。文件夹的位置通过JSON动态传递。涉及的代码如下:

response_dict = json.loads(response)
source = 'user@server.example.com:' + response_dict['path'] + '/'
args = ['rsync', '-rv', '-e', '--delete', '--progress', '--update', 'ssh', '-i', '/path/to/public.key', source, '/path/to/local/folder/']
call(args)

我已尝试过该命令的几种变体,包括:

args = ['rsync', '-rv', '-e', 'ssh', '-i', '/path/to/public.key', source, '/path/to/local/folder/', '--delete', '--progress', '--update']

args = ['rsync', '-rv', '-e', 'ssh', '-i', '/path/to/public.key', '-l', 'user', source, '/path/to/local/folder/', '--delete', '--progress', '--update']

甚至

args = ['rsync', '-rv', '-e', 'ssh', '-i', '/path/to/public.key', '-l', 'user', 'user@server.example.com:' + response_dict['path'] + '/', '/path/to/local/folder/', '--delete', '--progress', '--update']

但是我得到了同样的错误:

Unexpected remote arg: user@server.example.com:/path/to/remote/folder/ 
rsync error: syntax or usage error (code 1) at main.c(1330) [sender=3.1.1]

我是蟒蛇新手,我一直在学习,但这个让我完全难过。我一直在谷歌搜索一整天和昨天的大部分时间,但我发现的类似问题的每个解决方案都没有效果。如果有人能帮我弄清楚出了什么问题,我们将非常感激。

1 个答案:

答案 0 :(得分:1)

首先,您应该验证ssh命令是否有效。如果它没有,那么就没有任何一点试图让它在Python中运行。

其次,-e命令应该是单个字符串,例如

args = ["rsync", "-rv", "-e", "ssh -i /path/to/public.key", "user@server.example.com:/path/to/remote/folder/", "/path/to/local/folder/", "--delete", "--progress" "--update"]