mirror of
https://git.proxmox.com/git/pve-client
synced 2025-10-25 09:58:46 +00:00
lxc console: limit output buffer size
This commit is contained in:
parent
1ec5788ca4
commit
032dc44cfe
@ -281,6 +281,8 @@ __PACKAGE__->register_method ({
|
||||
$winch_received = 0;
|
||||
};
|
||||
|
||||
my $max_buffer_len = 256*1024;
|
||||
|
||||
my $drain_buffer = sub {
|
||||
my ($fh, $buffer_ref) = @_;
|
||||
|
||||
@ -292,7 +294,8 @@ __PACKAGE__->register_method ({
|
||||
}
|
||||
return $nr if !$nr;
|
||||
substr($$buffer_ref, 0, $nr, '');
|
||||
$write_select->remove($fh) if !length($$buffer_ref);
|
||||
$len = length($$buffer_ref);
|
||||
$write_select->remove($fh) if !$len;
|
||||
};
|
||||
|
||||
while (1) {
|
||||
@ -302,6 +305,7 @@ __PACKAGE__->register_method ({
|
||||
foreach my $fh (@$writable) {
|
||||
if ($fh == $output_fh) {
|
||||
$drain_buffer->(\*STDOUT, \$output_buffer);
|
||||
$read_select->add($web_socket) if length($output_buffer) <= $max_buffer_len;
|
||||
} elsif ($fh == $web_socket) {
|
||||
$drain_buffer->($web_socket, \$websock_buffer);
|
||||
}
|
||||
@ -319,9 +323,12 @@ __PACKAGE__->register_method ({
|
||||
return; # EOF
|
||||
} else {
|
||||
my ($payload, $req_close) = $parse_web_socket_frame->(\$wsbuf);
|
||||
if ($payload) {
|
||||
if (defined($payload) && length($payload)) {
|
||||
$output_buffer .= $payload;
|
||||
$write_select->add($output_fh);
|
||||
if (length($output_buffer) > $max_buffer_len) {
|
||||
$read_select->remove($web_socket);
|
||||
}
|
||||
}
|
||||
return if $req_close;
|
||||
}
|
||||
|
||||
Loading…
Reference in New Issue
Block a user