From mboxrd@z Thu Jan 1 00:00:00 1970 From: Michael Tremer To: development@lists.ipfire.org Subject: Re: [PATCH] BUG 11786 - squid: Remove setting for filter processes the number of Squid processes Date: Tue, 30 Oct 2018 14:03:40 +0000 Message-ID: In-Reply-To: <91ca8d3f-9558-7931-2816-af520a8a5cd0@ipfire.org> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============7294164034696725542==" List-Id: --===============7294164034696725542== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Hey, do you have any idea why the redirector is busy? -Michael On Tue, 2018-10-30 at 14:54 +0100, Matthias Fischer wrote: > Hi, >=20 > I tested this patch today and I fear the resulting value is too low. >=20 > For me, its leads to: >=20 > ***SNIP*** > ... > 2018/10/30 14:42:43 kid1| WARNING: All 2/2 redirector processes are busy. > 2018/10/30 14:42:43 kid1| WARNING: 4 pending requests queued > 2018/10/30 14:42:43 kid1| WARNING: Consider increasing the number of > redirector processes in your config file. > ... >=20 > Current setting is "40" (Duo box, 2 Cores, 'squidclamav, squidguard) >=20 > Best, > Matthias >=20 > On 30.10.2018 12:06, Daniel Weism=C3=BCller wrote: > > I added a function to determine the number of cores. > > Now the number of squid processes will be equal to the number of logical > > cores. > > Further I removed the possibility of changing the number > > of squid processes in the proxy.cgi > >=20 > > Signed-off-by: Daniel Weism=C3=BCller > > --- > > config/cfgroot/general-functions.pl | 7 +++++++ > > html/cgi-bin/proxy.cgi | 16 ++-------------- > > 2 files changed, 9 insertions(+), 14 deletions(-) > >=20 > > diff --git a/config/cfgroot/general-functions.pl b/config/cfgroot/general- > > functions.pl > > index 0577afe28..e8495e885 100644 > > --- a/config/cfgroot/general-functions.pl > > +++ b/config/cfgroot/general-functions.pl > > @@ -1165,5 +1165,12 @@ sub dnssec_status() { > > =20 > > return $status; > > } > > +sub number_cpu_cores() { > > + open my $cpuinfo, "/proc/cpuinfo" or die "Can't open cpuinfo: $!\n"; > > + my $cores =3D scalar (map /^processor/, <$cpuinfo>); > > + close $cpuinfo; > > + > > + return $cores; > > +} > > =20 > > 1; > > diff --git a/html/cgi-bin/proxy.cgi b/html/cgi-bin/proxy.cgi > > index 738425b9a..92bebfe18 100644 > > --- a/html/cgi-bin/proxy.cgi > > +++ b/html/cgi-bin/proxy.cgi > > @@ -287,7 +287,6 @@ $proxysettings{'IDENT_USER_ACL'} =3D 'positive'; > > $proxysettings{'ENABLE_FILTER'} =3D 'off'; > > $proxysettings{'ENABLE_UPDXLRATOR'} =3D 'off'; > > $proxysettings{'ENABLE_CLAMAV'} =3D 'off'; > > -$proxysettings{'CHILDREN'} =3D '10'; > > =20 > > $ncsa_buttontext =3D $Lang::tr{'advproxy NCSA create user'}; > > =20 > > @@ -437,11 +436,6 @@ if (($proxysettings{'ACTION'} eq $Lang::tr{'save'}) = || > > ($proxysettings{'ACTION'} > > $errormessage =3D $Lang::tr{'invalid maximum incoming size'}; > > goto ERROR; > > } > > - if (!($proxysettings{'CHILDREN'} =3D~ /^\d+$/) || > > ($proxysettings{'CHILDREN'} < 1)) > > - { > > - $errormessage =3D $Lang::tr{'advproxy invalid num of children'}; > > - goto ERROR; > > - } > > if ($proxysettings{'ENABLE_BROWSER_CHECK'} eq 'on') > > { > > $browser_regexp =3D ''; > > @@ -1034,12 +1028,8 @@ print < > > >
> > > > - > > - > > END > > ; > > -my $count =3D `ip n| wc -l`; > > -if ( $count < 1 ){$count =3D 1;} > > if ( -e "/usr/bin/squidclamav" ) { > > print ""; > > } else { > > print ""; > > } > > print ""; > > print ""; > > print < >
$Lang::tr{'advproxy redirector > > children'}
$Lang::tr{'processes'}:  > alt=3D'*' /> > value=3D'$proxysettings{'CHILDREN'}' size=3D'5' />".$Lang::tr{'advproxy squidclamav'}."<= br > > />"; > > if ( ! -e "/var/run/clamav/clamd.pid" ){ > > @@ -1048,18 +1038,16 @@ if ( -e "/usr/bin/squidclamav" ) { > > } > > else { > > print $Lang::tr{'advproxy enabled'}." > name=3D'ENABLE_CLAMAV' ".$checked{'ENABLE_CLAMAV'}{'on'}." />
"; > > - print "+ ".int(( $count**(1/3)) * 8);} > > +} > > print "
> bin/urlfilter.cgi'>".$Lang::tr{'advproxy url filter'}."
"; > > print $Lang::tr{'advproxy enabled'}." > name=3D'ENABLE_FILTER' ".$checked{'ENABLE_FILTER'}{'on'}." />
"; > > -print "+ ".int(($count**(1/3)) * 6); > > print "
> bin/updatexlrator.cgi'>".$Lang::tr{'advproxy update > > accelerator'}."
"; > > print $Lang::tr{'advproxy enabled'}." > name=3D'ENABLE_UPDXLRATOR' ".$checked{'ENABLE_UPDXLRATOR'}{'on'}." />
"; > > -print "+ ".int(($count**(1/3)) * 5); > > print "
> > @@ -4095,7 +4083,7 @@ END > > if (($proxysettings{'ENABLE_FILTER'} eq 'on') || > > ($proxysettings{'ENABLE_UPDXLRATOR'} eq 'on') || > > ($proxysettings{'ENABLE_CLAMAV'} eq 'on')) > > { > > print FILE "url_rewrite_program /usr/sbin/redirect_wrapper\n"; > > - print FILE "url_rewrite_children > > $proxysettings{'CHILDREN'}\n\n"; > > + print FILE "url_rewrite_children ", > > &General::number_cpu_cores(), "\n\n"; > > } > > =20 > > # Include file with user defined settings. > >=20 >=20 >=20 --===============7294164034696725542==--