轉:Resin的安裝和配置

來源:互聯網
上載者:User

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/>

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.