SO_REUSEPORT支持多个进程或者线程绑定到同一端口
每个进程可以自己创建socket、bind、listen、accept相同的地址和端口,各自是独立平等的。让多进程监听同一个端口,各个进程中accept socket fd不一样,有新连接建立时,内核只会唤醒一个进程来accept,并且保证唤醒的均衡性
<?php $context=stream_context_create(); stream_context_set_option($context, 'socket', 'so_reuseport', 1); for($i=0;$i<2;$i++){ $pid = pcntl_fork(); if($pid == 0){ while(true){ $socket = stream_socket_server("tcp://0.0.0.0:8000", $errno, $errstr,STREAM_SERVER_BIND | STREAM_SERVER_LISTEN,$context); while ($conn = @stream_socket_accept($socket,5)) { fwrite($conn, getmypid().':时间:' . date('Y-m-d H:i:s') . "\n"); fclose($conn); } fclose($socket); } } } while(1){ $pid = pcntl_wait($status); var_dump($pid,$status); sleep(1); }
本文深入探讨了SO_REUSEPORT套接字选项,它允许多个进程或线程同时绑定到同一端口,实现负载均衡。通过PHP代码示例展示了如何在多进程中使用SO_REUSEPORT进行并发处理,确保了内核在新连接到来时只唤醒一个进程,实现资源的有效利用。
8605

被折叠的 条评论
为什么被折叠?



