關于隊列可以參考我博客一篇的文章, [Redis 實現隊列](https://segmentfault.com/a/1190000011084493)
這里主要說下多個消費者管理問題.
- 采用swoole多進程管理多個worker消費者,worker消費者可以分為兩類,一種是靜態worker,靜態worker退出后會重啟,一個隊列會保持固定數量的靜態worker;另一種是動態worker,只有當隊列積壓過多任務數,會動態新增worker緩解壓力,當動態worker處理完任務后退出不重啟;
- 每個worker可以設置worker最大執行時間,最大執行任務數,這樣的好處是防止worker內存溢出;
- 當然不要開太多進程,進程切換開銷很大的;
- 可以參考我的框架[zcswoole消息隊列](http://www.hmoore.net/wuzhc/zcswoole/742975)
- php
- 編譯安裝
- 基本概念
- 垃圾回收機制
- 生命周期
- zval底層實現
- c擴展開發
- gdb調試工具
- 自定義擴展簡單demo
- 鉤子函數
- 讀取php.ini配置
- 數組
- 函數
- 類
- yaf擴展底層源碼
- swoole擴展底層源碼
- memoryGlobal內存池
- swoole協程使用記錄
- 單點登錄sso原理
- compser使用
- session實現機制
- c & linux
- gcc
- 指針
- 結構體,聯合和位字段
- 宏定義井號說明
- printf家族函數和可變參數
- 共享函數
- 靜態庫和動態庫
- makefile自動化構建
- 信號一
- 信號二
- inotify監控文件事件
- socket編程
- 簡介
- UNIX DOMAIN
- Internet DOMAIN
- TCP/IP
- 文件IO多路復用
- 內存管理
- 進程組,會話和控制終端
- daemon守護進程
- 多進程
- 多線程
- 常用進制轉換
- go
- 入門知識
- 字節和整數裝換
- python
- redis
- 應用場景
- 消息隊列
- 熱點數據
- 掃碼登錄
- 訂閱發布
- 次數限制
- 搶購超賣
- 持久化機制
- mysql
- 工作流程
- MyISAM和InnoDB區別
- 用戶和權限管理
- 執行計劃
- sql優化
- 事務和鎖
- 慢查詢日志
- case...when...then...end用法
- sql
- 參考
- linux
- 內核參數優化
- 防火墻設置
- docker
- docker入門知識
- 算法
- 多維數組合
- DFA算法
- 紅包金額分配