| Server IP : 127.0.1.1 / Your IP : 216.73.216.152 Web Server : Apache/2.4.52 (Ubuntu) System : Linux bahcrestlinepropertiesllc 5.15.0-113-generic #123-Ubuntu SMP Mon Jun 10 08:16:17 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /proc/2792863/root/lib/python3/dist-packages/sos/report/plugins/ |
Upload File : |
# 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.report.plugins import Plugin, IndependentPlugin
class RabbitMQ(Plugin, IndependentPlugin):
short_desc = 'RabbitMQ messaging service'
plugin_name = 'rabbitmq'
profiles = ('services',)
var_puppet_gen = "/var/lib/config-data/puppet-generated/rabbitmq"
files = (
'/etc/rabbitmq/rabbitmq.conf',
var_puppet_gen + '/etc/rabbitmq/rabbitmq.config'
)
packages = ('rabbitmq-server',)
def setup(self):
in_container = False
container_names = []
_containers = self.get_containers()
for _con in _containers:
if _con[1].startswith('rabbitmq'):
in_container = True
container_names.append(_con[1])
if in_container:
for container in container_names:
self.add_container_logs(container)
self.add_cmd_output(
'rabbitmqctl report',
container=container,
foreground=True,
tags="rabbitmq_report"
)
self.add_cmd_output(
"rabbitmqctl eval 'rabbit_diagnostics:maybe_stuck().'",
container=container,
foreground=True,
timeout=10
)
else:
self.add_cmd_output("rabbitmqctl report")
self.add_cmd_output(
"rabbitmqctl eval 'rabbit_diagnostics:maybe_stuck().'",
timeout=10)
self.add_copy_spec([
"/etc/rabbitmq/*",
self.var_puppet_gen + "/etc/rabbitmq/*",
self.var_puppet_gen + "/etc/security/limits.d/",
self.var_puppet_gen + "/etc/systemd/"
])
self.add_copy_spec([
"/var/log/rabbitmq/*",
])
self.add_file_tags({
"/var/log/rabbitmq/rabbit@.*[^-sasl].log": "rabbitmq_logs",
"/var/log/rabbitmq/startup_err": "rabbitmq_startup_err"
})
# Crash dump can be large in some situation but it is useful to
# investigate why rabbitmq crashes. So capture the file without
# sizelimit
self.add_copy_spec([
"/var/log/containers/rabbitmq/erl_crash.dump"
], sizelimit=0)
def postproc(self):
self.do_file_sub("/etc/rabbitmq/rabbitmq.conf",
r"(\s*default_pass\s*,\s*)\S+", r"\1<<***>>},")
# vim: set et ts=4 sw=4 :