在Paramiko中执行curl时,其输出在stderr中,而不是stdout中

问题描述 投票:1回答:1

我有一个手动任务,其中我ssh到服务器上,cd到一个文件夹,然后运行curl命令将文件下载到该文件夹​​。我现在正在尝试在Python程序中自动执行此操作。我可以使用paramiko SSH到服务器并运行任何命令:

ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(credentials)
ssh_stdin, ssh_stdout, ssh_stderr = ssh.exec_command('cd /path/to/folder/ && sudo curl -H \'X-JFrog-Art-Api:api_key\' -O "https://path/to/download/file.tar.xz"', timeout=600)
print(f'curl ssh_stdout: {ssh_stdout.readlines()}')
print(f'curl ssh_stderr: {ssh_stderr.readlines()}')

文件下载正确,但是我期望在stdout中显示的输出出现在stderr中。这是stderr

curl ssh_stderr: ['  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\n', '                                 Dload  Upload   Total   Spent    Left  Speed\n', '\r  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0\r  0     0    0     0    0     0      0      0 --:--:--  0:00:01 --:--:--     0\r  0     0    0     0    0     0      0      0 --:--:--  0:00:02 --:--:--     0
...
0  0:04:36  0:04:35  0:00:01 57.6M\r 99 14.9G   99 14.9G    0     0  55.5M      0  0:04:36  0:04:36 --:--:-- 57.6M\r100 14.9G  100 14.9G    0     0  55.5M      0  0:04:36  0:04:36 --:--:-- 57.8M\n']

这似乎不是使我的过程自动化的好方法。有没有办法使用其他一些库来做到这一点呢?我在想类似requests的东西。

python ssh command-line python-requests paramiko
1个回答
2
投票

[curl将其进度输出到标准错误。

您的代码或Paramiko都没问题。

在shell中,尝试:

curl https://www.example.com/ > stdout 2> stderr

您将看到stdout将包含example.com HTML内容,stderr将包含curl进度输出。

© www.soinside.com 2019 - 2024. All rights reserved.