> 當有多個客戶端一起請求的時候,服務端不可能來多少就處理多少,如果并發太多,就會因為性能的因素發生擁塞,然后造成雪崩。所以就搞了一個隊列,先將請求放在隊列里面,一個個來。
socket_listen里面的第二個參數backlog就是設置這個隊列的長度。如果將隊列長度設置成10,如果有20個并發請求,服務端就會先放10個請求進入這個隊列,然后其他的就直接拒絕。tcp協議這時候不會發送rst給客戶端,這樣的話客戶端就會重新發送SYN,以便能進入這個隊列。
資料來源:
https://www.jianshu.com/p/e6f2036621f4
http://www.cnblogs.com/yangwenxin/p/6601194.html
- 前言
- 函數參考
- Socket 函數
- socket_accept
- socket_bind
- socket_clear_error
- socket_close
- socket_connect
- socket_create_listen
- socket_create_pair
- socket_create
- socket_getpeername
- socket_getsockname
- socket_last_error
- socket_listen
- socket_read
- socket_recv
- socket_select
- socket_send
- socket_set_block
- socket_set_nonblock
- SplQueue
- 魔術方法
- 魔術常量
- 雜項
- backlog的用處
- new self()和new static()的區別
- PHP變量的生命周期
- PHP抽象類
- 對象接口
- PHP中的常用關鍵字
- 常量
- 內存泄露
- global 與 $GLOBAL
- 簡單說明CGI和動態請求是什么
- 設計模式
- 單例模式
- 工廠模式
- 適配器模式
- 策略模式
- 觀察者模式
- 控制反轉IoC簡介
- session
- use_trans_sid
- auto_start
- session_id
- cookie_secure
- 面試
- 數據庫相關
- 語句相關
- 索引相關
- 字段相關
- PHP相關
- 字符串相關
- 函數相關
- 運算符優先級相關
- 錯誤相關
- redis相關
- 10個常見的Redis面試"刁難"問題
- mysql
- MySQL中的鎖
- MySQL存儲引擎MyISAM 和 InnoDB的區別
- MySQL半同步復制
- explain 命令詳解
- 索引
- 數據庫事務
- MySQL和B樹的那些事
- git
- github----向開源框架提交pr的過程
- 推薦博客
- linux
- 命令
- free
- 高并發
- 搶購/秒殺功能
- 算法
- 一致性Hash算法