관리-도구
편집 파일: collectd.py
# Copyright (C) 2016 Archit Sharma <archit.sh@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. import re from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin class Collectd(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin): """ Collectd config collector """ plugin_name = "collectd" profiles = ('services', 'webserver') # enable the plugin either when collectd package is installed # or being inside Super Proviledged Container that does not have # the package but logs to the host's logfile packages = ('collectd',) files = ('/var/log/containers/collectd/collectd.log') def setup(self): self.add_copy_spec([ '/etc/collectd.conf', '/etc/collectd.d/*.conf', '/var/log/containers/collectd/collectd.log', '/var/lib/config-data/collectd', ]) p = re.compile('^LoadPlugin.*') try: with open("/etc/collectd.conf") as f: for line in f: if p.match(line): self.add_alert("Active Plugin found: %s" % line.split()[-1]) except IOError as e: self._log_warn("could not open /etc/collectd.conf: %s" % e) def postproc(self): # add these to protect_keys if need be: # "Port", "[<]*Host", protect_keys = [ "Password", "User", "[<]*URL", "Address" ] regexp = r"((?m)^[#]*\s*(%s)\s* \s*)(.*)" % "|".join(protect_keys) self.do_path_regex_sub( "/etc/collectd.d/*.conf", regexp, r'\1"*********"' ) self.do_file_sub("/etc/collectd.conf", regexp, r'\1"*********"') # vim: set et ts=4 sw=4 :