]>
git.proxmox.com Git - pve-manager.git/blob - PVE/Report.pm
8 $ENV{'PATH'} = '/sbin:/bin:/usr/sbin:/usr/bin';
10 my $cmd_timeout = 10; # generous timeout
12 my $init_report_cmds = sub {
13 # NOTE: always add new sections to the report_order array!
16 title
=> 'general system info',
19 'pveversion --verbose',
21 'top -b -n 1 | head -n 15',
22 'pvesubscription get',
24 'pvesh get /cluster/resources --type node --output-format=yaml',
28 'cat /etc/pve/storage.cfg',
36 sub { dir2text
('/etc/pve/qemu-server/', '\d.*conf') },
38 sub { dir2text
('/etc/pve/lxc/', '\d.*conf') },
41 'ip -details -statistics address',
42 'ip -details -4 route show',
43 'ip -details -6 route show',
44 'cat /etc/network/interfaces',
47 sub { dir2text
('/etc/pve/firewall/', '.*fw') },
48 'cat /etc/pve/local/host.fw',
54 'cat /etc/pve/corosync.conf 2>/dev/null'
64 'ls -l /dev/disk/by-*/',
66 'iscsiadm -m session',
75 push @{$report_def->{volumes
}}, 'zpool status', 'zpool list -v', 'zfs list' if cmd_exists
('zfs');
77 if (-e
'/etc/ceph/ceph.conf') {
78 my $crbd = eval "`ceph osd pool ls | sed -e 's/^/echo /' | sed 'p;s/echo/rbd ls/g'`";
79 push @{$report_def->{volumes
}}, 'ceph status', 'ceph osd status', 'ceph df', 'pveceph status', 'pveceph lspools', $crbd;
82 push @{$report_def->{disk
}}, 'multipath -ll', 'multipath -v3' if cmd_exists
('multipath');
88 # output the content of all the files of a directory
90 my ($target_dir, $regexp) = @_;
92 PVE
::Tools
::dir_glob_foreach
($target_dir, $regexp, sub {
94 $report .= "\n# cat $target_dir$file\n";
95 $report .= PVE
::Tools
::file_get_contents
($target_dir.$file)."\n";
99 # command -v is the posix equivalent of 'which'
100 sub cmd_exists
{ system("command -v '$_[0]' > /dev/null 2>&1") == 0 }
104 my $report_def = $init_report_cmds->();
106 my @report_order = ('general', 'storage', 'virtual guests', 'network',
107 'firewall', 'cluster', 'bios', 'pci', 'disks', 'volumes');
110 my $record_output = sub {
111 $report .= shift . "\n";
114 my $run_cmd_params = {
115 outfunc
=> $record_output,
116 errfunc
=> $record_output,
117 timeout
=> $cmd_timeout,
118 noerr
=> 1, # avoid checking programs exit code
121 foreach my $section (@report_order) {
122 my $s = $report_def->{$section};
124 my $title = "info about $section";
127 if (ref($s) eq 'HASH') {
128 $commands = $s->{cmds
};
129 $title = $s->{title
} if defined($s->{title
});
130 } elsif (ref($s) ne 'ARRAY') {
131 die "unknown report definition in section '$section'!";
134 $report .= "\n==== $title ====\n";
135 foreach my $command (@$commands) {
137 if (ref $command eq 'CODE') {
138 PVE
::Tools
::run_with_timeout
($cmd_timeout, $command);
140 print STDERR
"Process ".$command."...";
141 $report .= "\n# $command\n";
142 PVE
::Tools
::run_command
($command, %$run_cmd_params);
147 $report .= "\nERROR: $@\n" if $@;