我們首先來看下實(shí)例代碼:
function sig_handler($sig)
{
print("handled sig: $sig\n");
}
pcntl_signal(SIGIO, "sig_handler");
posix_kill(posix_getpid(),SIGIO);
while(true)
{
posix_kill(posix_getpid(),SIGIO);
pcntl_signal_dispatch();
sleep(1);
}
最好自己手動(dòng)循環(huán)處理信號(hào)隊(duì)列,而不是使用php提供的的declare(ticks=1),tick_handler()這種信號(hào)處理機(jī)制,因?yàn)閠ick機(jī)制的性能問題,每執(zhí)行一條語句都回調(diào)tick_handler查看是否有信號(hào),而很大部分時(shí)間是沒有信號(hào)的。
posix_signal設(shè)置信號(hào)的回調(diào)處理,
posix_kill僅僅是把信號(hào)放入進(jìn)程的信號(hào)待處理隊(duì)列中,所有并不會(huì)觸發(fā)信號(hào)回調(diào),由pcntl_signal_dispatch處理信號(hào)隊(duì)列中的信號(hào)
posix_getpwnam("nginx"):獲取用戶名的uid,gid等信息
pcntl_signal(SIGPIPE, SIG_IGN, false):忽略內(nèi)核發(fā)來的SIGPIPE信號(hào),當(dāng)連接已closed,進(jìn)程繼續(xù)發(fā)數(shù)據(jù)到無效socket,系統(tǒng)會(huì)收到含RST 控制位TCP包,系統(tǒng)會(huì)發(fā)出一個(gè)SIGPIPE信號(hào)給進(jìn)程,告訴進(jìn)程這個(gè)連接已經(jīng)斷開了,不要再寫了。該信號(hào)的默認(rèn)處理是終止進(jìn)程,進(jìn)程可以捕獲它并忽略該信號(hào)以免不情愿的被終止。
socket上下文選項(xiàng):
backlog:用于限制流監(jiān)聽隊(duì)列中未完成連接的連接數(shù)量
so_reuseport:重用端口(由內(nèi)核調(diào)度連接到多個(gè)監(jiān)聽同一個(gè)端口的進(jìn)程,由于是通過hash方式來標(biāo)志連接對(duì)應(yīng)的進(jìn)程,所以監(jiān)聽進(jìn)程數(shù)是不能改變的,)
定時(shí)器信號(hào)處理
pcntl_signal(SIGALRM,"sig_handler");
pcntl_alarm(2);
function sig_handler($sig)
{
echo "one second after";
}
while (1)
{
pcntl_signal_dispatch();
sleep(1);
}
您可能感興趣的文章:- php 中的信號(hào)處理操作實(shí)例詳解
- python多線程下信號(hào)處理程序示例
- 對(duì)Python信號(hào)處理模塊signal詳解
- Golang信號(hào)處理及如何實(shí)現(xiàn)進(jìn)程的優(yōu)雅退出詳解
- Perl信號(hào)處理學(xué)習(xí)簡單小結(jié)
- 詳細(xì)分析C++ 信號(hào)處理