當前位置: 首頁>>代碼示例>>Python>>正文


Python exceptions.CommandExecutionError方法代碼示例

本文整理匯總了Python中salt.exceptions.CommandExecutionError方法的典型用法代碼示例。如果您正苦於以下問題:Python exceptions.CommandExecutionError方法的具體用法?Python exceptions.CommandExecutionError怎麽用?Python exceptions.CommandExecutionError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在salt.exceptions的用法示例。


在下文中一共展示了exceptions.CommandExecutionError方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _get_top_data

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def _get_top_data(topfile):
    '''
    Helper method to retrieve and parse the nova topfile
    '''
    topfile = os.path.join(_hubble_dir()[1], topfile)

    try:
        with open(topfile) as handle:
            topdata = yaml.safe_load(handle)
    except Exception as e:
        raise CommandExecutionError('Could not load topfile: {0}'.format(e))

    if not isinstance(topdata, dict) or 'nova' not in topdata or \
            not(isinstance(topdata['nova'], dict)):
        raise CommandExecutionError('Nova topfile not formatted correctly')

    topdata = topdata['nova']

    ret = []

    for match, data in topdata.iteritems():
        if __salt__['match.compound'](match):
            ret.extend(data)

    return ret 
開發者ID:hubblestack,項目名稱:nova,代碼行數:27,代碼來源:hubble.py

示例2: get_top_data

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def get_top_data(topfile):

    topfile = __salt__['cp.cache_file'](topfile)

    try:
        with open(topfile) as handle:
            topdata = yaml.safe_load(handle)
    except Exception as e:
        raise CommandExecutionError('Could not load topfile: {0}'.format(e))

    if not isinstance(topdata, dict) or 'nebula' not in topdata or \
            not(isinstance(topdata['nebula'], dict)):
        raise CommandExecutionError('Nebula topfile not formatted correctly')

    topdata = topdata['nebula']

    ret = []

    for match, data in topdata.iteritems():
        if __salt__['match.compound'](match):
            ret.extend(data)

    return ret 
開發者ID:hubblestack,項目名稱:hubble-salt,代碼行數:25,代碼來源:nebula_osquery.py

示例3: get_passwd_raw

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def get_passwd_raw():
    '''
    Return the raw content of the file /etc/passwd

    CLI Example:

        .. code-block:: bash

            salt '*' account.get_passwd_raw
    '''
    file_user = '/etc/passwd'
    try:
        with salt.utils.fopen(file_user, 'r') as fp_:
            content = [line for line in fp_]
    except:
        raise CommandExecutionError(
            'An error has occurred while reading {0}'.format(file_user)
        )
    return content 
開發者ID:madrisan,項目名稱:saltstack-code-snippets,代碼行數:21,代碼來源:account.py

示例4: cluster_local_node_status

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def cluster_local_node_status():
    '''
    Return the status of the local cluster member.

    CLI Example:

        .. code-block:: bash

            salt '*' pacemaker.cluster_local_node_status
    '''
    try:
        node_status = lib_pacemaker.get_local_node_status(
            utils.cmd_runner()
        )
    except LibraryError as e:
        raise CommandExecutionError('Unable to get node status: {0}'.format(
            '\n'.join([item.message for item in e.args]))
        )
    return node_status 
開發者ID:madrisan,項目名稱:saltstack-code-snippets,代碼行數:21,代碼來源:pacemaker.py

示例5: get_passwd_data

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def get_passwd_data(ssh_client, target):
    '''
    Return a dictionary containing the data found in the file /etc/passwd.
    (key = username, value = the raw line of the corresponding user)
    '''
    tokens = ('username', 'passwd', 'uid', 'gid', 'gecos', 'homedir', 'shell')
    User = namedtuple('User', tokens)
    try:
        passwd_raw = saltstack_module_run(
            ssh_client, target, 'account.get_passwd_raw')
        user_infos = list(User(*line.rstrip().split(':'))
            for line in passwd_raw)
    except:
        raise CommandExecutionError(
            'An error has occurred while reading {0}'.format(filename)
        )
    def _pack_data(user):
        return '{0}:{1}:{2}:{3}:{4}:{5}'.format(
            user.username,
            user.uid,
            user.gid,
            user.gecos,
            user.homedir,
            user.shell)
    return dict((user.username, _pack_data(user)) for user in user_infos) 
開發者ID:madrisan,項目名稱:saltstack-code-snippets,代碼行數:27,代碼來源:check_account.py

