在線聊天室(online chatrooms)是一個共多人進行溝通交流的網絡平台,隨著越來越多的新技術的發明和成熟運用,在線聊天室也出現使用各種不同技術的, 這篇文章我想簡單總結一下。
首先說一下前台技術,最新的當然是基於HTML5的websocket,它實現了浏覽器與服務器全雙工通信(full-duplex)。WebSocket通信協議於2011年被IETF定為標准 RFC 6455,WebSocketAPI被W3C定為標准。在WebSocket API中,浏覽器和服務器只需要做一個握手的動作,然後,浏覽器和服務器之間就形成了一條快速通道。兩者之間就直接可以數據互相傳送。但是由於Websocket是HTML5的API,很多浏覽器都還得不到支持,所以這種方式現在應用不是特別多。第二種是ajax,它是采用一種輪詢的方式,每隔一段時間,去服務器上下載數據,查看是否更新,它的優點是異步請求處理(也可以設置同步),不會阻塞用戶其它操作,缺點是不間斷的輪詢不僅占用消耗帶寬,也占用過多的終端和服務器資源,而且由於ajax輪詢有時間間隔,所以獲得的消息不是實時的,因為不是消息觸發,ajax的效率幾乎是最低的。第三種是基於服務器的推送技術(comet),說是推送,其實是偽推送,原理是在終端和服務器之間建立一條長連接,前台通過判定這條長連接的內容是否改變而獲取內容,它的優點是占用資源較少,實時性好,確實是需要服務器特別的支持,而且長時間占用連接。現在越來越多的服務都采用了這種技術。
再來說下後台,聊天室屬於高IO的應用,數據庫方面可能是最大瓶頸,聊天的特點是短文本較多,類似於微博。而且它屬於多用戶系統,當用戶達到一個數量級時,如果采用Mysql等關系型數據庫的話,查詢的壓力應該是很大的。如果沒有特殊的要求,個人認為,聊天記錄不需要永久存儲,這時候memcache,redis等基於內存的存儲系統就能發揮作用了。下面是我開發的一個簡單的基於ajax+php+memcache的在線聊天室。
在這個聊天室中,所有聊天記錄都存放在memcache中,用cid存儲聊天記錄的最大id,用msgcid存放聊天記錄,每插入一條記錄,cid自增1。前台通過ajax獲取獲取json格式數據,由於memcache是基於內存的特性,整體系統運行速度是非常快的。下面是系統的源碼,整個系統只有兩個文件,合起來不到10KB。
下載
https://github.com/hitoy/online-chatroom
系統需求:
1,安裝有memcache
2,php安裝memcache擴展
3,支持Javascript和ajax的現代浏覽器