這篇文章主要講解了“PHP信號處理機制的詳細介紹”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“PHP信號處理機制的詳細介紹”吧!
我們首先來看下實例代碼:
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);
}最好自己手動循環處理信號隊列,而不是使用php提供的的declare(ticks=1),tick_handler()這種信號處理機制,因為tick機制的性能問題,每執行一條語句都回調tick_handler查看是否有信號,而很大部分時間是沒有信號的。
posix_signal設置信號的回調處理,
posix_kill僅僅是把信號放入進程的信號待處理隊列中,所有并不會觸發信號回調,由pcntl_signal_dispatch處理信號隊列中的信號
posix_getpwnam("nginx"):獲取用戶名的uid,gid等信息
pcntl_signal(SIGPIPE, SIG_IGN, false):忽略內核發來的SIGPIPE信號,當連接已closed,進程繼續發數據到無效socket,系統會收到含RST 控制位TCP包,系統會發出一個SIGPIPE信號給進程,告訴進程這個連接已經斷開了,不要再寫了。該信號的默認處理是終止進程,進程可以捕獲它并忽略該信號以免不情愿的被終止。
socket上下文選項:
backlog:用于限制流監聽隊列中未完成連接的連接數量
so_reuseport:重用端口(由內核調度連接到多個監聽同一個端口的進程,由于是通過hash方式來標志連接對應的進程,所以監聽進程數是不能改變的,)
定時器信號處理
pcntl_signal(SIGALRM,"sig_handler");
pcntl_alarm(2);
function sig_handler($sig)
{
echo "one second after";
}
while (1)
{
pcntl_signal_dispatch();
sleep(1);
}感謝各位的閱讀,以上就是“PHP信號處理機制的詳細介紹”的內容了,經過本文的學習后,相信大家對PHP信號處理機制的詳細介紹這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。