作者defsrisars (阿轉)
看板PHP
標題[請益] 關於websocket實作聊天室的問題
時間Wed Jul 13 17:35:54 2016
不好意思
最近剛開始接觸網頁設計
想請問一下關於聊天室的設計
版上的文大概都爬了
也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://webptt.com/m.aspx?n=bbs/PHP/M.1468402557.A.030.html
1F:→ MOONRAKER: 就記群組裡面有誰 然後群組內對話通通送一份啊 07/13 17:59
2F:→ xdraculax: 對話區要統一收server給的,對話前後順序才會一致 07/14 08:37
3F:→ alpe: public subscribe pattern 07/14 09:30
4F:推 lhsieh: html5 webrtc 07/25 12:22
5F:→ et69523820: 通常我會建立一個聊天室成員物件 必要屬性要有 07/26 01:49
6F:→ et69523820: 群組ID 和 使用者唯一編號 最少要有這2個 就可以達到 07/26 01:50
7F:→ et69523820: 分群 和 私聊了 07/26 01:51
8F:→ et69523820: A和B的訊息要丟給A和B 這屬於私聊 透過使用者唯一編號 07/26 01:52
9F:→ et69523820: 就會知道聊天訊息要傳給誰 07/26 01:52
10F:→ et69523820: 基本上即時聊天訊息 不會從資料庫讀出 除非是歷史訊息 07/26 02:02
11F:→ et69523820: 即時訊息 量是很恐怖的 資料庫會受不了 我的做法 07/26 02:03
12F:→ et69523820: 當接收到訊息 在伺服器可以把訊息緩存或直接就轉發 07/26 02:04
13F:→ et69523820: 訊息緩存的好處是 近期的歷史訊息不用到資料庫 就可以 07/26 02:05
14F:→ et69523820: 讀出 比如你收到一個群組為PP 目標使用者編號1234 07/26 02:06
15F:→ et69523820: 就去掃描你目前的線上聊天名單 有關群組PP 編號1234 07/26 02:07
16F:→ et69523820: 發送訊息即可 線上名單也是緩存 不用讀資料庫 07/26 02:08
17F:→ et69523820: 開發聊天室 資料庫只是輔助 其他都緩存 如果要保留 07/26 02:09
18F:→ et69523820: 聊天室訊息寫入資料庫 也建議不要一筆訊息就寫入一次 07/26 02:10
19F:→ et69523820: 這樣訊息量一堆資料庫效能會變低落 可以把訊息緩存到 07/26 02:10
20F:→ et69523820: 比如 500條訊息 在一次性寫入 這樣會對於資料表有索引 07/26 02:11
21F:→ et69523820: 速度會差非常多 07/26 02:11