[請益] 關於websocket實作聊天室的問題

看板PHP作者 (阿轉)時間9年前 (2016/07/13 17:35), 編輯推噓1(1020)
留言21則, 5人參與, 最新討論串1/1
不好意思 最近剛開始接觸網頁設計 想請問一下關於聊天室的設計 版上的文大概都爬了 也Google了很多websocket的文章 目前大概只只能寫出用自己本機掛server.php會一直回傳date給client 我想寫像FB或wootalk那樣的聊天室 (可能是1-1或n-n) 想請問如果是1-1的話,假如A和B 1.那麼A.B兩人的訊息都是由server端回傳印嗎? 還是自己key的訊息由自己client直接印,對方的server回傳後再印 後者會對效能比較好嗎?不過如果要像FB那樣保留歷史訊息是不是還是得經過server進後 端資料庫 2.假設A-B兩人聊天、C-D兩人聊天,server端要怎麼知道A和B的訊息要丟給A和B,C和D的 訊息要丟給C和D? 還是每次有訊息進來就存到資料庫再把資料庫資料丟回去?(資料表有row紀錄sender和r eceiver) 但是如果是這樣靠資料庫判斷的話,如果有x個人的群組該怎麼辦呢? 不好意思,這方面觀念沒有很好,謝謝 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 1.168.78.51 ※ 文章網址: https://www.ptt.cc/bbs/PHP/M.1468402557.A.030.html

07/13 17:59, , 1F
就記群組裡面有誰 然後群組內對話通通送一份啊
07/13 17:59, 1F

07/14 08:37, , 2F
對話區要統一收server給的,對話前後順序才會一致
07/14 08:37, 2F

07/14 09:30, , 3F
public subscribe pattern
07/14 09:30, 3F

07/25 12:22, , 4F
html5 webrtc
07/25 12:22, 4F

07/26 01:49, , 5F
通常我會建立一個聊天室成員物件 必要屬性要有
07/26 01:49, 5F

07/26 01:50, , 6F
群組ID 和 使用者唯一編號 最少要有這2個 就可以達到
07/26 01:50, 6F

07/26 01:51, , 7F
分群 和 私聊了
07/26 01:51, 7F

07/26 01:52, , 8F
A和B的訊息要丟給A和B 這屬於私聊 透過使用者唯一編號
07/26 01:52, 8F

07/26 01:52, , 9F
就會知道聊天訊息要傳給誰
07/26 01:52, 9F

07/26 02:02, , 10F
基本上即時聊天訊息 不會從資料庫讀出 除非是歷史訊息
07/26 02:02, 10F

07/26 02:03, , 11F
即時訊息 量是很恐怖的 資料庫會受不了 我的做法
07/26 02:03, 11F

07/26 02:04, , 12F
當接收到訊息 在伺服器可以把訊息緩存或直接就轉發
07/26 02:04, 12F

07/26 02:05, , 13F
訊息緩存的好處是 近期的歷史訊息不用到資料庫 就可以
07/26 02:05, 13F

07/26 02:06, , 14F
讀出 比如你收到一個群組為PP 目標使用者編號1234
07/26 02:06, 14F

07/26 02:07, , 15F
就去掃描你目前的線上聊天名單 有關群組PP 編號1234
07/26 02:07, 15F

07/26 02:08, , 16F
發送訊息即可 線上名單也是緩存 不用讀資料庫
07/26 02:08, 16F

07/26 02:09, , 17F
開發聊天室 資料庫只是輔助 其他都緩存 如果要保留
07/26 02:09, 17F

07/26 02:10, , 18F
聊天室訊息寫入資料庫 也建議不要一筆訊息就寫入一次
07/26 02:10, 18F

07/26 02:10, , 19F
這樣訊息量一堆資料庫效能會變低落 可以把訊息緩存到
07/26 02:10, 19F

07/26 02:11, , 20F
比如 500條訊息 在一次性寫入 這樣會對於資料表有索引
07/26 02:11, 20F

07/26 02:11, , 21F
速度會差非常多
07/26 02:11, 21F
文章代碼(AID): #1NXWjz0m (PHP)
文章代碼(AID): #1NXWjz0m (PHP)