]>
git.proxmox.com Git - pve-manager.git/blob - PVE/Report.pm
8 # output the content of all the files of a directory
10 my ($target_dir, $regexp) = @_;
12 print STDERR
"dir2text '${target_dir}${regexp}'...";
13 my $text = "# output '${target_dir}${regexp}' file(s)\n";
14 PVE
::Tools
::dir_glob_foreach
($target_dir, $regexp, sub {
16 return if $file eq '.' || $file eq '..';
17 $text .= "\n# cat $target_dir$file\n";
18 $text .= PVE
::Tools
::file_get_contents
($target_dir.$file)."\n";
23 # command -v is the posix equivalent of 'which'
24 my sub cmd_exists
{ system("command -v '$_[0]' > /dev/null 2>&1") == 0 }
26 my $init_report_cmds = sub {
29 title
=> 'general system info',
35 'pveversion --verbose',
37 'pvesubscription get',
38 'cat /etc/apt/sources.list',
39 sub { dir2text
('/etc/apt/sources.list.d/', '.+\.list') },
40 sub { dir2text
('/etc/apt/sources.list.d/', '.+\.sources') },
41 'apt-cache policy | grep -vP "^ +origin "',
44 'pvesh get /cluster/resources --type node --output-format=yaml',
48 title
=> 'overall system load info',
51 'top -b -c -w512 -n 1 -o TIME | head -n 30',
52 'head /proc/pressure/*',
58 'cat /etc/pve/storage.cfg',
63 'proxmox-boot-tool status',
70 sub { dir2text
('/etc/pve/qemu-server/', '\d+\.conf') },
72 sub { dir2text
('/etc/pve/lxc/', '\d+\.conf') },
78 'ip -details -statistics address',
79 'ip -details -4 route show',
80 'ip -details -6 route show',
81 'cat /etc/network/interfaces',
82 sub { dir2text
('/etc/network/interfaces.d/', '.*') },
83 sub { dir2text
('/etc/pve/sdn/', '.*') },
89 sub { dir2text
('/etc/pve/firewall/', '.+\.fw') },
90 'cat /etc/pve/local/host.fw',
91 'iptables-save -c | column -t -l4 -o" "',
99 'cat /etc/pve/corosync.conf 2>/dev/null',
101 'cat /etc/pve/datacenter.cfg',
107 'cat /etc/pve/jobs.cfg',
120 'lsblk --ascii -M -o +HOTPLUG,ROTA,PHY-SEC,FSTYPE,MODEL,TRAN',
121 'ls -l /dev/disk/by-*/',
123 'iscsiadm -m session',
136 if (cmd_exists
('zfs')) {
137 push @{$report_def->{volumes
}->{cmds
}},
145 if (-e
'/etc/ceph/ceph.conf') {
146 push @{$report_def->{volumes
}->{cmds
}},
152 'cat /etc/ceph/ceph.conf',
156 'ceph health detail',
160 if (cmd_exists
('multipath')) {
161 push @{$report_def->{disks
}->{cmds
}},
162 'cat /etc/multipath.conf',
163 'cat /etc/multipath/wwids',
172 my $def = $init_report_cmds->();
175 my $record_output = sub {
176 $report .= shift . "\n";
179 local $ENV{'PATH'} = '/sbin:/bin:/usr/sbin:/usr/bin';
180 my $cmd_timeout = 10; # generous timeout
182 my $run_cmd_params = {
183 outfunc
=> $record_output,
184 errfunc
=> $record_output,
185 timeout
=> $cmd_timeout,
186 noerr
=> 1, # avoid checking programs exit code
189 my $sorter = sub { ($def->{$_[0]}->{order
} // 1<<30) <=> ($def->{$_[1]}->{order} // 1<<30) };
191 for my $section ( sort { $sorter->($a, $b) } keys %$def) {
192 my $s = $def->{$section};
193 my $title = $s->{title
} // "info about $section";
195 $report .= "\n==== $title ====\n";
196 for my $command (@{$s->{cmds
}}) {
198 if (ref $command eq 'CODE') {
199 $report .= PVE
::Tools
::run_with_timeout
($cmd_timeout, $command);
201 print STDERR
"Process ".$command."...";
202 $report .= "\n# $command\n";
203 PVE
::Tools
::run_command
($command, %$run_cmd_params);
208 $report .= "\nERROR: $@\n" if $@;