GatewayWorker 有以下特性(更多請參考官網手冊)php
咱們主要使用它的WebSocket通信協議,而且此框架很是方便的與 ThinkPHP,laravel 等框架結合使用,GatewayWorker可獨立部署,php負責相關的業務邏輯
即時通信中,最重要的是響應速度,咱們須要展現 「消息列表」 那麼這時會有 未讀消息,未讀數量,最後一條消息內容,時間等等。
羣聊|私聊效果圖laravel
消息列表效果圖web
參數名 | 說明 |
---|---|
id | 主鍵 |
sender_id | 發送者id |
receive_id | 接收者id |
chat_identify | 標識 :a與b聊天,b與a聊天。記錄 a-b |
message_details | 消息內容 |
last_time_at | 聊天時間間隔 超過必定時間時記錄 |
每一個用戶的列表都是一個集合 key = message_list:user_id
Redis集合存儲 消息類型 1私信,2羣聊 message_list:user_id{ json_encode(['消息類型','接收者id|羣組id']), json_encode(['消息類型','接收者id|羣組id']), json_encode(['消息類型','接收者id|羣組id']), } 查找每一個人的消息列表,直接取出該列表便可,但每一個成員 都要對應 ‘未讀消息數量’,‘最後一條消息內容’,‘最後一條小時時間’。因爲是可變的,因此須要單獨存儲 Redis 鍵值 key = message_content:user_id_消息類型_id key =>json_encode(['消息數量','最後一條消息內容','時間']) 上面 集合列表裏的每個成員都 對應這裏的每一個鍵值。
私聊|羣聊 記錄表。目前設計是單表單庫。顯然,隨着用戶量增長,必然爆棚。影響查詢的響應速度。redis