nginx sendfile parameter explanation
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.

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

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

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

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.

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.

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/

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.

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

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

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

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.
