抑制织物运行输出的简单方法?

新手上路,请多包涵

我在远程机器上运行命令:

 remote_output = run('mysqldump --no-data --user=username --password={0} database'.format(password))

我想捕获输出,但不想将其全部打印到屏幕上。最简单的方法是什么?

原文由 Ben McCann 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 373
2 个回答

听起来您正在寻找 管理输出 部分。

要隐藏控制台的输出,请尝试如下操作:

 from __future__ import with_statement
from fabric.api import hide, run, get

with hide('output'):
    run('mysqldump --no-data test | tee test.create_table')
    get('~/test.create_table', '~/test.create_table')

下面是示例结果:

 No hosts found. Please specify (single) host string for connection: 192.168.6.142
[192.168.6.142] run: mysqldump --no-data test | tee test.create_table
[192.168.6.142] download: /home/quanta/test.create_table <- /home/quanta/test.create_table

原文由 quanta 发布,翻译遵循 CC BY-SA 3.0 许可协议

如果您想隐藏日志中的所有内容并避免在命令失败时结构抛出异常,请尝试此操作:

 from __future__ import with_statement
from fabric.api import env,run,hide,settings

env.host_string = 'username@servernameorip'
env.key_filename = '/path/to/key.pem'

def exec_remote_cmd(cmd):
    with hide('output','running','warnings'), settings(warn_only=True):
        return run(cmd)

之后,您可以检查命令结果,如本例所示:

 cmd_list = ['ls', 'lss']
for cmd in cmd_list:
    result = exec_remote_cmd(cmd)
    if result.succeeded:
        sys.stdout.write('\n* Command succeeded: '+cmd+'\n')
        sys.stdout.write(result+"\n")
    else:
        sys.stdout.write('\n* Command failed: '+cmd+'\n')
        sys.stdout.write(result+"\n")

这将是程序的控制台输出(注意没有来自 fabric 的日志消息):

* 命令成功:ls
桌面 espaiorgcats.sql 图片 公共视频
文档 examples.desktop projectes 脚本
下载 Music prueba 模板

* 命令失败:lss
/bin/bash: lss: 找不到命令

原文由 cfillol 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题