| Server IP : 54.233.248.239 / Your IP : 172.28.1.13 Web Server : Apache System : Linux ip-172-28-29-189 6.5.0-1014-aws #14~22.04.1-Ubuntu SMP Thu Feb 15 15:27:06 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.2.34-43+ubuntu22.04.1+deb.sury.org+1 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, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /usr/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, RedHatPlugin
class Lustre(Plugin, RedHatPlugin):
short_desc = 'Lustre filesystem'
plugin_name = 'lustre'
profiles = ('storage', 'network', 'cluster', )
packages = ('lustre', 'lustre-client', )
def get_params(self, name, param_list):
"""Use lctl get_param to collect a selection of parameters into a
file.
"""
self.add_cmd_output("lctl get_param %s" % " ".join(param_list),
suggest_filename="params-%s" % name,
stderr=False)
def setup(self):
self.add_cmd_output([
"lctl debug_kernel",
"lctl device_list",
"lctl list_nids",
"lctl route_list",
"lnetctl net show -v"
])
self.get_params(
"basic",
["version", "health_check", "debug", "timeout"]
)
self.get_params("lnet", ["peers", "routes", "routers", "nis"])
self.get_params(
"ldlm-lru",
["ldlm.namespaces.*.lru_max_age", "ldlm.namespaces.*.lru_size"]
)
self.get_params("ldlm-states", ["*.*.state"])
self.get_params("jobid", ["jobid_name", "jobid_var"])
self.get_params("job-stats", ["*.*.job_stats"])
self.get_params("server_uuids", ["*.*.*server_uuid"])
self.get_params("mgc_irstate", ["mgc.*.ir_state"])
# Client Specific
self.add_cmd_output([
"lfs df",
"lfs df -i"
])
self.get_params("osc_client", [
"osc.*.max_dirty_mb",
"osc.*.max_pages_per_rpc",
"osc.*.checksums",
"osc.*.max_rpcs_in_flight"
])
# Server Specific
self.get_params("osd", ["osd-*.*.{mntdev,files*," +
"kbytes*,blocksize,brw_stats}"])
self.get_params("quota", ["osd-*.*.quota_slave." +
"{info,limit_*,acct_*}"])
self.get_params("mgs", ["mgs.MGS.ir_timeout", "mgs.MGS.live.*"])
self.get_params("exports", ["*.*.exports.*.*"])
self.get_params("mntdev", ["osd*.*.mntdev"])
# mb_groups can be VERY large, and provide minimal debug usefulness
self.add_forbidden_path("*/mb_groups")
self.add_copy_spec([
"/sys/fs/ldiskfs",
"/proc/fs/ldiskfs",
])
# Grab emergency ring buffer dumps
if self.get_option("all_logs"):
self.add_copy_spec("/tmp/lustre-log.*")
# vim: set et ts=4 sw=4 :