|
Loader對象可出現(xiàn)在Context中以控制Java類的加載。屬性:delegate,true代表使用正式的Java代理模式(先詢問父類的加載器);false代表先在Web應(yīng)用程序中尋找。默認(rèn)值:false 首先,你需要了解一下JVM的Classloader機(jī)制(詳細(xì)請自行g(shù)oogle之)。 簡而言之,JVM的classloader加載繼承關(guān)系分為BootstarpClassLoader --> ExtClassLoader --> SystemClassLoader,應(yīng)用的WebAppClassLoader繼承自SystemClassLoader,在加載具體某個類時,一般會先委托給父類ClassLoader,當(dāng)父類ClassLoader無法加載成功時,才會再由子類ClassLoader嘗試加載,這就是所謂的delegate機(jī)制。 其次,Tomcat在jvm的ClassLoader機(jī)制上增加了幾個繼承層次。 SystemClassLoader --> CommonClassLoader -->(ServerClassLoader | SharedClassLoader --> WebAppClassLoader)。 CommonClassLoader用來加載${CATALINA_HOME}/conf/catalina.properties中common.loader配置目錄下的類文件,一般是用來加載${CATALINA_HOME}/lib下的文件。該loader加載的類為tomcat服務(wù)器和tomcat下面的所有webApp所共享。 ServerClassLoader用來加載${CATALINA_HOME}/conf/catalina.properties中server.loader配置目錄下的類文件,一般是用來加載${CATALINA_HOME}/server下的文件。該loader加載的類為tomcat服務(wù)器所獨(dú)有核心類,tomcat下面的WebApp無法訪問。 SharedClassLoader用來加載${CATALINA_HOME}/conf/catalina.properties中shared.loader配置目錄下的類文件,一般是用來加載${CATALINA_HOME}/shared下的文件。該loader加載的類為tomcat下面的所有webApp所共享。 WebAppClassLoader用來加載${CATALINA_HOME}/webapps/目錄下每個WebApp應(yīng)用的/WEB-INF/class,/WEB-INF/lib的類文件,每個WebApp對應(yīng)一個WebAppClassLoader,用來加載其所需要的類文件。 最后,說一下delegate配置的意義。 True,表示tomcat將遵循JVM的delegate機(jī)制,即一個WebAppClassLoader在加載類文件時,會先遞交給SharedClassLoader加載,SharedClassLoader無法加載成功,會繼續(xù)向自己的父類委托,一直到BootstarpClassLoader,如果都沒有加載成功,則最后由WebAppClassLoader自己進(jìn)行加載。 False,表示將不遵循這個delegate機(jī)制,即WebAppClassLoader在加載類文件時,會優(yōu)先自己嘗試加載,如果加載失敗,才會沿著繼承鏈,依次委托父類加載。 在此說一下配置為False需要注意的問題:一旦配置為False,如果你在WebApp中自己定義了一個java.lang.String,則這個String類會有可能覆蓋掉jdk中的String類,這也許不是你想要的結(jié)果。另外對于多個WebApp公用jar包,你可能會放到${CATALINA_HOME}/shared目錄中共享,但是一不小心在應(yīng)用的/WEB-INF/lib中也包含了一個同名的但版本不一致的jar的話,這就有可能會導(dǎo)致很多奇怪的問題。 轉(zhuǎn)自https://segmentfault.com/q/1010000000155690/a-1020000000155732
|