最近發現,很多網友喜歡把tomcat的work目錄裡的東西叫做緩存,其實那不是很恰當,work目錄只是tomcat的工作目錄,也就是tomcat把jsp轉換為class文件的工作目錄,這也正是為什麼它叫work目錄而不是cache目錄的原因。
jsp,tomcat的工作原理是當浏覽器訪問某個jsp頁面時,tomcat會在work目錄裡把這個jsp頁面轉換成.java文件,比如將index.jsp轉換為index_jsp.java文件,而後編譯為index_jsp.class文件,最後tomcat容器通過ClassLoader類把這個index_jsp.class類裝載入內存,進行響應客戶端的工作。
tomcat會定時稍描容器內的jsp文件,讀取每個文件的屬性,當發現某個jsp文件發生改變時(文件的最後修改時間與上次稍描時不相同時),tomcat會重新轉換、編譯這個jsp文件。但是tomcat的稍描是定時的不是實時的,這也正是為什麼jsp文件修改後需要幾分鐘的時間來等修改過的jsp生效。當然為了即刻生效,很多老前輩都會建議在修改jsp頁面後立即清除work目錄裡的文件。
另外,tomcat容器中,對轉換後的java文件(比如:index_jsp.java)的編譯最大只支持64k,所以在其他容器中的jsp移植到tomcat容器中時會遇到大jsp文件會發生無法編譯的情況,所以建議把jsp中的業務邏輯寫入單獨的類,在jsp中通過調用這個類的靜態方法來執行,並將jsp頁面中的js提取出來放到單獨的js文件內。