PHP中信號處理機制的操作方法?這個問題可能是我們?nèi)粘W習或工作經(jīng)常見到的。希望通過這個問題能讓你收獲頗深。下面是小編給大家?guī)淼膮⒖純?nèi)容,讓我們一起來看看吧!
十年的淮陰網(wǎng)站建設經(jīng)驗,針對設計、前端、開發(fā)、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。成都營銷網(wǎng)站建設的優(yōu)勢是能夠根據(jù)用戶設備顯示端的尺寸不同,自動調(diào)整淮陰建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設計,從而大程度地提升瀏覽體驗。成都創(chuàng)新互聯(lián)公司從事“淮陰網(wǎng)站設計”,“淮陰網(wǎng)站推廣”以來,每個客戶項目都認真落實執(zhí)行。
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); }
最好自己手動循環(huán)處理信號隊列,而不是使用php提供的的declare(ticks=1),tick_handler()這種信號處理機制,因為tick機制的性能問題,每執(zhí)行一條語句都回調(diào)tick_handler查看是否有信號,而很大部分時間是沒有信號的。
posix_signal設置信號的回調(diào)處理,
posix_kill僅僅是把信號放入進程的信號待處理隊列中,所有并不會觸發(fā)信號回調(diào),由pcntl_signal_dispatch處理信號隊列中的信號
posix_getpwnam("nginx"):獲取用戶名的uid,gid等信息
pcntl_signal(SIGPIPE, SIG_IGN, false):忽略內(nèi)核發(fā)來的SIGPIPE信號,當連接已closed,進程繼續(xù)發(fā)數(shù)據(jù)到無效socket,系統(tǒng)會收到含RST 控制位TCP包,系統(tǒng)會發(fā)出一個SIGPIPE信號給進程,告訴進程這個連接已經(jīng)斷開了,不要再寫了。該信號的默認處理是終止進程,進程可以捕獲它并忽略該信號以免不情愿的被終止。
socket上下文選項:
backlog:用于限制流監(jiān)聽隊列中未完成連接的連接數(shù)量
so_reuseport:重用端口(由內(nèi)核調(diào)度連接到多個監(jiān)聽同一個端口的進程,由于是通過hash方式來標志連接對應的進程,所以監(jiān)聽進程數(shù)是不能改變的,)
定時器信號處理
pcntl_signal(SIGALRM,"sig_handler"); pcntl_alarm(2); function sig_handler($sig) { echo "one second after"; } while (1) { pcntl_signal_dispatch(); sleep(1); }
感謝各位的閱讀!看完上述內(nèi)容,你們對PHP中信號處理機制的操作方法大概了解了嗎?希望文章內(nèi)容對大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。