我看我們公司私聊和群聊這種功能在設(shè)計上是單表的,群里一個人發(fā)送消息后,沒當前群里每個人都存儲一條數(shù)據(jù)。我感覺這樣的方式肯定是有問題,群里有1000人,每人發(fā)送一條消息,將要存儲1000*1000記錄,而且很多都是冗余信息。是不是應(yīng)該維護一個群組聊天記錄表,根據(jù)當前用戶所在的群組去找當前群組聊天記錄?還是說通過消息中間件那種訂閱主題模式,每一個群組做為一個主題群組成員去訂閱,然后實現(xiàn)分發(fā)。請問下qq實現(xiàn)這種功能機制什么,求一個最佳實踐,謝謝
關(guān)于聊天記錄我個人在設(shè)計網(wǎng)站消息分發(fā)的時候邏輯是
設(shè)置一個字段
0:面向所有用戶的消息(群發(fā))
n:給特定某個用戶發(fā)的消息(發(fā)給用戶id為n的用戶)
所以你可以像上述方式設(shè)計,在群調(diào)取后臺記錄時候調(diào)取后臺的標記為0的消息即可
(不過我這個是設(shè)計為單群(也就是網(wǎng)站全站消息),多群消息的話你可以自己結(jié)合這個邏輯考慮一下)
(不一定有用,不過這樣可以節(jié)省數(shù)據(jù)庫空間,也就是說,用戶在調(diào)取自己信息的時候數(shù)據(jù)庫會返回用戶id相符和與字段為0的消息)
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學院和江蘇省首批服務(wù)外包人才培訓基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團,成為集合面授教學培訓、網(wǎng)
達內(nèi)教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務(wù)負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。