관리-도구
편집 파일: openstack_nova.py
# Copyright (C) 2009 Red Hat, Inc., Joey Boggs <jboggs@redhat.com> # Copyright (C) 2012 Rackspace US, Inc., # Justin Shepherd <jshepher@rackspace.com> # Copyright (C) 2013 Red Hat, Inc., Jeremy Agee <jagee@redhat.com> # Copyright (C) 2015 Red Hat, Inc., Abhijeet Kasurde <akasurde@redhat.com> # Copyright (C) 2017 Red Hat, Inc., Martin Schuppert <mschuppert@redhat.com> # This file is part of the sos project: https://github.com/sosreport/sos # # This copyrighted material is made available to anyone wishing to use, # modify, copy, or redistribute it subject to the terms and conditions of # version 2 of the GNU General Public License. # # See the LICENSE file in the source distribution for further information. from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin import os class OpenStackNova(Plugin): """OpenStack Nova """ plugin_name = "openstack_nova" profiles = ('openstack', 'openstack_controller', 'openstack_compute') var_puppet_gen = "/var/lib/config-data/puppet-generated/nova" def setup(self): # collect commands output only if the openstack-nova-api service # is running in_container = self.running_in_container() if self.is_service_running('openstack-nova-api') or in_container: nova_config = "" # if containerized we need to pass the config to the cont. if in_container: nova_config = "--config-dir " + self.var_puppet_gen + \ "/etc/nova/" self.add_cmd_output( "nova-manage " + nova_config + " db version", suggest_filename="nova-manage_db_version" ) self.add_cmd_output( "nova-manage " + nova_config + " fixed list", suggest_filename="nova-manage_fixed_list" ) self.add_cmd_output( "nova-manage " + nova_config + " floating list", suggest_filename="nova-manage_floating_list" ) vars_all = [p in os.environ for p in [ 'OS_USERNAME', 'OS_PASSWORD']] vars_any = [p in os.environ for p in [ 'OS_TENANT_NAME', 'OS_PROJECT_NAME']] if not (all(vars_all) and any(vars_any)): self.soslog.warning("Not all environment variables set. " "Source the environment file for the user " "intended to connect to the OpenStack " "environment.") else: self.add_cmd_output("nova service-list") self.add_cmd_output("openstack flavor list --long") self.add_cmd_output("nova network-list") self.add_cmd_output("nova list --all-tenants") self.add_cmd_output("nova agent-list") self.add_cmd_output("nova version-list") self.add_cmd_output("nova hypervisor-list") self.add_cmd_output("openstack quota show") self.add_cmd_output("openstack hypervisor stats show") # get details for each nova instance cmd = "openstack server list -f value" nova_instances = self.exec_cmd(cmd)['output'] for instance in nova_instances.splitlines(): instance = instance.split()[0] cmd = "openstack server show %s" % (instance) self.add_cmd_output( cmd, suggest_filename="instance-" + instance + ".log") if self.get_option("all_logs"): self.add_copy_spec([ "/var/log/nova/", ]) else: novadir = '/var/log/nova/' novalogs = [ "nova-api.log*", "nova-compute.log*", "nova-conductor.log*", "nova-manage.log*", "nova-placement-api.log*", "nova-scheduler.log*" ] for novalog in novalogs: self.add_copy_spec(os.path.join(novadir, novalog)) self.add_copy_spec([ "/etc/nova/", self.var_puppet_gen + "/etc/nova/", self.var_puppet_gen + "/etc/my.cnf.d/tripleo.cnf", self.var_puppet_gen + "/var/spool/cron/nova", self.var_puppet_gen + "/etc/httpd/conf/", self.var_puppet_gen + "/etc/httpd/conf.d/", self.var_puppet_gen + "/etc/httpd/conf.modules.d/*.conf", self.var_puppet_gen + "_placement/etc/nova/", self.var_puppet_gen + "_placement/etc/httpd/conf/", self.var_puppet_gen + "_placement/etc/httpd/conf.d/", self.var_puppet_gen + "_placement/etc/httpd/conf.modules.d/*.conf", self.var_puppet_gen + "_placement/etc/my.cnf.d/tripleo.cnf", self.var_puppet_gen + "/../memcached/etc/sysconfig/memcached", self.var_puppet_gen + "_libvirt/etc/libvirt/", self.var_puppet_gen + "_libvirt/etc/my.cnf.d/tripleo.cnf", self.var_puppet_gen + "_libvirt/etc/nova/", self.var_puppet_gen + "_libvirt/etc/nova/migration/" "authorized_keys", self.var_puppet_gen + "_libvirt/var/lib/nova/.ssh/config", ]) def running_in_container(self): for runtime in ["docker", "podman"]: container_status = self.exec_cmd(runtime + " ps") if container_status['status'] == 0: for line in container_status['output'].splitlines(): if line.endswith("nova_api"): return True return False def apply_regex_sub(self, regexp, subst): self.do_path_regex_sub("/etc/nova/*", regexp, subst) self.do_path_regex_sub( self.var_puppet_gen + "/etc/nova/*", regexp, subst ) self.do_path_regex_sub( self.var_puppet_gen + "_placement/etc/nova/*", regexp, subst ) self.do_path_regex_sub( self.var_puppet_gen + "_libvirt/etc/nova/*", regexp, subst ) def postproc(self): protect_keys = [ "ldap_dns_password", "neutron_admin_password", "rabbit_password", "qpid_password", "powervm_mgr_passwd", "virtual_power_host_pass", "xenapi_connection_password", "password", "host_password", "vnc_password", "admin_password", "connection_password", "memcache_secret_key", "s3_secret_key", "metadata_proxy_shared_secret", "fixed_key", "transport_url" ] connection_keys = ["connection", "sql_connection"] self.apply_regex_sub( r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys), r"\1*********" ) self.apply_regex_sub( r"((?m)^\s*(%s)\s*=\s*(.*)://(\w*):)(.*)(@(.*))" % "|".join(connection_keys), r"\1*********\6" ) class DebianNova(OpenStackNova, DebianPlugin, UbuntuPlugin): nova = False packages = ( 'nova-api-ec2', 'nova-api-metadata', 'nova-api-os-compute', 'nova-api-os-volume', 'nova-common', 'nova-compute', 'nova-compute-kvm', 'nova-compute-lxc', 'nova-compute-qemu', 'nova-compute-uml', 'nova-compute-xcp', 'nova-compute-xen', 'nova-xcp-plugins', 'nova-consoleauth', 'nova-network', 'nova-scheduler', 'nova-volume', 'novnc', 'python-nova', 'python-novaclient', 'python-novnc' ) def setup(self): super(DebianNova, self).setup() self.add_copy_spec([ "/etc/sudoers.d/nova_sudoers", "/usr/share/polkit-1/rules.d/60-libvirt.rules", ]) class RedHatNova(OpenStackNova, RedHatPlugin): nova = False packages = ('openstack-selinux',) def setup(self): super(RedHatNova, self).setup() self.add_copy_spec([ "/etc/logrotate.d/openstack-nova", "/etc/polkit-1/localauthority/50-local.d/50-nova.pkla", "/etc/sudoers.d/nova", "/etc/security/limits.d/91-nova.conf", "/etc/sysconfig/openstack-nova-novncproxy" ]) if self.get_option("all_logs"): self.add_copy_spec([ "/var/log/httpd/nova_api*", "/var/log/httpd/placement*", ]) else: self.add_copy_spec([ "/var/log/httpd/nova_api*.log", "/var/log/httpd/placement*.log", ]) # vim: set et ts=4 sw=4 :