运行 来自 python 子进程的 rsync windows
Running rsync from python subprocess in windows
我需要从 Python 2.7 应用程序 运行 rsync windows 7 x64(使用 cwRsync 5.5.0)。
命令行一切正常:
将 env 中的 CWRSYNCHOME 设置为 cwrsync 二进制文件和 运行 以下命令
rsync.exe "/cygdrive/e/test" test1@192.168.1.14:
但是当尝试 运行 与 python 子进程相同的命令时:
process = subprocess.Popen(['rsync.exe', '/cygdrive/e/test', 'test1@192.168.1.14:'],
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
shell=True,
env={'CWRSYNCHOME': './bin'})
stdout, stderr = process.communicate()
print 'STDOUT:{}\nSTDERR:{}'.format(stdout, stderr)
我在 stderr 中收到以下错误:
rsync: pipe: Operation not permitted (1)
rsync error: error in IPC code (code 14) at pipe.c(59) [sender=3.1.2]
这里是详细的 rsync 标准输出:
FILE_STRUCT_LEN=16, EXTRA_LEN=4
cmd=<NULL> machine=192.168.1.14 user=test1 path=.
cmd[0]=ssh cmd[1]=-l cmd[2]=test1 cmd[3]=192.168.1.14 cmd[4]=rsync cmd[5]=--server cmd[6]=-vvvvve.LsfxC cmd[7]=. cmd[8]=.
opening connection using: ssh -l test1 192.168.1.14 rsync --server -vvvvve.LsfxC . . (9 args)
[sender] _exit_cleanup(code=14, file=pipe.c, line=59): entered
[sender] _exit_cleanup(code=14, file=pipe.c, line=59): about to call exit(14)
尝试设置 shell=False 并将命令作为单行传递(不是 cmd 和 args)- 错误仍然重复。
我做错了什么?
要让它工作,rsync 需要在 cygwin 下运行 shell:
process = subprocess.Popen(['sh.exe', '-c',
'rsync /cygdrive/e/test test1@192.168.1.14:'],
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
stdin=subprocess.PIPE,
env={'CWRSYNCHOME': '/bin/',
'PATH': '/bin/'})
正在运行(上面的示例中没有 ssh 授权)。
我需要从 Python 2.7 应用程序 运行 rsync windows 7 x64(使用 cwRsync 5.5.0)。
命令行一切正常: 将 env 中的 CWRSYNCHOME 设置为 cwrsync 二进制文件和 运行 以下命令
rsync.exe "/cygdrive/e/test" test1@192.168.1.14:
但是当尝试 运行 与 python 子进程相同的命令时:
process = subprocess.Popen(['rsync.exe', '/cygdrive/e/test', 'test1@192.168.1.14:'],
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
shell=True,
env={'CWRSYNCHOME': './bin'})
stdout, stderr = process.communicate()
print 'STDOUT:{}\nSTDERR:{}'.format(stdout, stderr)
我在 stderr 中收到以下错误:
rsync: pipe: Operation not permitted (1)
rsync error: error in IPC code (code 14) at pipe.c(59) [sender=3.1.2]
这里是详细的 rsync 标准输出:
FILE_STRUCT_LEN=16, EXTRA_LEN=4
cmd=<NULL> machine=192.168.1.14 user=test1 path=.
cmd[0]=ssh cmd[1]=-l cmd[2]=test1 cmd[3]=192.168.1.14 cmd[4]=rsync cmd[5]=--server cmd[6]=-vvvvve.LsfxC cmd[7]=. cmd[8]=.
opening connection using: ssh -l test1 192.168.1.14 rsync --server -vvvvve.LsfxC . . (9 args)
[sender] _exit_cleanup(code=14, file=pipe.c, line=59): entered
[sender] _exit_cleanup(code=14, file=pipe.c, line=59): about to call exit(14)
尝试设置 shell=False 并将命令作为单行传递(不是 cmd 和 args)- 错误仍然重复。
我做错了什么?
要让它工作,rsync 需要在 cygwin 下运行 shell:
process = subprocess.Popen(['sh.exe', '-c',
'rsync /cygdrive/e/test test1@192.168.1.14:'],
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
stdin=subprocess.PIPE,
env={'CWRSYNCHOME': '/bin/',
'PATH': '/bin/'})
正在运行(上面的示例中没有 ssh 授权)。