* [pve-devel] [PATCH container] vm status: force int where appropriate
@ 2021-05-31 14:37 Fabian Ebner
2021-05-31 14:37 ` [pve-devel] [PATCH qemu-server] " Fabian Ebner
2021-06-01 6:07 ` [pve-devel] [PATCH container] " Fabian Ebner
0 siblings, 2 replies; 3+ messages in thread
From: Fabian Ebner @ 2021-05-31 14:37 UTC (permalink / raw)
To: pve-devel
In the case of a running container with cgroupv2, swap would be a string,
causing a
size.toFixed is not a function
error for the format_size call in the containers's "Summary" page in the UI.
The 'vmid' is still a string, because the property is injected via the 'links'
property in the return type schema.
Signed-off-by: Fabian Ebner <f.ebner@proxmox.com>
---
src/PVE/LXC.pm | 14 +++++++-------
1 file changed, 7 insertions(+), 7 deletions(-)
diff --git a/src/PVE/LXC.pm b/src/PVE/LXC.pm
index bb1cbdb..1ec4818 100644
--- a/src/PVE/LXC.pm
+++ b/src/PVE/LXC.pm
@@ -187,7 +187,7 @@ sub vmstatus {
foreach my $vmid (keys %$list) {
my $d = $list->{$vmid};
- eval { $d->{pid} = find_lxc_pid($vmid) if defined($active_hash->{$vmid}); };
+ eval { $d->{pid} = int(find_lxc_pid($vmid)) if defined($active_hash->{$vmid}); };
warn $@ if $@; # ignore errors (consider them stopped)
$d->{status} = $active_hash->{$vmid} ? 'running' : 'stopped';
@@ -207,8 +207,8 @@ sub vmstatus {
if ($d->{pid}) {
my $res = get_container_disk_usage($vmid, $d->{pid});
- $d->{disk} = $res->{used};
- $d->{maxdisk} = $res->{total};
+ $d->{disk} = int($res->{used});
+ $d->{maxdisk} = int($res->{total});
} else {
$d->{disk} = 0;
# use 4GB by default ??
@@ -252,16 +252,16 @@ sub vmstatus {
my $cgroups = PVE::LXC::CGroup->new($vmid);
if (defined(my $mem = $cgroups->get_memory_stat())) {
- $d->{mem} = $mem->{mem};
- $d->{swap} = $mem->{swap};
+ $d->{mem} = int($mem->{mem});
+ $d->{swap} = int($mem->{swap});
} else {
$d->{mem} = 0;
$d->{swap} = 0;
}
if (defined(my $blkio = $cgroups->get_io_stats())) {
- $d->{diskread} = $blkio->{diskread};
- $d->{diskwrite} = $blkio->{diskwrite};
+ $d->{diskread} = int($blkio->{diskread});
+ $d->{diskwrite} = int($blkio->{diskwrite});
} else {
$d->{diskread} = 0;
$d->{diskwrite} = 0;
--
2.30.2
^ permalink raw reply [flat|nested] 3+ messages in thread
* [pve-devel] [PATCH qemu-server] vm status: force int where appropriate
2021-05-31 14:37 [pve-devel] [PATCH container] vm status: force int where appropriate Fabian Ebner
@ 2021-05-31 14:37 ` Fabian Ebner
2021-06-01 6:07 ` [pve-devel] [PATCH container] " Fabian Ebner
1 sibling, 0 replies; 3+ messages in thread
From: Fabian Ebner @ 2021-05-31 14:37 UTC (permalink / raw)
To: pve-devel
to avoid potential problems with stringified numbers in Javascript and
elsewehere.
The 'vmid' is still a string, because the property is injected via the 'links'
property in the return type schema.
Signed-off-by: Fabian Ebner <f.ebner@proxmox.com>
---
PVE/QemuServer.pm | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/PVE/QemuServer.pm b/PVE/QemuServer.pm
index 25ac052..2cad00b 100644
--- a/PVE/QemuServer.pm
+++ b/PVE/QemuServer.pm
@@ -2652,7 +2652,7 @@ sub vmstatus {
my $conf = PVE::QemuConfig->load_config($vmid);
my $d = { vmid => $vmid };
- $d->{pid} = $list->{$vmid}->{pid};
+ $d->{pid} = int($list->{$vmid}->{pid});
# fixme: better status?
$d->{status} = $list->{$vmid}->{pid} ? 'running' : 'stopped';
@@ -2711,8 +2711,8 @@ sub vmstatus {
$d->{netin} += $netdev->{$dev}->{transmit};
if ($full) {
- $d->{nics}->{$dev}->{netout} = $netdev->{$dev}->{receive};
- $d->{nics}->{$dev}->{netin} = $netdev->{$dev}->{transmit};
+ $d->{nics}->{$dev}->{netout} = int($netdev->{$dev}->{receive});
+ $d->{nics}->{$dev}->{netin} = int($netdev->{$dev}->{transmit});
}
}
--
2.30.2
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [pve-devel] [PATCH container] vm status: force int where appropriate
2021-05-31 14:37 [pve-devel] [PATCH container] vm status: force int where appropriate Fabian Ebner
2021-05-31 14:37 ` [pve-devel] [PATCH qemu-server] " Fabian Ebner
@ 2021-06-01 6:07 ` Fabian Ebner
1 sibling, 0 replies; 3+ messages in thread
From: Fabian Ebner @ 2021-06-01 6:07 UTC (permalink / raw)
To: pve-devel
Am 31.05.21 um 16:37 schrieb Fabian Ebner:
> In the case of a running container with cgroupv2, swap would be a string,
> causing a
> size.toFixed is not a function
> error for the format_size call in the containers's "Summary" page in the UI.
>
> The 'vmid' is still a string, because the property is injected via the 'links'
> property in the return type schema.
This is false, I missed where the vmid is assigned...
I'll send a v2, sorry for the noise.
>
> Signed-off-by: Fabian Ebner <f.ebner@proxmox.com>
> ---
> src/PVE/LXC.pm | 14 +++++++-------
> 1 file changed, 7 insertions(+), 7 deletions(-)
>
> diff --git a/src/PVE/LXC.pm b/src/PVE/LXC.pm
> index bb1cbdb..1ec4818 100644
> --- a/src/PVE/LXC.pm
> +++ b/src/PVE/LXC.pm
> @@ -187,7 +187,7 @@ sub vmstatus {
> foreach my $vmid (keys %$list) {
> my $d = $list->{$vmid};
>
> - eval { $d->{pid} = find_lxc_pid($vmid) if defined($active_hash->{$vmid}); };
> + eval { $d->{pid} = int(find_lxc_pid($vmid)) if defined($active_hash->{$vmid}); };
> warn $@ if $@; # ignore errors (consider them stopped)
>
> $d->{status} = $active_hash->{$vmid} ? 'running' : 'stopped';
> @@ -207,8 +207,8 @@ sub vmstatus {
>
> if ($d->{pid}) {
> my $res = get_container_disk_usage($vmid, $d->{pid});
> - $d->{disk} = $res->{used};
> - $d->{maxdisk} = $res->{total};
> + $d->{disk} = int($res->{used});
> + $d->{maxdisk} = int($res->{total});
> } else {
> $d->{disk} = 0;
> # use 4GB by default ??
> @@ -252,16 +252,16 @@ sub vmstatus {
> my $cgroups = PVE::LXC::CGroup->new($vmid);
>
> if (defined(my $mem = $cgroups->get_memory_stat())) {
> - $d->{mem} = $mem->{mem};
> - $d->{swap} = $mem->{swap};
> + $d->{mem} = int($mem->{mem});
> + $d->{swap} = int($mem->{swap});
> } else {
> $d->{mem} = 0;
> $d->{swap} = 0;
> }
>
> if (defined(my $blkio = $cgroups->get_io_stats())) {
> - $d->{diskread} = $blkio->{diskread};
> - $d->{diskwrite} = $blkio->{diskwrite};
> + $d->{diskread} = int($blkio->{diskread});
> + $d->{diskwrite} = int($blkio->{diskwrite});
> } else {
> $d->{diskread} = 0;
> $d->{diskwrite} = 0;
>
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2021-06-01 6:07 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-05-31 14:37 [pve-devel] [PATCH container] vm status: force int where appropriate Fabian Ebner
2021-05-31 14:37 ` [pve-devel] [PATCH qemu-server] " Fabian Ebner
2021-06-01 6:07 ` [pve-devel] [PATCH container] " Fabian Ebner
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox