现象:
用ss -tnpl 'sport = :80' 命令,发现对于同一个IP+Port,一个进程内会有多个fd与之对应。
经过修改listen 指令的参数发现是reuseport导致的。
调试
1. Gdb 调试worker进程发现listening数组中的端口被复制了。
2. 搜索代码发现在ngx_event_module中,对reuseport的端口做了特殊处理,如果是reuseport的端口,那么就给每个worker进程都复制一份,在ngx_open_listening_sockets的时候,每个worker进程就都有了。
原因
具体原因见https://trac.nginx.org/nginx/changeset/7315/nginx。在这之前的版本
1. 如果worker_processes指令在listen ..reuseport之后被解析,那么这个连接就不会被克隆到worker进程中。
2. 这也简化了接下来的worker connections数目的检查,因为它也需要知道在clone之前的监听套接字个数。
基于这两点,就在event模块对reuseport的端口进行了clone。