Apache MPM worker vs prefork

find what MPM Apache is using, it will either be using "worker" or "prefork"

apachectl -l
Compiled in modules:
core.c
prefork.c
http_core.c
mod_so.c


In my case it is "prefork"

vi /etc/httpd/conf/httpd.conf

Find the section that looks like this (by default one will normally exist for prefork and for worker, but in my case I only care about prefork since prefork is what is compiled in):

# prefork MPM
# StartServers: number of server processes to start
# MinSpareServers: minimum number of server processes which are kept spare
# MaxSpareServers: maximum number of server processes which are kept spare
# ServerLimit: maximum value for MaxClients for the lifetime of the server
# MaxClients: maximum number of server processes allowed to start
# MaxRequestsPerChild: maximum number of requests a server process serves

StartServers 8
MinSpareServers 5
MaxSpareServers 20
ServerLimit 2000
MaxClients 5000
MaxRequestsPerChild 4000


As some have mentioned the MPM prefork/worker sections are VERY important they affect both stability and performance.
In my case I'm the most concerned because I keep getting the MaxClients error message/hung Apache process without error (where Apache thinks it's running but can't connect and yet most of the time nothing in the debug log shows a problem).

Enable Debug:

Speaking of that you might want to enable this for debugging if you're having the issues I've seen (the crash but even with debug it often won't show the true error)

Add this to your config file: Loglevel debug

Back to the issue, prefork means a new process/server is started for each new connection to the web server.

My new settings:


StartServers 200
MinSpareServers 50
MaxSpareServers 200
ServerLimit 400
MaxClients 1000
MaxRequestsPerChild 0



WARNING: MaxClients of 1000 exceeds ServerLimit value of 400 servers,
lowering MaxClients to 400. To increase, please see the ServerLimit
directive.

Change ServerLimit to "4000" and restart


Tags:

apache, mpm, vs, preforkfind, quot, prefork, apachectl, compiled, modules, http_core, mod_so, vi, etc, httpd, conf, default, startservers, server, processes, minspareservers, maxspareservers, maximum, serverlimit, maxclients, maxrequestsperchild, requests, serves, ifmodule, sections, stability, debug, enable, debugging, ve, config, loglevel, settings, exceeds, servers, lowering, directive, restart,

Latest Articles

  • CentOS 6 impossible to compile a newer libguestfs
  • chroot
  • How To Get Started on Ubuntu with gpt-2 OpenAI Text Prediction
  • Remove cloud-init in your VM
  • QEMU-KVM KVM Command Line Practical Guide
  • Linux How To Change NIC Name to eth0 instead of enps33 or enp0s25
  • virt-resize: error: libguestfs error: could not create appliance through libvirt.
  • Asterisk Does Not Retry When Authentication Fails
  • Linux Debian Ubuntu How To Install PEPPER Faster and Latest Adobe Flash Player in Firefox
  • How To Speed Up Linux Ubuntu and Debian Based Computers By Improving CPU Performance and Changing the CPU Governor
  • Convert data or file to base64 on a single line
  • Linux Mint Ubuntu Debian radeon slow 2D performance issues radeon_dp_aux_transfer_native: 158 callbacks suppressed
  • mdadm: super0.90 cannot open /dev/sdb1: Device or resource busy mdadm: /dev/sdb1 is not suitable for this array.
  • How To Install NextCloud on Centos 7 and Centos 8
  • AH01630: client denied by server configuration:
  • ERROR: Could not find a version that satisfies the requirement PIL (from versions: none) ERROR: No matching distribution found for PIL
  • ZTE Camera Cannot Work unable to connect to camera. Camera has been disabled becaue of security policies or is being used by other apps
  • QEMU KVM how to boot off a physical CD/DVD/BDROM Drive
  • How To Install OpenProject on Centos 7 Step-by-Step Guide
  • Ubuntu Debian Linux Cannot Install Wine Solution - wine1.6 : Depends: wine1.6-i386 (= 1:1.6.2-0ubuntu14.2) but it is not installable wine1.4 : Depends: wine1.6 but it is not going to be installed