search
HomeOperation and MaintenanceNginxHow to set the number of Nginx server processes and how to utilize multi-core CPU

nginx configuration file nginx.conf

First you need to find the nginx configuration file nginx.conf to perform the following operations. Under the default configuration of the lnmp one-click installation package, nginx.conf Stored in

/usr/local/nginx/conf/nginx.conf

As for installing nginx in other environments, you can use

find / -name nginx.conf

to find the storage path of the configuration file.

nginx worker_processes process number setting

nginx configuration document nginx.conf can set worker_processes to change the number of nginx processes, according to this Q&A number of nginx worker processes It is shown that it is recommended that the number of nginx worker_processes processes be set to 1 because:

But our purpose is to allocate different worker_processes processes to run on cpu on different cores, so based on my current vps provider linode 512 configuration as an example, the server hen has 8 logical cpu, but as a user I only get 4 logical cpu, so here I set it to run 3 worker_processes processes, the reason is that by default, other programs will be in the first Running on 1 logical CPU (cpu0), in order not to affect other programs, I will allocate these 3 processes to run on 3 other logical CPUs (cpu1, cpu2, cpu3):

worker_processes 3;

Generally It is said that if you have several logical CPUs, it is appropriate to set several worker_processes. However, it does not make much sense if there are more than 8 worker_processes. The reason has been mentioned in the above paragraph in English.

You can use this command to view the current CPU situation:

cat /proc/cpuinfo

or directly display the number of logical CPUs:

cat /proc/cpuinfo |grep "processor"|wc -l

nginx worker_cpu_affinity setting

According to the information on nginx wiki:

worker_cpu_affinity is not enabled by default. From the example we can see that 0001 0010 0100 1000 respectively represent the 1st , 2, 3, and 4 logical CPUs, so we can set 0010 0100 1000 to bind 3 processes to the 2nd, 3rd, and 4th logical CPUs respectively:

worker_processes 3;
worker_cpu_affinity 0010 0100 1000;

At the same time, according to the example We can also see that worker_cpu_affinity can bind the same process to two logical cpu:

worker_processes 2;
worker_cpu_affinity 0101 1010;

0101 is the 1st and 3rd logical cpu, 1010 is the 2nd and 4th on a logical cpu.
nginx process is assigned to the enablement and testing of multi-core cpu settings

Save the nginx.conf file and reload the nginx configuration file:

/usr/local/nginx/sbin/nginx -s reload

Install apache on another computer Run ab under the host to test:
ab -n 20000 -k http://www.1990y.com/p.php
You can test a php page that requires mysql query, or you can test a static image Or page.

On the tested server, you can use top to view the current server situation, and then press 1 to display the usage of each logical CPU.

Enable cpu multi-core utilization

Rule settings
(1) How many cores the cpu has, there are several digits, 1 means the core is enabled, 0 means Kernel shutdown
(2) A maximum of 8 worker_processes can be opened. If more than 8 workers are used, the performance will not be improved, and the stability will be lower. Therefore, 8 processes are enough

Demonstration example
Two core cpu, start two processes

  worker_processes 2; 
  worker_cpu_affinity 01 10;

01 means the first cpu core is enabled, 10 means the second cpu core is enabled
worker_cpu_affinity 01 10; means Two processes are opened, the first process corresponds to the first cpu core, and the second process corresponds to the second cpu core

Two core cpu, eight processes are opened

  worker_processes 8; 
  worker_cpu_affinity 01 10 01 10 01 10 01 10;

8 processes are opened, which respectively correspond to opening 2 cores

8-core cpu, opening 8 processes

  worker_processes 8; 
  worker_cpu_affinity 10000000 01000000 00100000 00010000 00001000 00000100 00000010 00000001;

00000001 means opening the first cpu core, 00000010 means opening the second one cpu core, and so on

8-core cpu, open 2 processes

  worker_processes 2; 
  worker_cpu_affinity 10101010 01010101;

10101010 means starting the 2nd, 4th, 6th, and 8th cores, 01010101 means starting 1,3,5, 7 cores
2 processes correspond to 8 cores

Restart nginx
After the configuration is completed, you need to restart the nginx service

  /etc/init.d/nginx restart

