Home Backend Development PHP Tutorial nginx sendfile parameter explanation

nginx sendfile parameter explanation

Jul 29, 2016 am 09:05 AM
buffer kernel mode user

sendfile
Nowadays, popular web servers provide the sendfile option to improve server performance. So what exactly is sendfile and how does it affect performance? sendfile is actually a system call launched after Linux 2.0+. The web server can decide whether to use the sendfile system call by adjusting its own configuration. Let’s first look at the traditional network transmission process without sendfile:
read(file,tmp_buf, len);
write(socket,tmp_buf, len);
Hard disk >> kernel buffer >> user buffer>> kernel socket buffer >>Protocol stack
Generally speaking, a network application completes network transmission by reading data from the hard disk and then writing the data to the socket. The above two lines of code explain this point, but the above two simple lines of code cover up many underlying operations. Let’s take a look at how the bottom layer executes the above two lines of code:
1. The system call read() generates a context switch: switching from user mode to kernel mode, and then DMA performs a copy to read the file data from the hard disk into a kernel buffer.
2. The data is copied from the kernel buffer to the user buffer, and then the system call read() returns. At this time, a context switch occurs: switching from kernel mode to user mode.
3. The system calls write() to generate a context switch: switch from user mode to kernel mode, and then copy the data read from the user buffer in step 2 to the kernel buffer (the second time the data is copied to the kernel buffer), but this time it is different. Kernel buffer, this buffer is associated with the socket.
4. The system call write() returns, resulting in a context switch: switching from kernel mode to user mode (the fourth time), and then DMA copies the data from the kernel buffer to the protocol stack (the fourth time).
The above 4 steps have 4 context switches and 4 copies. We found that if we can reduce the number of switches and copies, the performance will be effectively improved. In the kernel2.0+ version, the system call sendfile() is used to simplify the above steps and improve performance. sendfile() can not only reduce the number of switches but also the number of copies.
Let’s take a look at the process of using sendfile() for network transmission:
sendfile(socket,file,len);
Hard disk >> kernel buffer (quick copy to kernelsocket buffer) >>Protocol stack
1. The system calls sendfile() to copy the hard disk data to the kernel buffer through DMA, and then the data is directly copied by the kernel to another kernel buffer related to the socket. There is no switching between user mode and kernel mode. Copying from one buffer to another is completed directly in the kernel.
2. DMA copies data from the kernelbuffer directly to the protocol stack. There is no switching, and there is no need to copy data from user mode to kernel mode, because the data is in the kernel.

Article reference: http://www.th7.cn/system/lin/201306/41314.shtml

').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i ').text(i)); }; $numbering.fadeIn(1700); }); });

The above has introduced the explanation of nginx sendfile parameters, including the relevant content. I hope it will be helpful to friends who are interested in PHP tutorials.

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

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

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

17 ways to solve the kernel_security_check_failure blue screen 17 ways to solve the kernel_security_check_failure blue screen Feb 12, 2024 pm 08:51 PM

Kernelsecuritycheckfailure (kernel check failure) is a relatively common type of stop code. However, no matter what the reason is, the blue screen error causes many users to be very distressed. Let this site carefully introduce 17 types to users. Solution. 17 solutions to kernel_security_check_failure blue screen Method 1: Remove all external devices When any external device you are using is incompatible with your version of Windows, the Kernelsecuritycheckfailure blue screen error may occur. To do this, you need to unplug all external devices before trying to restart your computer.

what is linux kernel what is linux kernel Mar 23, 2023 am 10:20 AM

linux kernel means linux kernel, which mainly functions to complete IO driver device management, TCP/IP and task scheduling; linux kernel is the main component of the Linux operating system and the core interface between computer hardware and its process. It is responsible for both communications and manage resources as efficiently as possible.

How to solve the problem of docker mounting directory permissions How to solve the problem of docker mounting directory permissions Feb 29, 2024 am 10:04 AM

In Docker, the permission problem of the mounting directory can usually be solved by the following method: adding permission-related options when using the -v parameter to specify the mounting directory. You can specify the permissions of the mounted directory by adding: ro or :rw after the mounted directory, indicating read-only and read-write permissions respectively. For example: dockerrun-v/host/path:/container/path:roimage_name Define the USER directive in the Dockerfile to specify the user running in the container to ensure that operations inside the container comply with permission requirements. For example: FROMimage_name#CreateanewuserRUNuseradd-ms/bin/

Linux system and kernel parameter optimization under high concurrency conditions Linux system and kernel parameter optimization under high concurrency conditions Aug 04, 2023 pm 04:41 PM

As we all know, Linux does not support high concurrency well under the default parameters, which is mainly limited by the limit on the maximum number of open files in a single process, kernel TCP parameters, and IO event distribution mechanism. Below, we will adjust from several aspects to enable the Linux system to support a high-concurrency environment.

What is the concept of Buffer in java What is the concept of Buffer in java Apr 28, 2023 pm 05:13 PM

1. Concept of using JavaNIOBuffers to interact with NIOChannel. Read data from Channel to buffers, and write data from Buffer to Channels; the three properties of Buffer must be controlled, namely capacity, position-location, and limit. 2. Instance publicstaticvoidmain(String[]args){//Generate a buffer with a length of 10IntBufferintBuffer=IntBuffer.allocate(10);for(inti=0;i

Linux is getting Blue Screen of Death for kernel panic Linux is getting Blue Screen of Death for kernel panic Jun 24, 2024 pm 06:47 PM

Late last year, version 255 of the Linux system management service systemd was given the ability to display Blue Screen of Death (BSOD) style error messages in full-screen mode. However, this solution does not work for kernel errors, so the upcoming

CentOS7 users need to update: Linux Kernel patch released CentOS7 users need to update: Linux Kernel patch released Jan 07, 2024 pm 09:21 PM

Based on the freely released source of Red Hat Enterprise Linux 7, the CentOS 7 branch inherits the feature of always getting the latest kernel security updates. Today, the system team released a very important patch to promptly fix four recently discovered vulnerabilities, and recommended users to install the patch as soon as possible and upgrade to kernel-3.10.0-514.10.2.el7. According to the RHSA-2017:0386-1 security advisory, one of the vulnerabilities fixed by this kernel patch is LinuxKernelKVM (Kernel-basedVirtualMachine) deployment (CVE-2016-8630), when undefined instructions are executed and simulated

Reasons for the recent surge in MODE currency Reasons for the recent surge in MODE currency Dec 06, 2024 am 11:43 AM

Mode coin’s listing on the OKX exchange marks a milestone in its entry into the mainstream cryptocurrency market. Binance CEO Changpeng Zhao expressed his optimism about the project, bringing confidence and credibility to Mode coin. An active and growing community creates enthusiasm and engagement for the project. Mode Coin’s tokenomics reward long-term holders and community contributors, while the booming DeFi industry provides a backdrop for growth.

See all articles