[pve-devel] [PATCH pve-common 1/1] ProcFSTools: add read_pressure
Alexandre Derumier
aderumier at odiso.com
Sun Oct 11 10:23:38 CEST 2020
Hi,
I have notice that it's possible to get pressure info for each vm/ct
through cgroups
/sys/fs/cgroup/unified/qemu.slice/<vmid>.scope/cpu.pressure
/sys/fs/cgroup/unified/lxc/<vmid>/cpu.pressure
Maybe it could be great to have some new rrd graphs for each vm/ct ?
They are very useful counters to known a specific vm/ct is overloaded
Le mar. 6 oct. 2020 à 13:58, Alexandre Derumier <aderumier at odiso.com> a
écrit :
> read new /proc/pressure/(cpu,disk,io) introduced in kernel 4.20.
>
> This give more granular informations than loadaverage.
>
> Signed-off-by: Alexandre Derumier <aderumier at odiso.com>
> ---
> src/PVE/ProcFSTools.pm | 18 ++++++++++++++++++
> 1 file changed, 18 insertions(+)
>
> diff --git a/src/PVE/ProcFSTools.pm b/src/PVE/ProcFSTools.pm
> index 7cf1472..7687c13 100644
> --- a/src/PVE/ProcFSTools.pm
> +++ b/src/PVE/ProcFSTools.pm
> @@ -132,6 +132,24 @@ sub read_loadavg {
> return wantarray ? (0, 0, 0) : 0;
> }
>
> +sub read_pressure {
> +
> + my $res = {};
> + foreach my $type (qw(cpu memory io)) {
> + if (my $fh = IO::File->new ("/proc/pressure/$type", "r")) {
> + while (defined (my $line = <$fh>)) {
> + if ($line =~
> /^(some|full)\s+avg10\=(\d+\.\d+)\s+avg60\=(\d+\.\d+)\s+avg300\=(\d+\.\d+)\s+total\=(\d+)/)
> {
> + $res->{$type}->{$1}->{avg10} = $2;
> + $res->{$type}->{$1}->{avg60} = $3;
> + $res->{$type}->{$1}->{avg300} = $4;
> + }
> + }
> + $fh->close;
> + }
> + }
> + return $res;
> +}
> +
> my $last_proc_stat;
>
> sub read_proc_stat {
> --
> 2.20.1
>
>
More information about the pve-devel
mailing list