前言
忙碌的人可以就此略過,有閑的人,可以浪費些空閑,看一看無關痛癢的文字。
實時Web,一般人可以玩得起,只要你具有一些JAVA編程知識,外加一些JS實踐,也不是難事。
這里,簡單設計一個基于socketio-netty的實時Web數據驅動平臺,用以托管實時應用,同時也提供了前后端的設計思路,從中也可以看到多租戶架構一些影子。
至于什么是Firebase,什么是socketio-netty,那就只有自行google。
設計思路
后端設計
- 一個應用實例對應一個IOHandler接口實現
- 用戶上傳實現代碼,初始化一個應用實例,產生一個API KEY
- API KEY 客戶端需要顯示引用;API KEY是應用實例一一對應關系
- 服務器端提供java class 的hotswap(熱部署),應用實例動態添加/刪除/替換,做到無縫、平滑
- 暫時不考慮文件系統等,功能為先
socketio-netty支持多個namespace(或許稱為頻道更為合適)的添加,靜態加載示范:
前端實踐
- 一個頁面,支持多個應用實例,支持多個API KEY
- 前端JS須定義
<script src="></script>
- API KEY使用方式和原生的socket.io客戶端使用方式一模一樣,無須多言。
WEB端管理維護
再來一個用戶的系統后臺管理就完備了:
- 上傳JAVA接口實現代碼,前期可只允許上傳.java代碼,以便代碼監測使用(私有,則不需要)
- 查看應用實例,重新生成API KEY等
- 實例維護,暫停/停止/升級/替換/添加等,無縫、平滑等
- 其它常規操作
設計小結
基礎功做好之后,很顯然,您已經實現了一個多租戶架構的實時WEB數據驅動平臺(名頭有些大哈),托管第三方實時應用,有點PAAS的味道。雖然針對的應用很窄,但更專業了。
至于計費,安全,權限等,暫時可以歇歇,想太多,走不了多遠,太累,反而成就感會降低。系統進化演進的,大而全,不如小而精。
這中間,難免需要對socketio-netty做一些定制工作,以適應應用實例的管理工作。
至于實際應用,需要注意的地方還很多,這里不過是一個簡單模型(去掉了非核心的部分)的描述,和Firebase沒有半毛錢的關系。
雖然設計了,不知道實際有沒有人需要這個東西,希望不是空中樓閣。
PS/碎碎語
socketio-netty最近的一些進展(與上面設計不相關):
- 增加示范在線演示
入口地址:http://socketio.yongboy.com/
在線聊天示范 訪問
在線畫板示范 訪問
想了解socket.io或者想了解socketio-netty的,可以點擊一下。
但愿別超出EC2的免費流量限額,可能隨時會關閉。 - 增加使用者名單
http://code.google.com/p/socketio-netty/wiki/UsersCollections
至少,目前已經有一家公司使用于生產環境