<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆 - 42  文章 - 71  trackbacks - 0
    <2010年6月>
    303112345
    6789101112
    13141516171819
    20212223242526
    27282930123
    45678910

    常用鏈接

    留言簿

    隨筆檔案

    文章分類

    文章檔案

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    最近項目組做了一個Blog系統(我沒有參與),玩Blog的人都知道,訪問某個Blog的時候,通常的格式是http://host:port/blogxxx,這個blogxxx的路徑在應用部署目錄下實際上是不存在的,只是使用了Filter攔截解釋才得以返回正確的結果。

    這個Blog應用在開發環境是WebSphere Application Server 6.1.0.0版本的,一切運行正常。到了生產環境部署的時候是用的WebSphere Application Server 6.1.0.25版本的,訪問Blog的時候就會出現404的錯誤。

    一開始以為是應用的問題,仔細檢查了應用之后,感覺問題不在于應用。打開了WAS的Trace看了一下,感覺有點差別:

     

    請求的Blog地址為: http://xxxx.com/Blog/BillyTest

    在WAS 6.1.0.0的Trace(真實IP地址替換為0.0.0.0):

    [10-6-25 3:26:45:236 CST] 00000035 WebContainer  3   Looking for vhost with key –> 0.0.0.0:9080/Blog/BillyTest/
    [10-6-25 3:26:45:236 CST] 00000035 VirtualHostCo 3   map vHost [0.0.0.0:9080] relativePath [/Blog/BillyTest/]
    [10-6-25 3:26:45:236 CST] 00000035 WebContainer  3   request processor handling request --> com.ibm.ws.wswebcontainer.webapp.WebGroup@15de15de
    [10-6-25 3:26:45:236 CST] 00000035 WebGroup      3   WebGroup found --> /Blog
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getEncodedRequestURI
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getEncodedRequestURI uri --> /Blog/BillyTest/
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getRequestURI uri --> /Blog/BillyTest/
    [10-6-25 3:26:45:236 CST] 00000035 WebApp        3   URI --> /Blog/BillyTest/ handled by WebApp --> XXXXX_BLOG_EAR
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getWebAppDispatcherContext
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getWebAppDispatcherContext
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getWebAppDispatcherContext
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   resetPathElements
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletRes 3   Setting the default response encoding
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getWebAppDispatcherContext
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletRes 3   _locale: zh_CN
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletRes 3   _encoding: ISO-8859-1
    [10-6-25 3:26:45:236 CST] 00000035 WebApp        3   RequestProcessor handling request is class com.ibm.ws.wswebcontainer.extension.DefaultExtensionProcessor
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getWebAppDispatcherContext
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getAttribute name --> javax.servlet.include.request_uri
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getWebAppDispatcherContext
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getServletPath --> path
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getWebAppDispatcherContext
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getPathInfo path --> /BillyTest/
    [10-6-25 3:26:45:236 CST] 00000035 DefaultExtens 3   handleRequest: servletPath [] pathInfo [/BillyTest/]
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getWebAppDispatcherContext
    [10-6-25 3:26:45:236 CST] 00000035 WebAppFilterM >  doFilter Entry
    [10-6-25 3:26:45:236 CST] 00000035 SRTServletReq 3   getAttribute name --> com.ibm.servlet.engine.webapp.dispatch_nested
    [10-6-25 3:26:45:236 CST] 00000035 WebAppFilterM 3   requestURI [/BillyTest/] isInternal [false]
    [10-6-25 3:26:45:236 CST] 00000035 LRUCache      >  get Entry
                                     /BillyTest/
    [10-6-25 3:26:45:236 CST] 00000035 LRUCache      <  get Exit
    [10-6-25 3:26:45:236 CST] 00000035 WebAppFilterC >  _doFilter Entry

     

    可以看到,在最后幾行,請求的URL進入了Filter Chain進行處理了,后續Filter的處理已經省略。

     

     

    在WAS 6.1.0.25上的Trace(真實IP地址已經替換為0.0.0.0)

    [10-6-25 3:02:06:515 GMT+08:00] 00000112 WebContainer  3   Looking for vhost with key –> 0.0.0.0:80/Blog/BillyTest
    [10-6-25 3:02:06:515 GMT+08:00] 00000112 VirtualHostCo 3   map vHost [0.0.0.0:80] relativePath [/Blog/BillyTest]
    [10-6-25 3:02:06:515 GMT+08:00] 00000112 WebContainer  3   request processor handling request --> com.ibm.ws.wswebcontainer.webapp.WebGroup@52245224
    [10-6-25 3:02:06:515 GMT+08:00] 00000112 WebGroup      3   WebGroup found --> /Blog
    [10-6-25 3:02:06:515 GMT+08:00] 00000112 SRTServletReq >  getRequestURI [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771] Entry
    [10-6-25 3:02:06:515 GMT+08:00] 00000112 SRTServletReq >  getEncodedRequestURI [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771] Entry
    [10-6-25 3:02:06:515 GMT+08:00] 00000112 SRTServletReq <  getEncodedRequestURI uri --> /Blog/BillyTest Exit
    [10-6-25 3:02:06:515 GMT+08:00] 00000112 SRTServletReq <  getRequestURI uri --> /Blog/BillyTest Exit
    [10-6-25 3:02:06:515 GMT+08:00] 00000112 WebApp        3   (WEB) URI --> /Blog/BillyTest handled by WebApp --> TJMCC_EIPIV_YYT_BLOG_EAR
    [10-6-25 3:02:06:515 GMT+08:00] 00000112 SRTServletReq 3   getWebAppDispatcherContext [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771]
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletReq 3   getWebAppDispatcherContext [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771]
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletReq 3   getWebAppDispatcherContext [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771]
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletReq 3   resetPathElements [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771]
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletRes 3   Setting the default response encoding
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletReq 3   getWebAppDispatcherContext [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771]
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletRes 3   _locale: zh_CN
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletRes 3   _encoding: ISO-8859-1
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 WebApp        3   RequestProcessor handling request is class com.ibm.ws.wswebcontainer.extension.DefaultExtensionProcessor
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletReq 3   getWebAppDispatcherContext [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771]
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletReq >  getRequestURI [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771] Entry
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletReq >  getEncodedRequestURI [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771] Entry
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletReq <  getEncodedRequestURI uri --> /Blog/BillyTest Exit
    [10-6-25 3:02:06:516 GMT+08:00] 00000112 SRTServletReq <  getRequestURI uri --> /Blog/BillyTest Exit
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 DefaultExtens >  handleRequest : request--->/Blog/BillyTest<--- Entry
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 SRTServletReq 3   getAttribute name --> javax.servlet.include.request_uri [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771]
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 SRTServletReq 3   getWebAppDispatcherContext [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771]
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 SRTServletReq 3   getServletPath --> path
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 SRTServletReq >  getPathInfo [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771] Entry
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 SRTServletReq 3   getWebAppDispatcherContext [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771]
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 SRTServletReq <  getPathInfo path --> [/BillyTest] Exit
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 DefaultExtens 3   handleRequest: servletPath [] pathInfo [/BillyTest]
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 DefaultExtens 3   handleRequest stripping leading slashes pathInfo ---> BillyTest
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 DefaultExtens 3   file does not exist :/opt/IBM/WebSphere/AppServer/profiles/AppSrv01/installedApps/wasc3Cell01/TJMCC_EIPIV_YYT_BLOG_EAR.ear/TJMCC_EIPIV_YYT_Blog.war/BillyTest
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 DefaultExtens 3   isDirectoryTraverse returningfalse , matchstring :/BillyTest
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 DefaultExtens 3   FileNotFoundException caught
    [10-6-25 3:02:06:517 GMT+08:00] 00000112 SRTServletReq 3   setAttribute name --> com.ibm.ws.webcontainer.filter.filenotfound value --> com.ibm.websphere.servlet.error.ServletErrorReport: SRVE0190E: 找不到文件:/BillyTest [com.ibm.ws.webcontainer.srt.SRTServletRequest@7710771]

    從最后一行可以看出,Web容器在Filter作用之前去Web應用所在目錄下查找/BillyTest目錄,結果發現沒有找到,所以就直接返回了404的響應給瀏覽器。

     

    從上面的Trace對比,懷疑問題出在WAS下版本的行為變化上,查閱一下IBM的文檔,找到如下一個解釋:

    在WebSphere 6的某些版本中,Web容器在查找用戶請求的資源之前,不會調用用戶自行設定的Filter。所以在上面的例子中,由于所請求的/BillyTest資源并不是實際存在的,所以未經過應用Filter處理就拋出了FileNotFoundException。要想改變服務器的這種行為,需要為Web容器設置自定義參數:com.ibm.ws.webcontainer.invokeFiltersCompatibility,將其設置為”true”

     

    登錄WAS Admin,服務器>應用服務器>your_server_name>Web容器設置>Web容器>定制屬性,點擊“新建”,加入一個自定義屬性:

    名稱:com.ibm.ws.webcontainer.invokeFiltersCompatibility

    值:true

     

    2010-06-28_195740

     

    配置之后,重新啟動則應用運行正常。

     

    經過這次的問題處理,感覺測試環境和生產環境應該盡可能的使用同樣版本的平臺和產品,否則會在上線的時候給你帶來意外的驚喜。

     

    關于這個問題原文地址在:

    http://www-01.ibm.com/support/docview.wss?rs=180&uid=swg1PK31377

     

     

    posted on 2010-06-28 19:58 YODA 閱讀(4704) 評論(3)  編輯  收藏

    FeedBack:
    # re: WebSphere 6.1.0.25 的 404錯誤 2010-06-29 09:26 隔葉黃鶯
    收藏下,以后可能用得著。  回復  更多評論
      
    # re: WebSphere 6.1.0.25 的 404錯誤[未登錄] 2010-06-29 10:03 YODA
    @隔葉黃鶯
    謝謝兄臺支持
      回復  更多評論
      
    # re: WebSphere 6.1.0.25 的 404錯誤[未登錄] 2010-07-01 09:30 IVY
    多虧有你了,不然還不知道要折騰多久@YODA
      回復  更多評論
      

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: www视频在线观看免费| 中文在线观看国语高清免费| 最近2019年免费中文字幕高清| 亚洲一区无码中文字幕 | 无码不卡亚洲成?人片| 亚洲丶国产丶欧美一区二区三区| 成人无遮挡裸免费视频在线观看 | 一个人免费观看www视频| 亚洲国产成人精品女人久久久| 美女免费视频一区二区| 亚洲av手机在线观看| 国产99精品一区二区三区免费 | 国产桃色在线成免费视频| 久久久久se色偷偷亚洲精品av| 成年女人免费碰碰视频| 亚洲AV无码成人精品区日韩| 国产在线观看免费视频播放器| 羞羞视频免费网站含羞草| AV在线亚洲男人的天堂| 精品一卡2卡三卡4卡免费视频| 亚洲AV福利天堂一区二区三| 1000部羞羞禁止免费观看视频| 四虎亚洲精品高清在线观看| 国产gav成人免费播放视频| 国产三级在线免费观看| 国产精品亚洲一区二区在线观看| 国产女高清在线看免费观看| 91国内免费在线视频| 国产日产成人免费视频在线观看| 亚洲AV性色在线观看| AV在线亚洲男人的天堂| 最近2019免费中文字幕视频三| 亚洲伊人久久大香线蕉AV| 亚洲黄片毛片在线观看| 99精品一区二区免费视频| 亚洲欧美日韩综合久久久| 久久久久亚洲AV无码专区桃色| 91精品免费观看| www亚洲精品久久久乳| 久久夜色精品国产嚕嚕亚洲av| 免费观看男人免费桶女人视频|