Google Prettify

2008-03-13

如何在weblogic 8中取得jsp編譯後的java檔

有寫過JSP的人都知道, 所謂的JSP,是container用來產生servlet class檔用的。Container翻譯JSP,產生.java檔,透過.java檔產生.class檔。最終就如同servlet一樣,還是要執行.class檔。所以當一個畫面呈現在瀏器時,至少會有jsp、java、class 3個檔案。不過在weblogic container中卻只看得到2個檔案

1.jsp檔在${BEA_HOME|}\user_projects\domains\mydomain\applications下, 也就是deploy的目錄。
2.class檔在${BEA_HOME}\user_projects\domains\mydomain\myserver\.wlnotdelete\extract下,也就是weblogic暫存目錄下。

那.java檔呢? weblogic 預設在產生.class檔後就會移除掉。要保留.java檔的方法是在weblogic.xml中設定keepgenerated為true即可。
${BEA_HOME}\user_projects\domains\mydomain\applications\${AP_NAME}\WEB-INF\weblogic.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE weblogic-web-app PUBLIC "-//BEA Systems, Inc.//DTD Web Application 8.1//EN" 
"http://www.bea.com/servers/wls810/dtd/weblogic810-web-jar.dtd">
<weblogic-web-app>    
  <jsp-descriptor>
    <jsp-param>
      <param-name>keepgenerated</param-name>
      <param-value>true</param-value>
    </jsp-param>
  </jsp-descriptor>
  <container-descriptor>
    <prefer-web-inf-classes>false</prefer-web-inf-classes>
  </container-descriptor>
</weblogic-web-app>

2008-02-17

WDS使用技巧


Google的桌面搜尋是出了有名的。很可惜,不知道為什麼,在我的電腦上執行,總會有問題。但對於這類的搜尋功能又是愛不釋手(在有需要找檔案或是一些文件時,速度真是超快的)。因此就在想想有什麼替代方案;那就是WDS啦。什麼是WDS? WDS就是Windows Desktop Search;聽名字就知道跟google desktop search是相同的東西。以下是一些進階搜尋的功能:
ext:doc - 搜尋後面為doc的文件
file:report - 搜尋檔案名中包含report這個詞的文件
cameramake:canon - 搜尋所有圖片中由canon相機產生的(依賴於EXIF訊息)
from:zhang - 搜尋發件人名字中有zhang的郵件
size:>100000000 - 搜尋尺寸大於100MB的項目。這個做得比較土,不支持MB,KB等服務機構,只能是字元為服務機構,要加一堆0……
phone:12345678 - 搜尋電話號碼為12345678的聯絡人
來源:windows desktop search一些小技巧


2008-01-22

如何在Quartz中確定當上一個job尚未執行完前不執行下一次job?

為了避免重覆執行企業邏輯,我們在排程時有時必須確保上一次的工作執行完後,才可以允許下一個排程工作繼續執行。也就是說,原則上是個一個固定時間區間執行一次企業邏輯運算,但實際上必須等到上一次運算完後,才可以繼續執行下一次的運算...當然,也是要在固定時間區間之後。以下是個人撰寫的部份sample code。主要是利用Scheduler.getCurrentlyExecutingJobs()來限制執行job的數量。其實原理並不是不執行排程,只是不執行排程裡設定的動作。

Sample code後有一段是展示如何重新啟動排程及設定排程時間。

這段Sample code是使用Spring framework。

public class LogAnalysisJob extends QuartzJobBean {
    private LogAnalysisBO bo;

    public void setBo(MyBO bo) {
        this.bo = bo;
    }

    protected void executeInternal(JobExecutionContext c)
    throws JobExecutionException {
    Scheduler sc = c.getScheduler();
    try {
      List l = sc.getCurrentlyExecutingJobs();
      if (l.size() <= 1) { //限定目前的只有1個bo被執行
      bo.exe();//真正執行企業邏輯的部份
    }
    SimpleTriggerBean t = (SimpleTriggerBean) c.getTrigger();
    if (count > 10) {
       t.setRepeatInterval(t.getRepeatInterval() + 3000);//如果排程執行超過10次, 每次執行間隔就延長3秒
       sc.rescheduleJob(t.getName(), c.getJobDetail().getGroup(), t);
       count = 0;
    }
    count++;
  } catch (SchedulerException e) {
    e.printStackTrace();
  }

    private static int count;
}

2008-01-21

在Spring中使用Quartz

最近工作上同時使用了spring framework與quartz排程。其實這個solution在網路上已經有很多了,甚至是copy-paust良葛格的sample code也可以直接用。當然會記在這裡,一定是遇到了一些難以解決的問題。
當我在執行時,發生了NoSuchMethodError
Caused by:java.lang.NoSuchMethodError:org.apache.commons.collections.SetUtils.orderedSet...
解決方法是更換commons-collections至3.X版就可以了。

2008-01-04

Hibernate中Criteria如何查詢nested property?

假設我們有一個Object A。A的型態是ObjectA,A有一個property名稱是 propertyA、類型是ObjectB。ObjectB中有一個property名稱是propertyB屬性是String。注意、問題來了:要怎麼使用Hibernate criteria去取得propertyB值是"nested property"的instance A呢?一般人都會直覺的認為

Criteria cri = session.createCriteria(ObjectA.class);
cri.add(Restrictions.eq("propertyA.propertyB", "nested property"));
Collection r = cri.list();

這樣是不行滴。(其中一個)正確的寫法是:

Criteria cri = session.createCriteria(ObjectA.class);
cri.createAlias("propertyA", "ptA");
cri.add(Restrictions.eq("ptA.propertyB", "nested property"));
Collection r = cri.list();

沒錯,跟HQL一樣,需要使用alias。
更多請參考:Hibernate 文件

2007-11-27

如何在weblogic 8.1中得知是否有發生connection leak?

        案子中使用的container是weblogic 8.1。最近工作上寫的系統,偶爾會發connetion leak。長官執疑什麼是connection leak? 在請教過google大神後,才在BEA的官網中找到一些資訊。
在weblogic 8.1中發生connection leak時會產生<BEA-001074>錯誤。那什麼叫connection leak? "BEA官方解釋是
A JDBC pool connection leak was detected. A connection leak occurs when a connection obtained from the pool was not closed explicitly by calling close() and then was disposed by the garbage collector and returned to the connection pool. A stack trace is printed indicating where the leaked connection was created...
如何知道那裡有發生connection leak呢?

首先要在 startup scripts (startWeblogic.cmd)中加入 -Dweblogic.Debug=weblogic.JDBCConn="true", weblogic.JTAJDBC="true"

另外要設定weblogic中domain的config.xml中的指定連線 ConnLeakProfilingEnabled屬性為true。

 <JDBCConnectionPool ConnLeakProfilingEnabled="true"
    ConnProfilingEnabled="true"
     DriverName="oracle.jdbc.OracleDriver"
     InactiveConnectionTimeoutSeconds="0" MaxCapacity="20"....

其實設定ConnLeakProfilingEnabled也可以透過weblogic console中設定。




其中Inactive Connection Timeout要設定為0

您或許對這些有興趣

最後

謝謝您的閱讀,希望您可以有豐富的收獲。