How Apache increases the number of concurrent connection requests
Sites that use Apache as an HTTP server will inevitably encounter this problem: apache has a very low load, but accessing the web server is very slow. After excluding the cause of the script program, it is basically a problem of apache settings.
The following content may help resolve this issue.
1. First, you must understand the MPM (Multi-Processing Modules) used by Apache
MPM is the core of Apache. Its role is to manage network connections and schedule requests.
MPM in Apache2.0 is divided into three types (perfork, worker, event). perfork is inherited from Apache1.3. It adopts process management method, so it can provide more reliable performance and better compatibility; worker is a new method added in Apache2.0, which adopts thread control method. , it can save system overhead and process more data than perfork, but at the same time, the compatibility is not very good, and many old programs cannot work under the worker; event is still in the experimental stage, and it allocates different processes to each task. Pool, should not be used at this time.
You can get which MPM is currently used by Apache through the command httpd -l
This article only discusses the perfork method
2. Understand how perfork works
Check the configuration file httpd.conf of Apache2.0 and you can see the configuration section of perfork, which is roughly as follows:
ServerLimit 256
StartServers 5
MinSpareServers 10
MaxSpareServers 15
MaxClients 256
MaxRequestsPerChild 4000
When Apache is started, Apache will automatically create StartServers processes and try its best to keep the number of idle processes between MinSpareServers and MaxSpareServers.
If the idle processes are smaller than MinSpareServers, Apache will create new processes at a rate of approximately 1 per second.
If the idle processes are smaller than MaxSpareServers, Apache will delete excess idle processes and release server resources.
The maximum number of processes is controlled by MaxClients. In Apache1.3, the maximum can only be set to 256. However, in Apache2.0, you can break the limit of 256 by adding the ServerLimit item at the beginning of the configuration. In this case, MaxClients ≤ ServerLimit ≤ 20000
MaxRequestsPerChild is used to control how many requests each process will be automatically destroyed after processing. This parameter can be set to 0 to indicate unlimited (that is, the process will not be destroyed).
3. Optimize perfork
First of all, for a website with a relatively high load, the process limit of 256 is not enough. If the server has reached the limit of 256, then the next access needs to be queued. This is why the load of some servers is not high, but One of the reasons why access is so slow. So first you should understand the number of processes when the server is busy.
You can know the number of Apache processes in the current system through the command ps -ef|grep httpd|wc -l, and achieve the purpose of soft expansion of the server by setting ServerLimit and MaxClients.
Then, during peak traffic times, what often happens is that all of a sudden there are a lot of concurrent connections, and then suddenly there's a lot less access. If Apache does not prepare a sufficient number of preparation processes, then access can only wait for Apache to add one new process per second, and then delete the redundant processes. Then Apache can only be busy creating and destroying processes, which greatly reduces access. speed. You can appropriately increase StartServers, MinSpareServers, and MaxSpareServers so that Apache does not have to be busy doing useless work.
Finally, it is strongly recommended not to set MaxRequestsPerChild to 0, but to set it to non-0, which can protect the Apache process from memory leaks, because you don't know when the application running on Apache will go wrong and cause memory leaks.
After setting it up, it looks like this:
ServerLimit 1000
StartServers 30
MinSpareServers 30
MaxSpareServers 45
MaxClients 1000
MaxRequestsPerChild 4000
Detailed steps http://www.liaoxiansheng.cn/?p=496

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Learn about Python programming with introductory code examples Python is an easy-to-learn, yet powerful programming language. For beginners, it is very important to understand the introductory code examples of Python programming. This article will provide you with some concrete code examples to help you get started quickly. Print HelloWorldprint("HelloWorld") This is the simplest code example in Python. The print() function is used to output the specified content

PHP variables store values during program runtime and are crucial for building dynamic and interactive WEB applications. This article takes an in-depth look at PHP variables and shows them in action with 10 real-life examples. 1. Store user input $username=$_POST["username"];$passWord=$_POST["password"]; This example extracts the username and password from the form submission and stores them in variables for further processing. 2. Set the configuration value $database_host="localhost";$database_username="username";$database_pa

Title: From Beginner to Mastery: Code Implementation of Commonly Used Data Structures in Go Language Data structures play a vital role in programming and are the basis of programming. In the Go language, there are many commonly used data structures, and mastering the implementation of these data structures is crucial to becoming a good programmer. This article will introduce the commonly used data structures in the Go language and give corresponding code examples to help readers from getting started to becoming proficient in these data structures. 1. Array Array is a basic data structure, a group of the same type

"Go Language Programming Examples: Code Examples in Web Development" With the rapid development of the Internet, Web development has become an indispensable part of various industries. As a programming language with powerful functions and superior performance, Go language is increasingly favored by developers in web development. This article will introduce how to use Go language for Web development through specific code examples, so that readers can better understand and use Go language to build their own Web applications. 1. Simple HTTP Server First, let’s start with a

How to use PHP to write the inventory management function code in the inventory management system. Inventory management is an indispensable part of many enterprises. For companies with multiple warehouses, the inventory management function is particularly important. By properly managing and tracking inventory, companies can allocate inventory between different warehouses, optimize operating costs, and improve collaboration efficiency. This article will introduce how to use PHP to write code for inventory warehouse management functions, and provide you with relevant code examples. 1. Establish the database before starting to write the code for the inventory warehouse management function.

The simplest code example of Java bubble sort Bubble sort is a common sorting algorithm. Its basic idea is to gradually adjust the sequence to be sorted into an ordered sequence through the comparison and exchange of adjacent elements. Here is a simple Java code example that demonstrates how to implement bubble sort: publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

Huawei Cloud Edge Computing Interconnection Guide: Java Code Samples to Quickly Implement Interfaces With the rapid development of IoT technology and the rise of edge computing, more and more enterprises are beginning to pay attention to the application of edge computing. Huawei Cloud provides edge computing services, providing enterprises with highly reliable computing resources and a convenient development environment, making edge computing applications easier to implement. This article will introduce how to quickly implement the Huawei Cloud edge computing interface through Java code. First, we need to prepare the development environment. Make sure you have the Java Development Kit installed (

Java Selection Sorting Method Code Writing Guide and Examples Selection sorting is a simple and intuitive sorting algorithm. The idea is to select the smallest (or largest) element from the unsorted elements each time and exchange it until all elements are sorted. This article will provide a code writing guide for selection sorting, and attach specific Java sample code. Algorithm Principle The basic principle of selection sort is to divide the array to be sorted into two parts, sorted and unsorted. Each time, the smallest (or largest) element is selected from the unsorted part and placed at the end of the sorted part. Repeat the above
