Server : nginx/1.18.0 System : Linux localhost 6.14.3-x86_64-linode168 #1 SMP PREEMPT_DYNAMIC Mon Apr 21 19:47:55 EDT 2025 x86_64 User : www-data ( 33) PHP Version : 8.0.16 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, Directory : /usr/lib/python3/dist-packages/sos/report/plugins/ |
# 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, RedHatPlugin, UbuntuPlugin
import glob
class CephOSD(Plugin, RedHatPlugin, UbuntuPlugin):
short_desc = 'CEPH osd'
plugin_name = 'ceph_osd'
profiles = ('storage', 'virt', 'container')
containers = ('ceph-osd.*',)
def check_enabled(self):
return True if glob.glob('/var/lib/ceph/osd/*/*') else False
def setup(self):
self.add_file_tags({
'/var/log/ceph/ceph-osd.*.log': 'ceph_osd_log',
})
# Only collect OSD specific files
self.add_copy_spec([
"/var/log/ceph/ceph-osd*.log",
"/var/log/ceph/ceph-volume*.log",
"/var/lib/ceph/osd/",
"/var/lib/ceph/bootstrap-osd/",
"/run/ceph/ceph-osd*"
])
self.add_cmd_output([
"ceph-disk list",
"ceph-volume lvm list"
])
ceph_cmds = [
"bluestore bluefs available",
"config diff",
"config show",
"dump_blacklist",
"dump_blocked_ops",
"dump_historic_ops_by_duration",
"dump_historic_slow_ops",
"dump_mempools",
"dump_ops_in_flight",
"dump_op_pq_state",
"dump_osd_network",
"dump_reservations",
"dump_watchers",
"log dump",
"perf dump",
"perf histogram dump",
"objecter_requests",
"ops",
"status",
"version",
]
osd_ids = []
# Get the ceph user processes
out = self.exec_cmd('ps -u ceph -o args')
if out['status'] == 0:
# Extract the OSD ids from valid output lines
for procs in out['output'].splitlines():
proc = procs.split()
if len(proc) < 6:
continue
if proc[4] == '--id' and proc[5].isdigit():
osd_ids.append("osd.%s" % proc[5])
try:
cname = self.get_all_containers_by_regex("ceph-osd*")[0][1]
except Exception:
cname = None
self.add_cmd_output(
["ceph daemon %s %s" % (i, c) for i in osd_ids for c in ceph_cmds],
container=cname
)
self.add_forbidden_path([
"/etc/ceph/*keyring*",
"/var/lib/ceph/*keyring*",
"/var/lib/ceph/*/*keyring*",
"/var/lib/ceph/*/*/*keyring*",
"/var/lib/ceph/osd",
"/var/lib/ceph/mon",
# Excludes temporary ceph-osd mount location like
# /var/lib/ceph/tmp/mnt.XXXX from sos collection.
"/var/lib/ceph/tmp/*mnt*",
"/etc/ceph/*bindpass*"
])
# vim: set et ts=4 sw=4 :