From: Bernhard Bitsch <bbitsch@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: [PATCH] speed.cgi: reduce system load by copying two general-functions.
Date: Fri, 22 Oct 2021 11:22:11 +0200 [thread overview]
Message-ID: <3ef729a2-6730-699e-396c-998c7cc23b37@ipfire.org> (raw)
In-Reply-To: <20211022080532.3195-1-arne_f@ipfire.org>
[-- Attachment #1: Type: text/plain, Size: 3759 bytes --]
Reviewed-by: Bernhard Bitsch <bbitsch(a)ipfire.org>
Am 22.10.2021 um 10:05 schrieb Arne Fitzenreiter:
> include general-functions.pl load and initialize many subfunctions that are not
> needed by speed.cgi which was executed very ofthen.
> So this reduce the system load significant if webif was open in browser
> and ajax-speed display enabled.
>
> Signed-off-by: Arne Fitzenreiter <arne_f(a)ipfire.org>
> ---
> config/cfgroot/general-functions.pl | 2 ++
> html/cgi-bin/speed.cgi | 46 +++++++++++++++++++++++++++--
> 2 files changed, 45 insertions(+), 3 deletions(-)
>
> diff --git a/config/cfgroot/general-functions.pl b/config/cfgroot/general-functions.pl
> index f72d6588c..c10a04faa 100644
> --- a/config/cfgroot/general-functions.pl
> +++ b/config/cfgroot/general-functions.pl
> @@ -53,6 +53,7 @@ sub system_background($) {
> }
>
> # Returns the output of a shell command
> +# if you change this also check speed.cgi that include a local copy for systemload reasons
> sub system_output($) {
> my @command = @_;
> my $pid;
> @@ -1227,6 +1228,7 @@ sub firewall_reload() {
> }
>
> # Function which will return the used interface for the red network zone (red0, ppp0, etc).
> +# if you change this also check speed.cgi that include a local copy for systemload reasons
> sub get_red_interface() {
>
> open(IFACE, "${General::swroot}/red/iface") or die "Could not open /var/ipfire/red/iface";
> diff --git a/html/cgi-bin/speed.cgi b/html/cgi-bin/speed.cgi
> index b550fda52..651c3c0b3 100644
> --- a/html/cgi-bin/speed.cgi
> +++ b/html/cgi-bin/speed.cgi
> @@ -19,7 +19,47 @@
> # #
> ###############################################################################
>
> -require '/var/ipfire/general-functions.pl';
> +###############################################################################
> +# functions copied from general-functions.pl for speed improvement because #
> +# loading and initializing the whole general-functions.pl every second create #
> +# high system load #
> +###########################################OA##################################
> +#
> +# Returns the output of a shell command
> +sub General__system_output($) {
> + my @command = @_;
> + my $pid;
> + my @output = ();
> +
> + unless ($pid = open(OUTPUT, "-|")) {
> + open(STDERR, ">&STDOUT");
> + exec { ${command[0]} } @command;
> + die "Could not execute @command: $!";
> + }
> +
> + waitpid($pid, 0);
> +
> + while (<OUTPUT>) {
> + push(@output, $_);
> + }
> +
> + close(OUTPUT);
> + return @output;
> +}
> +#
> +# Function which will return the used interface for the red network zone (red0, ppp0, etc).
> +sub General__get_red_interface() {
> +
> + open(IFACE, "/var/ipfire/red/iface") or die "Could not open /var/ipfire/red/iface";
> +
> + my $interface = <IFACE>;
> + close(IFACE);
> + chomp $interface;
> +
> + return $interface;
> +}
> +#
> +###############################################################################
>
> my $data_last = $ENV{'QUERY_STRING'};
> my $rxb_last = 0;
> @@ -38,8 +78,8 @@ foreach $field (@fields) {
> }
> }
>
> -my $interface = &General::get_red_interface();
> -my @data_now = &General::system_output("ip", "-s", "link", "show", "$interface");
> +my $interface = &General__get_red_interface();
> +my @data_now = &General__system_output("ip", "-s", "link", "show", "$interface");
>
> my $lastline;
> my $rxb_now = 0;
>
next prev parent reply other threads:[~2021-10-22 9:22 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-10-22 8:05 Arne Fitzenreiter
2021-10-22 9:22 ` Bernhard Bitsch [this message]
2021-10-22 10:07 ` Michael Tremer
2021-10-22 10:30 ` Bernhard Bitsch
2021-10-25 18:54 ` Michael Tremer
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=3ef729a2-6730-699e-396c-998c7cc23b37@ipfire.org \
--to=bbitsch@ipfire.org \
--cc=development@lists.ipfire.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox