1。系統架構:
采用模塊化思想,分為3層:
a。數據存儲層:使用MySQL來存放bbs的所有數據,包括用戶信息,文章數據,用戶信件,用戶消息,系統數據(?),關鍵問題: 數據庫的規劃,是否用文件來輔助。
b。系統功能層:完成bbs的基本功能,由多個並列模塊組成,向下調用MySQL的函數訪問數據庫,向上,接受處理請求,將處理的結果返回上層,根據請求類型,返回成敗結果和其他數據。而且模塊高度靈活,可以方便的修改增加。包括:
** 用戶模塊,處理用戶的注冊,基本數據的修改,權限的變化,網友信息的查詢。
** 版面模塊,完成文章發表,文章的讀取,文章的刪除,文章的加標記,讀改刪權限檢查,此模塊對數據庫的要求最高。
** 精華區模塊,包括精華區的文章,目錄的增加,刪除,上下移動
(?)讀改刪權限檢查,目錄結構是其中的難點。
** 信件模塊,包括發新信件,讀刪信件,信箋標記,新信件的通知
** 消息模塊,包括發送消息,接受消息,新消息通知,消息回顧,消息存信件。
** 系統動態模塊,包括當前上站人數,當前動態,由於變動頻繁,此類數據用共享內存實現可能更好。
** 聊天模塊,雙人聊天是否能借鑒icq的做法,由雙方直接通話,但聊天結果存信件可能較麻煩,同時,為兼容telnet功能,當上層服務層為telnet時,增加專門的模塊來進行處理。
** 聊天室模塊,利用共享內存還是數據庫?開房間,裡面的權限問題。根據需要,還能增加新的功能。例如:活動看板模塊,但對於非telnet終端,意義好象不大。。。。。
c。服務層:直接和客戶機對話,根據客戶機的請求,調用功能模塊取得數據,然後將數據發送回客戶端,根據客戶端的類型,分別開發不同的服務模塊,並且盡可能合理進行抽象,使對不同的服務層,能共用系統功能層的模塊。具體包括:
++ cq66服務端,采取原cq66的方式,並重新規劃協議,支持系統功能層的所有功能,但要用專門的客戶端程序(cq66),如果能做到向下兼容則更好,客戶端程序要隨服務端的升級而升級,用戶可能有點不便。有需要可以在傳輸過程中加入加密功能,類似ssh。
++ telnet服務端,采用舊bbs的方式,有些功能不支持,客戶端無須升級,服務器端要保存客戶方的狀態,並根據客戶端的按鍵來判斷狀態的轉移,並由此得出所需的數據,(例如閱讀某篇文章),然後再向系統功能層請求數據,然後將數據加以處理(例如加上頂行,尾行)然後返回數據,可以在現有的bbsd上修改,可以省去io模塊的設計但難度較大,除文章方面好一點外,其他比較難改,但從頭寫起太費力。
++ httpd服務端,所需的功能更少,相對較簡單,本來直接調用MySQL數據庫也行,直接可以用PHP,但考慮到分層的原則,建議仍用c編CGI的方式實現不知能不能在原來的基礎上修改呢?估計不行。
系統的關鍵和難點:
a。數據庫的設計,MySQL支持大量的table嗎?例如幾萬?每個用戶至少一個表,然後每個版一個表,精華區的表結構可能更復雜。
但應該總會比現在bbs的文件結構清晰一些,效率也高一點吧,排序和cache的功能可以信賴MySQL吧。
b。MySQL中文本字段的大小限制,限制一篇文章不得大於64k不過分吧,而且從效率的角度,將一篇文章以最大2k的塊為單位存放可能更好,這樣,當telnet用戶看文章時,telnet服務器不用每次都查詢數據庫讀取幾十k的數據,再將其中的某2k傳給用戶,可局部補償數據庫字段不能象文件那樣從中間讀取一部分。不過這樣文章字段數據的管理比較復雜。
2。系統開發計劃:
先考慮用戶模塊和版面模塊,規劃好數據結構,應該很容易和現有bbsd結合