隨著WEB技術的發展,企業級三層Web應用已經非常流行了,以Servlet技術為例,Web浏覽器,Servlet中間層,後台數據庫服務器構成了這三層結構,結構非常清晰,對設計和開發帶來了很多方便,但是大家都知道,層與層之間連接,再加上大量的邏輯運算和數據讀取放在了中間層服務器端完成,導致了Web的性能問題一直使開發人員很頭疼,我就我在開發一個文檔中心系統過程中關於如何改善jsp(SUN企業級應用的首選)性能的一些想法寫出來,希望大家多多提意見。
我的想法是把對象保存為文件的形式,這裡文件的格式很多,可以是xml(標准化越來越近了)格式的,也可以是通過序列化的對象產生的自定義的文件,這裡我講的是後一種。中間層讀取數據時不是從數據庫中讀取,而是讀本地的文件,新增,修改時也是一樣。減少了中間層服務器連接數據庫服務器的次數,利用讀取和寫中間層服務器的硬盤文件來代替去操作數據庫,提高了jsp(SUN企業級應用的首選)的性能。
具體實現描述如下:以文檔對象(Document)為例,我的文檔數據表在數據庫中保存一份,文檔對象以文件的形式在中間層服務器本地硬盤保存一份,用戶進入閱讀界面閱讀一篇文檔時,這個頁面根據所請求的文檔ID會生成一個文檔對象,Document doc=new Document(ID),然後文檔的其他屬性從以文檔ID命名的文件中獲取,
FileInputStream fis=new FileInputStream(doc.getID());
ObjectInputStream ois=new ObjectInputStream(fis);
doc =(Document)os.readObject();
(標准化越來越近了):namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />
新增或修改文檔時:
Document doc=new Document();
doc.setID(…);
doc.setTitle(…);
doc.setKeyWord(…);
……
FileOutputStream fos=new FileOutputStream(doc.getID());
ObjectOutputStream oos=new ObjectOutputStream(fos);
oos.writeObject(doc);
oos.flush();
產生新的或覆蓋原有的文件,在用戶閱讀這篇文檔的時候(在這個系統中當新增或修改完文檔後馬上轉入浏覽該文檔頁面),我在後台將這個文檔的屬性加入到數據庫中,這樣用戶不用等到所有的操作完成之後才能看到頁面,這樣也分攤了中間層服務器的負擔,因為文檔表關聯了很多的視圖,所以新增或修改的時候我同時更新了文件和數據表,而像評論,日志這樣獨立的表,可以只用更新相應文件就可以了,等到了晚上中間層服務器空閒的時候再來更新評論,日志表.這樣效果會更好。
下面來介紹一下它的實現,要想讓文件保存對象並能把它復制出來重建對象,這個對象必須
實現序列化接口(Serializableinterface),對於這個類來說,該接口不需要實現任何方