Starting with Learn 9.1 April 2014, Blackboard Learn no longer supports Apache 1.3 web server. If your deployment requires a web server, Apache 2.2 can be used. The instructions can be found in config/apache2/README.txt file under the Blackboard Learn install. Apache 2.2 is required if Shibboleth authentication provider is used.
Process Model in Apache
Apache 1.3 serves requests using preforked processes. When the server’s parent process is started, it forks a number of child processes that are responsible for accepting connections on the listening sockets. When a connection is received, the system wakes up one of the processes to handle the connection.
Apache 2.x supports pluggable concurrency models called Multi-Processing Modules (MPMs). When building Apache, you must choose MPM. Two of the important MPMs are Worker MPM and Prefork MPM. Worker MPM uses multiple child processes, each with multiple threads. Each thread handles one connection at a time. Worker is generally a good choice for high-traffic servers because it has smaller memory footprint than Prefork MPM. Prefork MPM uses multiple child processes with one thread each. Each process handles one connection at a time. Prefork is comparable in speed to worker, but it uses more memory. Prefork's threadless design can be used with non-thread-safe third-party modules and it is easier to debug on platforms with poor thread debugging support.
Apache 2.2 runs with Prefork MPM as the default. Follow the below instructions to switch to Worker MPM. Blackboard recommends using the Worker MPM.
To determine which MPM is running:
To determine if Apache has Worker MPM compiled in:
Uncomment HTTPD=/usr/sbin/httpd.worker in /etc/sysconfig/httpd
The Keep-Alive extension to HTTP/1.0 and the persistent connection feature of HTTP/1.1 provide long-lived HTTP sessions. They allow same TCP connections to be used by multiple requests. Performance tests have shown reduced latency times. As a result, Blackboard recommends leaving the default setting, KeepAlive On in httpd.conf.
KeepAliveTimeout specifies the amount of time the server waits for subsequent requests on a persistent connection. This directive is set to 5 by default. Blackboard’s internal tests suggest increasing the value to 15 for optimal performance.
Estimating MaxClients for Optimal Performance
MaxClients sets the limit on simultaneous requests so connection attempts beyond the configured number ofMaxClients are queued. MaxClients defaults to 256 with the Prefork MPM and 400 (ServerLimit multiplied by the value of ThreadsPerChild) for the Worker MPM. Blackboard recommends setting MaxClients to 200 as a starting point. When using the Prefork MPM, ServerLimit must always be the same as MaxClients.
Use the formula below to achieve a more precise calculation of MaxClients. The formula aligns to the tunable capacity of Tomcat application server. MaxClients must not exceed the MaxThreads configured bybbconfig.appserver.maxthreads.
MaxClients = minimum(
“RAM Memory allocated to Apache Web server” /
“Max child process size”,
To calculate the Max child process size, use the following command during a server busy time.
ps -ylC httpd --sort:rss
It is also important to ensure that you have enough RAM memory on the server for Apache by using the below formula:
“RAM Memory dedicated to Apache Web server” =
MaxClients * “Max child process size”
An example configuration for the Worker MPM:
An example configuration for the Prefork MPM: