本文整理匯總了Python中ansible.executor.playbook_executor.PlaybookExecutor.run方法的典型用法代碼示例。如果您正苦於以下問題:Python PlaybookExecutor.run方法的具體用法?Python PlaybookExecutor.run怎麽用?Python PlaybookExecutor.run使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類ansible.executor.playbook_executor.PlaybookExecutor
的用法示例。
在下文中一共展示了PlaybookExecutor.run方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: ansible_task
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def ansible_task(playbooks):
Options = namedtuple('Options', \
['connection', 'module_path', 'forks', 'become', 'become_method', 'become_user', 'check', 'listhosts', 'listtasks', 'listtags', 'syntax'])
options = Options(
connection = 'ssh',
module_path = '/opt/ansible/modules',
forks = 100,
become = True,
become_method = 'sudo',
become_user = 'root',
check = False,
listhosts = None,
listtasks = None,
listtags = None,
syntax = None
)
loader = DataLoader()
variable_manager = VariableManager()
inventory = Inventory(loader=loader, variable_manager=variable_manager, host_list='/opt/ansible/inventory')
variable_manager.set_inventory(inventory)
pb = PlaybookExecutor(playbooks=[playbooks], inventory=inventory, variable_manager=variable_manager, loader=loader, options=options, passwords=None)
pb.run()
stats = pb._tqm._stats
ips = stats.processed.keys()
return [ {ip : stats.summarize(ip)} for ip in ips ]
示例2: PlayBook
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
class PlayBook(object):
def __init__(self, playbook, inventory="inventory.py", extra_vars=None):
basedir = os.path.abspath(os.path.dirname(__file__))
self.playbook = os.path.join(basedir, playbook)
self.options = Options(
inventory=inventory,
sudo=False, su=False, sudo_user=None, su_user=None,
listtags=False, listtasks=False, listhosts=False,
syntax=False, check=False,
ask_pass=False,ask_su_pass=False,ask_sudo_pass=False,ask_vault_pass=False,
connection='smart', timeout=10, remote_user=None, private_key_file=None,
ssh_common_args=None, ssh_extra_args=None,
sftp_extra_args=None, scp_extra_args=None,
module_path=None, forks=5,
become=False, become_method='sudo', become_user=None,
verbosity=0)
self.loader = DataLoader()
self.variable_manager = VariableManager()
self.variable_manager.extra_vars = extra_vars
self.inventory = Inventory(loader=self.loader,
variable_manager=self.variable_manager,
host_list=inventory)
self.pbex = PlaybookExecutor(playbooks=[self.playbook],
inventory=self.inventory,
loader=self.loader,
variable_manager=self.variable_manager,
options=self.options,
passwords={'become_pass': None})
def run(self):
self.pbex.run()
stats = self.pbex._tqm._stats
self.pbex._tqm.send_callback('human_log')
return stats
示例3: playbook_api
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def playbook_api(self,yml_fp):
loader = DataLoader()
variable_manager = VariableManager()
inventory = Inventory(
loader=loader,
variable_manager=variable_manager,
host_list=self.ansible_host_list
)
variable_manager.set_inventory(inventory)
playbooks = ["%s" % yml_fp]
pbex = PlaybookExecutor(
playbooks=playbooks,
inventory=inventory,
variable_manager=variable_manager,
loader=loader,
options=self.options,
passwords=self.passwords
)
callback = AnsiCallBack()
pbex._tqm._stdout_callback = callback
pbex.run()
return self.evaluate_results(callback)
示例4: run_playbook
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def run_playbook(self, hosts, playbook_path):
"""
run ansible palybook
"""
global tasklist
tasklist = {}
for host in hosts:
tasklist[host] = {}
tasklist[host]['ok'] = []
tasklist[host]['failed'] = []
tasklist[host]['skppied'] = []
self.results_callback = PlayBookResultCallback(tasklist)
try:
executor = PlaybookExecutor(
playbooks=[playbook_path],
inventory=self.inventory,
variable_manager=self.variable_manager,
loader=self.loader,
options=self.options,
passwords=self.passwords)
executor._tqm._stdout_callback = self.results_callback
executor.run()
except Exception as e:
print(e)
return False
示例5: run_playbook
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def run_playbook(self, host_list, role_name, role_uuid, temp_param):
"""
run ansible palybook
"""
try:
self.callback = ResultsCollector()
filenames = [BASE_DIR + '/handlers/ansible/v1_0/sudoers.yml']
logger.info('ymal file path:%s'% filenames)
template_file = TEMPLATE_DIR
if not os.path.exists(template_file):
logger.error('%s 路徑不存在 '%template_file)
sys.exit()
extra_vars = {}
host_list_str = ','.join([item for item in host_list])
extra_vars['host_list'] = host_list_str
extra_vars['username'] = role_name
extra_vars['template_dir'] = template_file
extra_vars['command_list'] = temp_param.get('cmdList')
extra_vars['role_uuid'] = 'role-%s'%role_uuid
self.variable_manager.extra_vars = extra_vars
logger.info('playbook 額外參數:%s'%self.variable_manager.extra_vars)
# actually run it
executor = PlaybookExecutor(
playbooks=filenames, inventory=self.inventory, variable_manager=self.variable_manager, loader=self.loader,
options=self.options, passwords=self.passwords,
)
executor._tqm._stdout_callback = self.callback
executor.run()
except Exception as e:
logger.error("run_playbook:%s"%e)
示例6: __init__
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def __init__(self, **kwargs):
super(Ansible_playbook, self).__init__(**kwargs)
self.task_file = kwargs.get('task_file', None)
self.sudo = kwargs.get('sudo', False)
self.sudo_user = kwargs.get('sudo_user', False)
self.sudo_password = kwargs.get('sudo_password', False)
# check if parameters have been provided
if self._is_parameters_ok():
variable_manager = VariableManager()
loader = DataLoader()
options = self._get_options()
passwords = {'become_pass': self.sudo_password}
inventory = Inventory(loader=loader, variable_manager=variable_manager, host_list="localhost")
variable_manager.set_inventory(inventory)
playbooks = [self.task_file]
executor = PlaybookExecutor(
playbooks=playbooks,
inventory=inventory,
variable_manager=variable_manager,
loader=loader,
options=options,
passwords=passwords)
executor.run()
示例7: _run_playbook
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def _run_playbook(self, playbook):
self.options = options = self.Options(**self.options_args)
vm = self.variable_manager
vm.extra_vars = load_extra_vars(loader=self.loader, options=options)
pbe = PlaybookExecutor(
playbooks=[playbook],
inventory=self.inventory,
variable_manager=vm,
loader=self.loader,
options=options,
passwords=dict(),
)
pbe.run()
return vm.get_vars(self.loader)
示例8: run
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def run(self):
executor = PlaybookExecutor(
playbooks=[self.playbook_path],
inventory=self.inventory,
variable_manager=self.variable_manager,
loader=self.loader,
options=self.options,
passwords=self.passwords
)
if executor._tqm:
executor._tqm._stdout_callback = self.results_callback
executor.run()
executor._tqm.cleanup()
return self.results_callback.output
示例9: run
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def run(self):
executor = PlaybookExecutor(
playbooks=[self.playbook_path],
inventory=self.inventory,
variable_manager=self.variable_manager,
loader=self.loader,
passwords={"conn_pass": self.passwords}
)
context.CLIARGS = ImmutableDict(self.options)
if executor._tqm:
executor._tqm._stdout_callback = self.results_callback
executor.run()
executor._tqm.cleanup()
return self.results_callback.output
示例10: run
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def run(self, log):
if not self.playbook:
code = 999
simple = 'playbook must exist'
return code, simple, None
if log:
log_file.append(log)
if not os.path.exists(self.playbook):
code = 1000
results = 'not exists playbook: ' + self.playbook
return code, results, None
pbex = PlaybookExecutor(playbooks=[self.playbook],
inventory=self.inventory,
variable_manager=self.variable_manager,
loader=self.loader,
options=self.options,
passwords=self.passwords)
try:
code = pbex.run()
except AnsibleParserError:
code = 1001
results = 'syntax problems in ' + self.playbook
return code, results, None
stats = pbex._tqm._stats
hosts = sorted(stats.processed.keys())
results = [{h: stats.summarize(h)} for h in hosts]
if not results:
code = 1002
results = 'no host executed in ' + self.playbook
return code, results, None
complex = '\n'.join(log_add)
return code, results, complex
示例11: run
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def run(self, playbooks, limit=''):
"""
param: `playbooks`: type string or list, example: ['/etc/ansible/test.yml'], '/etc/ansible/test1.yml, /etc/ansible/test2.yml'
param: `limit`: eq --limit ''
"""
self._prepare_run()
results = 0
if isinstance(playbooks, basestring):
if ',' in playbooks:
playbooks = [pl.strip() for pl in playbooks.split(',') if os.path.exists(pl)]
else:
playbooks = [playbooks.strip()]
# --limit
if limit:
self.inventory.subset(limit)
try:
# create the playbook executor, which manages running the plays via a task queue manager
pbex = PlaybookExecutor(playbooks=playbooks, inventory=self.inventory,
variable_manager=self.variable_manager,
loader=self.loader, options=self.options, passwords=self.passwords)
results = pbex.run()
except Exception, ex:
results = str(ex)
示例12: runPlaybook
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def runPlaybook(self):
sys.stdout = open('Output-pythonAnsible','w')
variable_manager = VariableManager()
loader = DataLoader()
inventory = Inventory(loader=loader, variable_manager=variable_manager, host_list=self.host_list)
#self.playbook_path
#playbook_path = '/home/davis/Documents/Network-automation/cisco_xe.yml'
if not os.path.exists(self.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_extra_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=100, remote_user='slotlocker', private_key_file=None, ssh_common_args=None, ssh_extra_args=None, sftp_extra_args=None, scp_extra_args=None, become=True, become_method=None, become_user='root', verbosity=None, check=False)
#variable_manager.extra_vars = {'hosts': 'mywebserver'} # This can accomodate various other command line arguments.`
passwords = {}
pbex = PlaybookExecutor(playbooks=[self.playbook_path], inventory=inventory, variable_manager=variable_manager, loader=loader, options=options, passwords=passwords)
results = pbex.run()
print "Output ::-",results
return results
示例13: PlayBook
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
class PlayBook(object):
def __init__(self, inventory='/etc/ansible/hosts', extra_vars=None, private_key_file=None):
"""
:param playbook: playbook.yml
:param inventory: inventory file or script
:type param extra_vars: dict
:param private_key_file: ssh private key
"""
self.pbex = None
self.options = Options(private_key_file=private_key_file, connection='smart', forks=10, timeout=10,
verbosity=0, check=False,
listtasks=False, listhosts=False, syntax=False,
subset=None, module_path=None, become=None, become_user=None, become_method='sudo')
# initialize needed objects
self.loader = DataLoader()
self.variable_manager = VariableManager()
self.variable_manager.extra_vars = extra_vars
self.variable_manager.options_vars = {'ansible_check_mode': self.options.check}
self.inventory = Inventory(loader=self.loader, variable_manager=self.variable_manager, host_list=inventory)
self.variable_manager.set_inventory(self.inventory)
# Limits inventory results to a subset of inventory that matches a given pattern
self.inventory._subset = self.options.subset
def run_playbook(self, playbook):
self.pbex = PlaybookExecutor(playbooks=[playbook], inventory=self.inventory,
variable_manager=self.variable_manager,
loader=self.loader, options=self.options,
passwords={'conn_pass': None, 'become_pass': None})
self.pbex._tqm._stdout_callback = ResultCallback()
return self.pbex.run()
def run_play(self, play):
pass
示例14: pbexe
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def pbexe(userid,serial,host,module,apppath,yaml,url=None):
variable_manager = VariableManager()
loader = DataLoader()
hostfile = '/ansible/hosts'
inventory = Inventory(loader=loader, variable_manager=variable_manager,host_list='/ansible/hosts')
playbook_path = yaml
if not os.path.exists(playbook_path):
print 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_extra_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=100, remote_user='root', private_key_file=None, ssh_common_args=None, ssh_extra_args=None, sftp_extra_args=None, scp_extra_args=None, become=True, become_method=None, become_user='root', verbosity=None, check=False)
variable_manager.extra_vars = {
'host': host,
'module': module,
'tomcat_root': apppath,
'url': url
} # This can accomodate various other command line arguments.`
passwords = {}
cb = CallbackModule(serial)
# cb = default.CallbackModule()
pbex = PlaybookExecutor( playbooks=[playbook_path], inventory=inventory, variable_manager=variable_manager, loader=loader, options=options, passwords=passwords)
pbex._tqm._stdout_callback = cb
results = pbex.run()
return results
示例15: run
# 需要導入模塊: from ansible.executor.playbook_executor import PlaybookExecutor [as 別名]
# 或者: from ansible.executor.playbook_executor.PlaybookExecutor import run [as 別名]
def run(self,mission_id,role_name,exe_group):
'''
create play with tasks actually run it
'''
tqm = None
try:
retry_path = '/etc/ansible/main.yml'
inventory_path = [retry_path]
self.results_callback = ResultCallback()
extra_vars = {}
extra_vars['host_list'] = exe_group
extra_vars['role_name'] = role_name
extra_vars['run_id'] = mission_id
self.variable_manager.extra_vars = extra_vars
pbex = PlaybookExecutor(
playbooks=inventory_path,
inventory=self.inventory,
variable_manager=self.variable_manager,
loader=self.loader,
options=self.options,
passwords=self.passwords,
)
pbex._tqm._stdout_callback = self.results_callback
result = pbex.run()
finally:
if tqm is not None:
tqm.cleanup()