From mboxrd@z Thu Jan 1 00:00:00 1970 From: Bernhard Bitsch 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 Message-ID: <3ef729a2-6730-699e-396c-998c7cc23b37@ipfire.org> In-Reply-To: <20211022080532.3195-1-arne_f@ipfire.org> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============6710717669989237261==" List-Id: --===============6710717669989237261== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Reviewed-by: Bernhard Bitsch 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. >=20 > Signed-off-by: Arne Fitzenreiter > --- > config/cfgroot/general-functions.pl | 2 ++ > html/cgi-bin/speed.cgi | 46 +++++++++++++++++++++++++++-- > 2 files changed, 45 insertions(+), 3 deletions(-) >=20 > diff --git a/config/cfgroot/general-functions.pl b/config/cfgroot/general-f= unctions.pl > index f72d6588c..c10a04faa 100644 > --- a/config/cfgroot/general-functions.pl > +++ b/config/cfgroot/general-functions.pl > @@ -53,6 +53,7 @@ sub system_background($) { > } > =20 > # Returns the output of a shell command > +# if you change this also check speed.cgi that include a local copy for sy= stemload reasons > sub system_output($) { > my @command =3D @_; > my $pid; > @@ -1227,6 +1228,7 @@ sub firewall_reload() { > } > =20 > # 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 sy= stemload reasons > sub get_red_interface() { > =20 > 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 @@ > # = # > #########################################################################= ###### > =20 > -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 cre= ate # > +# high system load = # > +###########################################OA#############################= ##### > +# > +# Returns the output of a shell command > +sub General__system_output($) { > + my @command =3D @_; > + my $pid; > + my @output =3D (); > + > + unless ($pid =3D open(OUTPUT, "-|")) { > + open(STDERR, ">&STDOUT"); > + exec { ${command[0]} } @command; > + die "Could not execute @command: $!"; > + } > + > + waitpid($pid, 0); > + > + while () { > + 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/ipfi= re/red/iface"; > + > + my $interface =3D ; > + close(IFACE); > + chomp $interface; > + > + return $interface; > +} > +# > +##########################################################################= ##### > =20 > my $data_last =3D $ENV{'QUERY_STRING'}; > my $rxb_last =3D 0; > @@ -38,8 +78,8 @@ foreach $field (@fields) { > } > } > =20 > -my $interface =3D &General::get_red_interface(); > -my @data_now =3D &General::system_output("ip", "-s", "link", "show", "$int= erface"); > +my $interface =3D &General__get_red_interface(); > +my @data_now =3D &General__system_output("ip", "-s", "link", "show", "$int= erface"); > =20 > my $lastline; > my $rxb_now =3D 0; >=20 --===============6710717669989237261==--