示例6: get_top_data

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def get_top_data(topfile):

    topfile = __salt__['cp.cache_file'](topfile)

    try:
        with open(topfile) as handle:
            topdata = yaml.safe_load(handle)
    except Exception as e:
        raise CommandExecutionError('Could not load topfile: {0}'.format(e))

    if not isinstance(topdata, dict) or 'pulsar' not in topdata or \
            not(isinstance(topdata['pulsar'], dict)):
        raise CommandExecutionError('Pulsar topfile not formatted correctly')

    topdata = topdata['pulsar']

    ret = []

    for match, data in topdata.iteritems():
        if __salt__['match.compound'](match):
            ret.extend(data)

    return ret 
開發者ID:hubblestack,項目名稱:hubble,代碼行數:25,代碼來源:pulsar.py

示例7: _cmd_and_result

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def _cmd_and_result(*args, **kwargs):
  cmd = _helm_cmd(*args, **kwargs)
  env_string = "".join(['%s="%s" ' % (k, v) for (k, v) in cmd.get('env', {}).items()])
  cmd_string = env_string + " ".join(cmd['cmd'])
  result = None
  try:
    result = __salt__['cmd.run_all'](**cmd)
    if result['retcode'] != 0:
      raise CommandExecutionError(result['stderr'])
    return {
      'cmd': cmd_string,
      'stdout': result['stdout'],
      'stderr': result['stderr']
    }
  except CommandExecutionError as e:
    raise HelmExecutionError(cmd_string, e) 
開發者ID:salt-formulas,項目名稱:salt-formula-helm,代碼行數:18,代碼來源:helm.py

示例8: test_no_config_file

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def test_no_config_file(self):
        config_file = "/etc/sysconfig/openattic"
        with self.assertRaises(CommandExecutionError) as ctx:
            openattic.configure_grafana("grafana.localhost")
        self.assertEqual(str(ctx.exception),
                         "No openATTIC config file found in the following locations: "
                         "('/etc/default/openattic', '/etc/sysconfig/openattic')") 
開發者ID:SUSE,項目名稱:DeepSea,代碼行數:9,代碼來源:test_openattic.py

示例9: _select_config_file_path

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def _select_config_file_path():
    """
    Return an openATTIC configuration pathname
    """
    possible_paths = ("/etc/default/openattic", "/etc/sysconfig/openattic")
    for path in possible_paths:
        if os.access(path, os.F_OK) and os.access(path, os.R_OK | os.W_OK):
            return path
    raise CommandExecutionError(
        ("No openATTIC config file found in the following locations: "
         "{}".format(possible_paths))) 
開發者ID:SUSE,項目名稱:DeepSea,代碼行數:13,代碼來源:openattic.py

示例10: get_group_list

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def get_group_list():
    '''
    Return the list of the groups configured in /etc/group

    CLI Example:

        .. code-block:: bash

            salt '*' account.get_group_list
    '''
    file_group = '/etc/group'
    tokens = ('groupname', 'passwd', 'gid', 'grouplist')
    Group = namedtuple('Group', tokens)
    try:
        with salt.utils.fopen(file_group, 'r') as fp_:
            group_infos = list(Group(*line.split(':')) for line in fp_)
    except:
        raise CommandExecutionError(
            'An error has occurred while reading {0}'.format(file_group)
        )

    def _secondary_groups(group):
        grouplist = group.grouplist.strip()
        return grouplist.split(',') if len(grouplist) > 0 else ''
    def _pack_data(group):
        secgroups = _secondary_groups(group)
        return dict(
            gid = int(group.gid), grouplist = secgroups
        ) if secgroups else dict(gid = int(group.gid))
    return dict((group.groupname, _pack_data(group)) for group in group_infos) 
開發者ID:madrisan,項目名稱:saltstack-code-snippets,代碼行數:32,代碼來源:account.py

示例11: get_user_list

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def get_user_list():
    '''
    Return the list of the users configured in /etc/passwd

    CLI Example:

        .. code-block:: bash

            salt '*' account.get_user_list
    '''
    file_user = '/etc/passwd'
    tokens = ('username', 'passwd', 'uid', 'gid', 'gecos', 'homedir', 'shell')
    User = namedtuple('User', tokens)
    try:
        with salt.utils.fopen(file_user, 'r') as fp_:
            user_infos = list(User(*line.rstrip().split(':')) for line in fp_)
    except:
        raise CommandExecutionError(
            'An error has occurred while reading {0}'.format(file_user)
        )

    def _pack_data(user):
        return dict(
            uid = int(user.uid),
            gid = int(user.gid),
            gecos = user.gecos,
            homedir = user.homedir,
            shell = user.shell)
    return dict((user.username, _pack_data(user)) for user in user_infos) 
