-----BEGIN PGP SIGNED MESSAGE----- Hash: SHA512 So a <600MB total RSS footprint for the entire show, and I can stably sustain 1000 concurrent ModPerl::Registry requests, in a few milliseconds per request. Good luck doing anything this efficiently with a multi-tiered dynamic content delivery regime. The real tuning effort is to balance mpm_event threads (100 - 1000x) and ithreads.
- -- Joe Schaefer, Ph.D. We only build what you need built. <j...@sunstarsys.com> 954.253.3732 On 2022-08-27 at 15:42, j...@sunstarsys.com wrote: > See https://sunstarsys.com/essays/perl7-sealed-lexicals. For the full effect, you will need to build B::Generate with this patched version instead: https://github.com/SunStarSys/cms/blob/master/Generate.xs > > Sample mod_perl config + benchmarks: > > <IfModule mpm_event_module> > StartServers 2 > MinSpareThreads 100 > MaxSpareThreads 500 > ThreadLimit 1000 > ThreadsPerChild 100 > MaxRequestWorkers 1000000 > MaxConnectionsPerChild 0 > </IfModule> > > <IfModule mod_perl.c> > PerlSwitches -T -I/home/joesuf4/src/cms/lib > PerlInterpStart 2 > PerlInterpMax 4 > PerlInterpMinSpare 1 > PerlInterpMaxSpare 4 > PerlInterpMaxRequests 1000000 > PerlOptions +GlobalRequest > > <Directory /home/joesuf4/src/cms> > Require all granted > AddHandler perl-script .pl > PerlResponseHandler ModPerl::Registry > Options +ExecCGI > </Directory> > > <Directory /home/joesuf4/src/trunk/content> > Require all granted > </Directory> > > <VirtualHost *:80> > ServerName localhost > DocumentRoot /home/joesuf4/src/trunk/content > Alias /perl-script /home/joesuf4/src/cms > </VirtualHost> > > </IfModule> > > > ab -n 10000 -c 1000 http://localhost/perl-script/enquiry.pl > This is ApacheBench, Version 2.3 <$Revision: 1879490 $> > Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/ > Licensed to The Apache Software Foundation, http://www.apache.org/ > > Benchmarking localhost (be patient) > Completed 1000 requests > Completed 2000 requests > Completed 3000 requests > Completed 4000 requests > Completed 5000 requests > Completed 6000 requests > Completed 7000 requests > Completed 8000 requests > Completed 9000 requests > Completed 10000 requests > Finished 10000 requests > > > Server Software: Apache/2.4.52 > Server Hostname: localhost > Server Port: 80 > > Document Path: /perl-script/enquiry.pl > Document Length: 1329 bytes > > Concurrency Level: 1000 > Time taken for tests: 1.218 seconds > Complete requests: 10000 > Failed requests: 0 > Total transferred: 15010000 bytes > HTML transferred: 13290000 bytes > Requests per second: 8207.94 [#/sec] (mean) > Time per request: 121.833 [ms] (mean) > Time per request: 0.122 [ms] (mean, across all concurrent requests) > Transfer rate: 12031.37 [Kbytes/sec] received > > Connection Times (ms) > min mean[+/-sd] median max > Connect: 0 2 6.2 0 24 > Processing: 4 93 49.6 82 458 > Waiting: 1 80 44.5 71 455 > Total: 17 95 49.5 84 458 > > Percentage of the requests served within a certain time (ms) > 50% 84 > 66% 100 > 75% 112 > 80% 120 > 90% 147 > 95% 173 > 98% 233 > 99% 318 > 100% 458 (longest request) > > % pgrep -f apache2 | xargs -n1 ps -uwww > USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND > root 442827 0.0 0.1 18180 14244 ? Ss 11:27 0:00 /usr/sbin/apache2 -k start > USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND > www-data 446387 1.7 1.5 7549352 129692 ? Sl 11:28 0:12 /usr/sbin/apache2 -k start > USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND > www-data 451006 15.2 1.5 7483708 128468 ? Sl 11:39 0:10 /usr/sbin/apache2 -k start > USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND > www-data 451317 11.7 1.4 7483772 119836 ? Sl 11:39 0:07 /usr/sbin/apache2 -k start > USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND > www-data 451629 6.4 1.3 7483804 113012 ? Sl 11:39 0:03 /usr/sbin/apache2 -k start > USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND > www-data 451929 1.1 1.4 7483816 116668 ? Sl 11:39 0:00 /usr/sbin/apache2 -k start -----BEGIN PGP SIGNATURE----- Version: FlowCrypt Email Encryption 8.3.3 Comment: Seamlessly send and receive encrypted email wsFzBAEBCgAGBQJjCkWOACEJEEAg7C7WAdUZFiEEf+9TuFcgikzfTrs6QCDs LtYB1RkFAw//ceUc4RCiyAE4/NiLHh7/RFihyIEBm4LIi+JOF7y61mzWmjj2 oFguaOACfG5zsF3TftGeJXmYtP9tTE9e4NC4TJJ0ciwD9Z22lpx1+3WM6Vwg gjnlYpm+HtElgvXB34DFj7k6ahNvbwT0NZxCa9R4Cx+x3mfe/43THDTqRHF7 H3QDqgsyEZingtBOL6uuViW82tR6f/Vl6tOf+3OQqCqsPHSr6UPzUorcB2wy uL7YJKKqxERi6hrZEPM2scQsKvkAc7CTuuxXG7J2nWL+FM+A/+nPYMUWR10b rJJcj0W+iHjcx0bmoIQJJdNOFkQn0hydprTdhH0caLN879OxX3pJI8jzjOxb A5btacCuXbPwHrNMxb4bmvPrDHTQj8Sw5B6ylOIRIX/YRWcrZ9lJO9cO9/61 0W005EZFEjzCiSrvDJuQLa+uvC7CNJkP2Fzi1SuOWkj8QnV0M1Y+4WfoFH8R ZDlHOdU5Nam8baREQZIDmkH/H/kSevbtdllZIWtlxDKUkN+H2/3LW1crMO60 sLJqDkO8J4CyDBp9crMOiRHaDx9Yxa/BnnXmwFHyqD07VwSzd43C81nUTfjN MwgxS9SpxwK24J6V6sRVwguPUyoO7ytLb8n7RZM5VIyD9dd0wc99VtxNf8hl eNMCrRd19h6Oj2cWxG1kTb6PinHUFgZ/DPY= =H1je -----END PGP SIGNATURE-----
0x4020EC2ED601D519.asc
Description: application/pgp-keys