Address
https://github.com/langsim/nginx-1.6.2-comment
Introduction
I hope to complete a highly readable nginx source code comment.
Content that will not be commented
- spdy-related code, because spdy has been replaced by http2.
- Thread-related code, because at least in version 1.6.2 nginx threads are still in the experimental stage.
- Others than Linux Platform code.
- Code of other event models other than epoll
- Code of other compilers other than gcc.
- mail-related code.
Completion level
- core directory 60%
- event directory 20%
- http directory 10%
- os directory 80%
Function linked list
- http filter module, ngx_http_top_header_filter and ngx_http_top_body_filter will form two function linked lists, the calling order of the functions in the linked list will be the same as that of the corresponding module in the ngx_modules array The order is reversed.
- Many of the 11 stages of http request processing can have multiple callback functions. The order of calling callback functions in the same stage is the same as the order of the corresponding modules in the ngx_modules array.
Log
nginx has two log files by default:
- access.log: Each http request will generate a line of records in it.
- error.log: Some general, error or debug logs when nginx is running.
Process model
Four process states may appear after nginx is started:
- Single process running in the foreground
- Single process daemon mode
- One master process, one (or more) worker processes, one (or 0) ) cachemanager processes and one (or 0) cacheloader processes run together in the foreground
- A master process, one (or more) worker processes, one (or 0) cachemanager processes and one (or 0) cacheloader processes are in Run in daemon state.
- The master process is used to start other processes during startup, and is used to manage other processes after startup is completed.
- woker process, used to actually handle link requests.
- The cachemanager process is used to clean cache files as required.
- When the cacheloader process starts, it will index the cache files that meet the requirements in the cache directory in the memory, clear the cache files that do not meet the requirements, and then exit.
- After starting, send a signal to the main process of running nginx, and then exit.
Switching of process running status
- Reload configuration file (reload)
- Hot upgrade executable file
Compilation
nginx compilation is the same as the compilation method of regular open source software on the Linux platform, both are run./ configure && make && make install, you can add your own custom options after ./configure.
nginx uses signals
- TERM, INT for quick shutdown
- QUIT for graceful shutdown
- HUP for smooth restart and reloading the configuration file
- USR1 to reopen the log file, which is more useful when cutting logs
- USR2 for smooth upgrade executable The program
- WINCH shuts down the working process gracefully
nginx memory pool
nginx has two memory pools
- The memory pool used to allocate memory on shared memory
- The memory pool used to apply for memory on ordinary memory, the purpose is Efficient use of memory
nginx uses calculation hash algorithm
- crc32
- crc16
- sha1
- murmurhash
- md5
nignx process communication and synchronization
- shared memory Use
- signal
- unix socket
').addClass('pre-numbering').hide();
$(this).addClass('has-numbering').parent().append($numbering);
for (i = 1; i ').text(i));
};
$numbering.fadeIn(1700);
});
});
The above introduces the (personal open source) nginx source code comments, including the relevant content. I hope it will be helpful to friends who are interested in PHP tutorials.