開發者ID:madrisan,項目名稱:saltstack-code-snippets,代碼行數:31,代碼來源:account.py

示例12: get_service_list

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def get_service_list():
    '''
    Return the list of the services configured in /etc/services

    CLI Example:

        .. code-block:: bash

            salt '*' service_iana.get_service_list

    '''
    toks = ('name', 'port')
    Service = collections.namedtuple('Service', toks)
    skip_line = lambda line: line.lstrip().startswith('#') or not line.strip()

    service_infos = []
    try:
        with salt.utils.fopen(file_services, 'r') as fp_:
            # just take the first two tokens and ignore the comment (if any)
            service_infos = [Service(*line.split()[:2]) for line in fp_
                if not skip_line(line)]
    except:
        raise CommandExecutionError(
            'An error has occurred while reading {0} at line\n{1}'.format(
                file_services, line)
        )

    return dict([
        (service.port, {
            'name': service.name,
            'port': service.port.split('/')[0],
            'protocol': service.port.split('/')[1]
        }) for service in service_infos]) 
開發者ID:madrisan,項目名稱:saltstack-code-snippets,代碼行數:35,代碼來源:service_iana.py

示例13: cluster_resources

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def cluster_resources():
    '''
    Return the cluster status resources.

    CLI Example:

        .. code-block:: bash

            salt '*' pacemaker.cluster_resources
    '''
    info_dom = utils.getClusterState()
    resources = info_dom.getElementsByTagName('resources')
    if resources.length == 0:
        raise CommandExecutionError('No resources section found')

    def _pack_data(resource):
        nodes = resource.getElementsByTagName('node')
        node = list(node.getAttribute('name')
                   for node in nodes if nodes.length > 0)
        resource_agent = resource.getAttribute('resource_agent')
        resource_id = resource.getAttribute('id')
        role = resource.getAttribute('role')
        return (resource_id, dict(
                resource_agent = resource_agent,
                role = role,
                node = node[0] if len(node) == 1 else node))

    return dict(_pack_data(resource)
        for resource in resources[0].getElementsByTagName('resource')) 
開發者ID:madrisan,項目名稱:saltstack-code-snippets,代碼行數:31,代碼來源:pacemaker.py

示例14: lscpu

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def lscpu(*args):
    '''
    Return the number of core, logical, and CPU sockets, by parsing
    the lscpu command and following back to /proc/cpuinfo when this tool
    is not available.

    CLI Example:

        .. code-block:: bash

            salt '*' cpuinfo.lscpu
            salt '*' cpuinfo.lscpu logicals
    '''
    (cpus, sockets, cores) = _lscpu() or _proc()

    infos = {
        'cores': cores,
        'logicals': cpus,
        'sockets': sockets
    }

    if not args:
        return infos

    try:
        ret = dict((arg, infos[arg]) for arg in args)
    except:
        raise CommandExecutionError(
            'Invalid flag passed to {0}.proc'.format(__virtualname__)
        )
    return ret 
開發者ID:madrisan,項目名稱:saltstack-code-snippets,代碼行數:33,代碼來源:cpuinfo.py

示例15: get_users_infos

# 需要導入模塊: from salt import exceptions [as 別名]
# 或者: from salt.exceptions import CommandExecutionError [as 別名]
def get_users_infos(ssh_client, target, users):
    '''
    Return a dictionary containing the system informations for
    the list of users 'users'.
    '''
    all_groups = saltstack_module_run(
        ssh_client, target, 'account.get_group_list')
    group_names = all_groups.keys()

    def _pack_data(user):
        data = saltstack_module_run(
            ssh_client, target, 'user.info', [user])
        if not data:
            raise CommandExecutionError(
                'Unable to find the user: {0}'.format(user))
        gid = data['gid']
        groups = [grp for grp in group_names if all_groups[grp]['gid'] == gid]
        secgroups = [grp for grp in data['groups'] if grp not in groups]

        return dict(
            group = ','.join(groups),
            shell = data['shell'],
            home = data['home'],
            secgroups = ','.join(secgroups),
        )

    return dict((user, _pack_data(user)) for user in users) 
開發者ID:madrisan,項目名稱:saltstack-code-snippets,代碼行數:29,代碼來源:check_account.py


注:本文中的salt.exceptions.CommandExecutionError方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。