Resin的安裝和配置
Resin 可以在 http://www.caucho.com/download/index.xtp 免費下載和使用。使用Resin開發或者學習是免
費的,但是如果把Resin作為收費產品發布是需要付費的。目前的版本是2.10。
下載Resin 時選擇Archive Versions 中的 windows.zip的普通安裝包resin-2.1.0.zip。
把該zip包解壓到任何目錄下面,如d:/resin。以下介紹都假設Resin安裝在d:/resin下。進入d:/resin/bin,
鍵入httpd,可以在命令列控制台下運行Resin伺服器。此時彈出一個有start 和stop兩個Radio按紐和一close
按紐的對話方塊。在這裡可以看到Resin的運行資訊。這些資訊同時Resin可以在d:/resin/log目錄下面的
stdout.log 記錄檔中察看到。如:
Resin 2.0.4 (built Thu Nov 15 17:56:24 PST 2001)
Copyright(c) 1998-2001 Caucho Technology. All rights reserved.
Starting Resin on Wed, 23 Jan 2002 14:41:47 +0800 (CST)
http listening to *:80
srun listening to haitaiserver:6802
點選stop,可以停止當前的Resin伺服器處理序;再點選start,又可以開啟新的Resin伺服器處理序。關閉該對話
框,則回到Command 控制台的盤符提示狀態下。如果在nt4或者win2k環境下,需要把Resin當成服務,只需要
在Command控制台的該目錄下,鍵入 httpd ?install,就可以在管理工具的服務下面看到新增了一條Resin
Web Server的自動的服務。以後只要進入nt 4或者win2k,就可以啟動Resin服務。該服務也可以像其他服務一
樣設定成手動或者禁用狀態。注意有的時候在安裝完服務後,啟動Resin,並不能看到自己寫的Resin常式可以
被解析,瀏覽器顯示伺服器找不到錯誤。只要重新啟動win2k或者nt,就能解決該問題。
下面簡要介紹一下Resin伺服器的配置。Resin伺服器和大多數Java Web伺服器一樣,通過一個Xml檔案配置。
進入d:/resin/conf目錄,開啟resin.conf,這是一個xml格式的文本。
這裡面有很多標記,先尋找到:<http-server>。在<http-server></http-server>標記對中的配置和resin的
Java Web 服務器有關。找到<app-dir>,在<app-dir></app-dir>標記對中的表示resin的根,相當於Apache的
htdocs 或者 IIS 的wwwroot。Resin內建http伺服器,但是也可以不使用它,採用Apache 或者 IIS做http服
務器。這個在下面段落中會提到。
再尋找<http port='8080'/>標記,它可以這樣配置<http host='localhost' port='80'/>。host參數指定的
是伺服器,port指定的是http連接埠,預設是localhost和8080。還有<srun host='localhost' port='6802'/>
標記。這個是jsp和java Servlet的引擎配置。一般預設就可以了,除非6802連接埠已經被別的程式佔用了。然
後,配置jdk。這個需要在classpath中設定。右鍵點擊我的電腦,在系統特性的進階標籤中,點擊環境變數,
在系統變數中建立一個環境變數,變數名為classpath,值為jdk所在的目錄;再建立另外一個環境變數,變數
名為path,值為javac.exe和java.exe所在的目錄(在jdk所在的目錄下面的bin目錄下)。一般這樣子配置以
後,Resin就可以使用了。在d:/resin/doc中(假設你的<appdir></appdir>對中的名稱是doc,也就是根是
d:/resin/doc,而且你的<http host='localhost' port='80'/>如左配置),隨便寫一個jsp檔案,如可以寫
個test.jsp檔案,內容為<%=1+2+3%>。然後,在瀏覽器中,鍵入http://localhost/test.jsp。如果你可以看
到瀏覽器顯示6,則表示Resin伺服器已經可以正常運行了。注意,修改配置後,一般重新啟動resin才能看到
變化。
Resin使用簡介
使用Resin開發Java Web項目時,需要建立自己的WebApp。這裡不介紹Resin Cmp/Ejb的開發和使用,只介紹用
Resin開發普通的jsp/java servlet項目。在這裡還要談到resin.conf的配置。Resin中的應用可以有2種方式
發布:一是在Resin的目錄下發布;二是打包成War發布。
1、在Resin的目錄下發布
在resin.conf中尋找<web-app>標籤,該標籤表示一個web應用。
標籤中,id屬性工作表示該應用的Web路徑。如<web-app id='/test'>,表示該應用在Web上訪問的時候應該用
http://hostname/test/來訪問。app-dir屬性工作表示該應用的實際路徑。如
<app-dir>d:/resin/doc/test</app-dir>表示該應用在d:/resin/doc/test目錄下面。預設值為根下面的和id
同名的目錄。Resin可以配置3種error-page:404錯誤也就是檔案找不到錯誤頁;Exception違例頁;不能串連
java引擎頁。他們分別可以這樣子設定。
404檔案找不到頁
<web-app id='/app1'>
<error-page error-code='404' location='/file_not_found.jsp'/>
</web-app>
Exception 違例頁
<web-app id='/foo'>
<error-page exception-type='java.lang.NullPointerException'
location='/nullpointer.jsp'/>
</web-app>
不能串連到srun Servlet引擎錯誤頁
該頁設定和應用無關,屬於伺服器的設定。
<http-server>
<error-page exception-type='connection'
location='/missing_file.html'/>
</http-server>
classpath的設定
參見下面的語句:
<classpath id='WEB-INF/classes' source='WEB-INF/src' compile='true'/>
id參數的值表示classpath中編譯後的class的存放路徑;source參數的值表示classpath中java原始碼的存放
路徑;compile中的值可能是true或者false,表示是否由Resin的srun自動編譯java原始碼。Classpath的設定
一般和javaBean或者Servlet的使用有關。id的值表示javaBean的編譯好的包存放的根,source的值表示
javaBean的java原始碼存放的根。Servlet相同。
Servlet的設定
參見下面的語句:
<servlet-mapping url-pattern='*.xtp' servlet-name='xtp'/>
<servlet-mapping url-pattern='*.jsp' servlet-name='jsp'/>
<servlet-mapping url-pattern='/servlet/*' servlet-name='invoker'/>
一般就是指定那些需要通過srun的解析。比如在這裡,把*.jsp改成*.jss,其他不變,那麼只要在訪問時遇到
*.jss的檔案就和原來遇到*.jsp一樣處理。通過這個可以指定解析的引擎,如以下的配置:
<servlet-mapping url-pattern='*.xtp' servlet-name='com.caucho.jsp.XtpServlet'/>
在Servlet中,也可以指定servlet。如
<servlet servlet-name='hello' servlet-class='test.HelloWorld'/>
<servlet-mapping url-pattern='/hello.html' servlet-name='hello'/>
在servlet-mapping中有個重要的參數case-sensitive 如果在windows上,最好配置成false,忽略大小寫,從
而和windows的約定一致。
Session的配置
參見如下的配置語句:
<session-config>
<session-max>4096</session-max>
<session-timeout>30</session-timeout>
<enable-cookies>true</enable-cookies>
<enable-url-rewriting>true</enable-url-rewriting>
<file-store>WEB-INF/sessions</file-store>
</session-config>
session-max :最大 session數量
session-timeout :session到期時間,以分鐘為單位。
是否允許cookie :指session是否採用cookies。如果採用cookies,瀏覽器必須支援session才能使用,發布
時建議改成false。enable-url-rewriting和enable-cookies一般配合使用。如果enable-cookies是false,
enable-url-rewriting應該設成true比較合適。
file-store :該配置指示伺服器是否把session作為檔案存放在伺服器上。如果把該項注釋掉,則在你的
web-app目錄下的WEB-Inf/sessions目錄不儲存序列化後的session對象。Session還有jdbc-store配置,對應
著把session通過jdbc永久儲存在資料庫中。其實也就是會話變數的序列化後的儲存和重新載入的物理實現。
在這裡session還支援了多伺服器的設定問題,
通過tcp-store參數設定。由於涉及到Server Load Balancer的問題,在這裡不詳細敘述,只簡單寫一個例子:
<http-server>
<http id='a' port='80'/>
<srun id='a' host='host-a' port='6802'/>
<http id='b' port='80'/>
<srun id='b' host='host-b' port='6802'/>
<host id=''>
<web-app id=''>
<session-config>
<tcp-store/>
<always-load-session/>
</session-config>
</web-app>
</host>
</http-server>
這個例子表示session是按照tcp ring的方式傳遞。
temp-dir 的設定
temp-dir指的是應用的臨時目錄。也就是在javax.servlet.context.tempdir中用到的目錄。模認是應用目錄
下的WEB-INF/tmp目錄。
以上的設定都可以在<web-app>標籤對中設定,控制某個web應用的設定。
2、打包成War發布
以下是介紹對如何在resin下使用已經打包成War的java Web應用進行發布。
其實這個是最簡單也是最清晰的良好方法。在j2ee中,所有的項目都打包成ear發布。其中,Web應用打包成
war,ejb應用打包成jar。在resin中,這些都可以直接部署。這裡我只對打包成war的Web應用的部署做介紹。
在resin.conf中,尋找這個:<war-dir id='webapps'/>。他表示war檔案應該被拷貝的路徑。這裡指的是相對
於resin的安裝路徑,如以上的設定表示d:/resin/webapps。只要重新啟動Resin就可以了。Resin會把該war自
動解包到webapps目錄下。你可以在command控制台或者stdout.log中看到類似於
[2002-04-27 09:56:21.680] initializing application http://haitaiserver:8080/rwtest 的語句。這個
表示該Web應用是自動安裝的。只要這個應用是符合j2ee標準的Web應用,應該不會有問題。通過如上顯示的路
徑就可以訪問到這個應用。如果你到d:/resin/webapps/rwtest中瀏覽,你會看到Resin已經為你產生了rwtest
目錄,下面是META-INF和WEB-INF還有你自己的JSP/servlet 檔案和目錄。是完全符合j2ee的結構的。你可以
在rwtest目錄下建立新的jsp/servlet,一樣可以被編譯和解析並啟動並執行。在實際操作中,可以使用Jbuilder
或者 WebSphere等Ide工具進行整合調試和打包,非常的方便。
使用Resin進行java Web項目的開發和調試
這裡篇幅有限,不可能講太多,我只對實際中最有用的部分做介紹。
Resin中如果定義了錯誤頁,則出錯後最常見的一大串Exception不會被看到,直接跳轉到錯誤頁。所以建議開
發中先不設定錯誤頁。jsp錯誤中最常見的就是Nullpoint Exception,其次是名稱的拼字錯誤。錯誤也可以在
Resin安裝目錄下的log目錄下的stderr.log中找到。通過對該log檔案的分析可以看到很多有用的錯誤資訊。
在調試jsp的時候,如果定義了compile為true,jsp先被翻譯成Servlet的java檔案,再被編譯成class檔案。
可以在你自己的work目錄中找到該檔案。java的名稱在Resin中是這樣子定義的:原先的jsp檔案名稱前加底線
,再加上_jsp這個字樣。所以在java 應用中的命名不要以_jsp結尾,也不要出現中文名稱等字元;其實名稱
以_jsp為開頭也是不合法的。
關於java對多國語言的支援問題,在Resin中得到了很好的解決。以jsp為例,參考Resin自動產生的java
Servlet檔案。只要在任何的jsp檔案的最開始處增加:
<% @page contentType="text/html;charset=gb2312" %>
中文問題就解決了。察看產生的Servlet源檔案片斷:
response.setContentType("text/html;charset=gb2312");
request.setCharacterEncoding("GB2312");
以上為設定字元集
private static byte[] _jsp_string26;
private static byte[] _jsp_string27;
_jsp_string26 = "/r/n</table>/r/n<table class=/"type/">/r/n<tr>/r/n <td>".getBytes("GB2312");
_jsp_string27 = "/r/n</td><td>/r/n</tr>/r/n<!--/r/n<tr>/r/n<td>/r/".getBytes("GB2312");
以上是對頁面的顯示的編碼。其中,getBytes("gb2312")是靜態編碼,這是Resin為瞭解決某些環境下還是不
能正常顯示而設定的。在Resin的設定檔(/conf/resin.conf)中,可以通過設定<jsp precompile='true'
static-encoding='false' recompile-on-error='true'/>中的static-encoding屬性為true或者false,來控
制是否靜態編碼。其實在Resin容器的內部,所有的字元都是按照iso-8859-1來處理的。iso-8859-1是一個大
字元集,雖然中文的gb2312和8859在字的定義上有不同,但是編碼是包容了gb2312的。按照解決多國語言的方
法,在純英文平台上用iso-8859-1處理內部編碼,而把字元的顯示推向用戶端的機器。所以這樣只要編碼是正
確的,在頁面上顯示中文就不存在問題。Tomcat3.2不方便的地方是Tomcat對資料庫的操作中文支援不好,需
要手動在java Bean或者Servlet中寫入程式碼。通過測試,在Resin中完全沒有這個問題。Tomcat4.0解決了這個問
題。不過個人習慣來講還是覺得resin在配置方面方便一些。
在Resin中可以自動解決引入的jar。這個在使用特殊的類或者第三方提供的開發包非常有用。方法非常簡單:
只要把該jar或者是zip拷貝到Resin安裝目錄下的lib目錄下面,重新啟動Resin,就可以了。如db2用到的
db2java.zip檔案,只要輕鬆拷貝到d:/resin/lib中就可以了。
Resin提供了對Jbuilder的整合調試。可以到:
http://www.caucho.com/projects/jbuilder/resin-jbuilder.jar免費下載到resin的jbuilder的ide擴充包。
然後,把該包該名成:resin-jbuilder.jar,拷貝到jbuilder6/lib/ext目錄下。然後,把Resin2.1解包安裝
在jbuilder6/resin-2.1目錄下,就可以了。開啟任何的War項目,在project上點右鍵,選擇properties,選
擇Servers標籤。在原來的選擇框上,就可以看到多了一項Resin2.1。這樣子就可以象原來用tomcat一樣調試
jsp/servlet了,而且比Tomcat更方便。調試方法和用Tomcat調試一樣。
其他問題
使用Resin可以和apache結合使用。也就是利用apache做http伺服器,而Resin做srun伺服器。可以參考
resin/conf/samples目錄下的apache.conf。主要就是把 app-dir 設成 /usr/local/apache/htdocs(也就是
apache的root)。同時在apache 中的http.conf也做了相應的設定。Resin還提供了對該過程的自動安裝程式
,運行resin/bin/setup,你可以在彈處的對話方塊中選擇apache,這樣子就可以了。只要你曾經安裝過apache
,resin可以自己找到httpd.conf檔案所在的路徑。
使用命令列方式啟動Resin,如果改動了Resin.conf,Resin會自己重新啟動適應新的配置。這個很適合初期安
裝時使用。
Resin對資料庫緩衝池的支援很好。在這裡,它提供了DBPool對緩衝池做了封裝。實際使用時,只要在
resin.conf這樣配置:
<dbpool.sql>
<id>ORCL</id>
<driver>oracle.jdbc.driver.OracleDriver</driver>
<url>jdbc:oracle:thin:@localhost:1521:SMTH</url>
<!-- <url>jdbc:oracle:oci8:@SMTH</url> -->
<user>scott</user>
<password>tiger</password>
<max-connections>5</max-connections>
</dbpool.sql>
然後,在你的jsp或者servlet中就可以這樣子使用了:
先匯入 com.caucho.sql.*包,然後如下直接得到串連:
Connection conn = DBPool.getPool("ORCL").getConnection();
個人建議不要如上使用串連池,還是按照ejb的方法用從Context中直接找到的DataSource對象中得到串連通用
性比較好。代碼也很簡單:
Context ctx = new InitialContext();
DataSource ds = (DataSource)ctx.lookup(“jdbc/EmployeeDB”);
Connection conn = ds.getConnection();
在Resin中如下配置jdbc就可以了:
<resource-ref>
<res-ref-name>jdbc/EmployeeDB</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<init-param driver-name="com.caucho.jdbc.mysql.Driver"/>
<init-param url="jdbc:mysql_caucho://localhost:3306/test"/>
<init-param user="name"/>
<init-param password="password"/>
<init-param max-connections="20"/>
<init-param max-idle-time="30"/>
</resource-ref>
用Resin Web Server開發還是比較愉快的。只是沒有像Weblogic 或者WebSphere那樣子提供現成的管理主控台而已。但是從穩定性和方便性來講,Resin個人認為比Tomcat要好很多。況且Resin還有提供了resin-cmp 和 resin-ejb,功能更強大。
技巧:
# Resin加為服務
httpd -install
#刪除服務
httpd - remove
HKEY_LOCAL_MACHINE-->SYSTEM-->CurrentControlSet-->Services-->resin
刪除這個resin以及裡面的登錄機碼
#禁止瀏覽目錄
在resin 3.x中設定resin.conf,將directory-servlet屬性設定為false既可。
resin 2.x中沒有directory-servlet,設定resin.conf,找到<web-app id='/'>,在其後加入<directory-servlet id=false/>