The above is the detailed content of How to set the number of Nginx server processes and how to utilize multi-core CPU. For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:亿速云. If there is any infringement, please contact admin@php.cn delete
NGINX Unit: Key Features and CapabilitiesNGINX Unit: Key Features and CapabilitiesApr 25, 2025 am 12:17 AM

NGINXUnit is an open source application server that supports multiple programming languages ​​and provides functions such as dynamic configuration, zero downtime updates and built-in load balancing. 1. Dynamic configuration: You can modify the configuration without restarting. 2. Multilingual support: compatible with Python, Go, Java, PHP, etc. 3. Zero downtime update: Supports application updates that do not interrupt services. 4. Built-in load balancing: Requests can be distributed to multiple application instances.

NGINX Unit vs. Other Application ServersNGINX Unit vs. Other Application ServersApr 24, 2025 am 12:14 AM

NGINXUnit is better than ApacheTomcat, Gunicorn and Node.js built-in HTTP servers, suitable for multilingual projects and dynamic configuration requirements. 1) Supports multiple programming languages, 2) Provides dynamic configuration reloading, 3) Built-in load balancing function, suitable for projects that require high scalability and reliability.

NGINX Unit: The Architecture and How It WorksNGINX Unit: The Architecture and How It WorksApr 23, 2025 am 12:18 AM

NGINXUnit improves application performance and manageability with its modular architecture and dynamic reconfiguration capabilities. 1) Modular design includes master processes, routers and application processes, supporting efficient management and expansion. 2) Dynamic reconfiguration allows seamless update of configuration at runtime, suitable for CI/CD environments. 3) Multilingual support is implemented through dynamic loading of language runtime, improving development flexibility. 4) High performance is achieved through event-driven models and asynchronous I/O, and remains efficient even under high concurrency. 5) Security is improved by isolating application processes and reducing the mutual influence between applications.

Using NGINX Unit: Deploying and Managing ApplicationsUsing NGINX Unit: Deploying and Managing ApplicationsApr 22, 2025 am 12:06 AM

NGINXUnit can be used to deploy and manage applications in multiple languages. 1) Install NGINXUnit. 2) Configure it to run different types of applications such as Python and PHP. 3) Use its dynamic configuration function for application management. Through these steps, you can efficiently deploy and manage applications and improve project efficiency.

NGINX vs. Apache: A Comparative Analysis of Web ServersNGINX vs. Apache: A Comparative Analysis of Web ServersApr 21, 2025 am 12:08 AM

NGINX is more suitable for handling high concurrent connections, while Apache is more suitable for scenarios where complex configurations and module extensions are required. 1.NGINX is known for its high performance and low resource consumption, and is suitable for high concurrency. 2.Apache is known for its stability and rich module extensions, which are suitable for complex configuration needs.

NGINX Unit's Advantages: Flexibility and PerformanceNGINX Unit's Advantages: Flexibility and PerformanceApr 20, 2025 am 12:07 AM

NGINXUnit improves application flexibility and performance with its dynamic configuration and high-performance architecture. 1. Dynamic configuration allows the application configuration to be adjusted without restarting the server. 2. High performance is reflected in event-driven and non-blocking architectures and multi-process models, and can efficiently handle concurrent connections and utilize multi-core CPUs.

NGINX vs. Apache: Performance, Scalability, and EfficiencyNGINX vs. Apache: Performance, Scalability, and EfficiencyApr 19, 2025 am 12:05 AM

NGINX and Apache are both powerful web servers, each with unique advantages and disadvantages in terms of performance, scalability and efficiency. 1) NGINX performs well when handling static content and reverse proxying, suitable for high concurrency scenarios. 2) Apache performs better when processing dynamic content and is suitable for projects that require rich module support. The selection of a server should be decided based on project requirements and scenarios.

The Ultimate Showdown: NGINX vs. ApacheThe Ultimate Showdown: NGINX vs. ApacheApr 18, 2025 am 12:02 AM

NGINX is suitable for handling high concurrent requests, while Apache is suitable for scenarios where complex configurations and functional extensions are required. 1.NGINX adopts an event-driven, non-blocking architecture, and is suitable for high concurrency environments. 2. Apache adopts process or thread model to provide a rich module ecosystem that is suitable for complex configuration needs.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool