0

我正在尝试在 python 代码中使用 Ansible 2.0 API 运行剧本。当我运行代码时,它会打印剧本的执行。有什么方法可以抑制/隐藏这些印刷品吗?

    def run_playbook(playbook, inventory, package, var_file_path, forks):
      callback = ResultsCollector()
      variable_manager = VariableManager()
      loader = DataLoader()

      inventory = Inventory(loader=loader, variable_manager=variable_manager,  host_list=inventory)
      playbook_path = playbook

      if not os.path.exists(playbook_path):
          print '[INFO] The playbook does not exist'
          sys.exit()

      Options = namedtuple('Options', ['listtags', 'listtasks', 'listhosts', 'syntax','connection', 'module_path', 'forks', 'remote_user', 'private_key_file', 'ssh_common_args', 'ssh_extra_args', 'sftp_ex
    tra_args', 'scp_extra_args', 'become', 'become_method', 'become_user', 'verbosity', 'check'])
      options = Options(listtags=False, listtasks=False, listhosts=False, syntax=False,  connection='ssh', module_path=None, forks=forks, remote_user=None, private_key_file=None, ssh_common_args=None, ssh
    _extra_args=None, sftp_extra_args=None, scp_extra_args=None, become=False, become_method=None, become_user=None, verbosity=5, check=False)
      variable_manager.extra_vars = {'hosts': package, 'var_file': var_file_path} # This can accomodate various other command line arguments.`
      passwords = {}

      pbex = PlaybookExecutor(playbooks=[playbook_path], inventory=inventory, variable_manager=variable_manager, loader=loader, options=options, passwords=passwords)

      results = pbex.run()
      stats = pbex._tqm._stats
      return stats

  run_playbook(fetch_playbook, inventory_file, source_machine, fetch_var_yml,10)
4

2 回答 2

0

这是一个老问题,但我遇到了同样的问题。就我而言,它有助于将 stdout_callback 插件设置为您想要的插件

  • 你自己的或
  • 默认
  • json
  • 没有任何
    pbex = PlaybookExecutor(playbooks=[playbook_path], inventory=inventory,variable_manager=variable_manager, loader=loader, passwords=passwords)
    ...
    pbex._tqm._stdout_callback = 'null'
    results = pbex.run()

提示来自:https ://kurisu.love/index.php/archives/137/

于 2020-04-16T11:46:51.403 回答
0

看起来您已经编写了一个自定义回调处理程序 (ResultsCollector),但没有看到该代码以及它如何处理结果,此解决方案可能无法满足您的要求。

在运行 playbook 之前,尝试将回调对象设置为 playbook 执行器的 stdout_callback,如下所示:

  callback = ResultsCollector()
  ...
  pbex._tqm._stdout_callback = callback
  results = pbex.run()
  stats = pbex._tqm._stats
  return stats
于 2018-04-30T20:28:40.520 回答