posts - 23,  comments - 3,  trackbacks - 0
            2014年2月10日
          win7自動(dòng)升級(jí)到了ie11,但是debug工具太難用了,準(zhǔn)備會(huì)退到9,但是在添加刪除程序里,把ie11的功能關(guān)閉,安裝9時(shí),提示ie已經(jīng)安裝。
          并且ie圖標(biāo)也沒了。。progrem files下面的ie啟動(dòng)程序也沒了。。。。

          最好在這找到了卸載的辦法
          http://www.iefans.net/windows-7-ie11-wufa-xiezai-chongxin-anzhuang-gengxin-banben/
          posted @ 2014-02-10 18:43 temper 閱讀(4214) | 評(píng)論 (1)編輯 收藏
            2013年11月20日
          工作中用到了struts2的tabbedpanel標(biāo)簽。
          在火狐和chrome下都沒問(wèn)題,但是在ie下報(bào)錯(cuò):
          SCRIPT5007: 無(wú)法獲取未定義或 null 引用的屬性“toLowerCase” 
                         struts_dojo.js, 行6471 字符1。
          針對(duì)struts_dojo.js進(jìn)行debug,發(fā)現(xiàn)6470行的“node.scopeName”是undefined。

          直接修改此js代碼,增加“&&typeof(node.scopeName)!='undefined'”,
          重新做成struts2-dojo-plugin.jar,問(wèn)題解決
          posted @ 2013-11-20 17:10 temper 閱讀(2631) | 評(píng)論 (2)編輯 收藏
            2012年12月10日
          JVM的-XX:[+/-]<option>以前竟然沒注意,mark一個(gè):Boolean options are turned on with -XX:+<option> and turned off with -XX:-<option>. http://t.cn/qkcrs
          posted @ 2012-12-10 10:47 temper 閱讀(332) | 評(píng)論 (0)編輯 收藏
            2012年1月31日
          昨天配了兩個(gè)weblogic節(jié)點(diǎn),但是怎么也啟動(dòng)不起來(lái)。以前這種操作做了十幾次了,沒遇到過(guò)這種問(wèn)題。
          錯(cuò)誤如下:
          weblogic.security.SecurityInitializationException: 認(rèn)証が拒否されました。起動(dòng)アイデンティティが有効ではありません。起動(dòng)アイデンティティ?ファイル(boot.properties)のユーザー名またはパスワード(もしくはその雙方)が有効ではありません。起動(dòng)アイデンティティ?ファイルが作成された後に起動(dòng)アイデンティティが変更されていることが考えられます。適切な値のユーザー名およびパスワードで起動(dòng)アイデンティティ?ファイルを編集および更新してください。更新された起動(dòng)アイデンティティ?ファイルを使用して初めてサーバーを起動(dòng)するときには、それらの値は暗號(hào)化されます。
              at weblogic.security.service.CommonSecurityServiceManagerDelegateImpl.doBootAuthorization(CommonSecurityServiceManagerDelegateImpl.java:960)
              at weblogic.security.service.CommonSecurityServiceManagerDelegateImpl.initialize(CommonSecurityServiceManagerDelegateImpl.java:1054)
              at weblogic.security.service.SecurityServiceManager.initialize(SecurityServiceManager.java:873)
              at weblogic.security.SecurityService.start(SecurityService.java:148)
              at weblogic.t3.srvr.SubsystemRequest.run(SubsystemRequest.java:64)
              at weblogic.work.ExecuteThread.execute(ExecuteThread.java:256)
              at weblogic.work.ExecuteThread.run(ExecuteThread.java:221)
          Caused By: javax.security.auth.login.FailedLoginException: [Security:090303]ユーザーweblogicの認(rèn)証が失敗しました。weblogic.security.providers.authentication.LDAPAtnDelegateException: [Security:090295]予期しない例外が捕捉されました
              at weblogic.security.providers.authentication.LDAPAtnLoginModuleImpl.login(LDAPAtnLoginModuleImpl.java:251)
              at com.bea.common.security.internal.service.LoginModuleWrapper$1.run(LoginModuleWrapper.java:110)
              at java.security.AccessController.doPrivileged(Native Method)
          提示用戶名和密碼問(wèn)題,但是用戶名和密碼我很確頂沒錯(cuò)。

          然后根據(jù)這里:
          http://bbs.weblogicfans.net/viewthread.php?tid=399&extra=&ordertype=1&page=4
          增加了啟動(dòng)參數(shù)t3://AdminServerIP:AdminServerPort(以前都是系統(tǒng)默認(rèn)),發(fā)現(xiàn)啟動(dòng)成功。
          查看startManagedWebLogic.cmd,發(fā)現(xiàn)41行
          set ADMIN_URL=XXX,竟然用的是計(jì)算機(jī)名。。。。。。。。。。。

          測(cè)試機(jī)裝完環(huán)境,配置集群時(shí),為了便于辨認(rèn),修改了計(jì)算機(jī)名,悲劇的根源。。。。。。
          然后發(fā)現(xiàn)stopManagedWebLogic.cmd里面用的也是計(jì)算機(jī)名。。。。。。

          計(jì)算機(jī)名,ip都可能被改,我感覺弄個(gè)localhost比啥都強(qiáng),實(shí)在不明白這么做得原因是啥。

          不過(guò)以后搭建環(huán)境時(shí),一定要先把系統(tǒng)要修改的做完,然后再裝其他軟件。
          posted @ 2012-01-31 11:25 temper 閱讀(2875) | 評(píng)論 (0)編輯 收藏
            2011年9月27日

          在HP-UX操作系統(tǒng)中使用-d32或-d64來(lái)指定使用Java應(yīng)用程序使用32bit的JVM還是使用64bit的JVM(默認(rèn)32bit).
          一個(gè)Java應(yīng)用程序運(yùn)行時(shí),它會(huì)根據(jù)自己所在的HP-UX使用的CPU類型及指定的JVM位數(shù)(-d32 or保持默認(rèn)、-d64)使用$JAVA_HOME/java(殼)自動(dòng)選擇要執(zhí)行的JVM.

          Itanium:
          $JAVA_HOME/bin/IA64N/java
          $JAVA_HOME/bin/IA64W/java

          PA-RISC:
          $JAVA_HOME/bin/PA_RISC/java
          $JAVA_HOME/bin/PA_RISC2.0/java
          $JAVA_HOME/bin/PA_RISC2.0W/java

          目錄說(shuō)明
          PA_RISC            PA_RISC 1.1 32-bit JVM
          PA_RISC2.0       PA-RISC 2.0 32-bit JVM
          PA_RISC2.0W     PA-RISC 2.0 64-bit JVM
          IA64N      Integrity narrow 32-bit JVM
          IA64W     Integrity wide 64-bit JVM

          WebLogic Server 8.1及WebLogic Serevr 9.x and later version使用64位JVM.

          WebLogic Server 8.1:
          修改${Domain_home}下的startWebLogic.sh和startManagedWebLogic.sh中兩個(gè)腳本的MEM_ARGS參數(shù)值,在此參數(shù)值的最前面加上-64參數(shù)即可,例如:
          MEM_ARGS=”-d64 –Xms512m –Xmx1024m…”

          WebLogic Serevr 9.x and later version:
          修改${Domain_home}/bin/下的setDomainEnv.sh腳本MEM_ARGS參數(shù)值,在此參數(shù)值的最前面加上-64參數(shù)即可。

          轉(zhuǎn)載自


          posted @ 2011-09-27 14:44 temper 閱讀(1585) | 評(píng)論 (0)編輯 收藏
          最近的項(xiàng)目涉及到了JAVA需要調(diào)用C程序的問(wèn)題。主要是調(diào)用C寫的加密算法。
          主要解決方案是應(yīng)用JNI去調(diào)用C生成的so庫(kù)
          用eclispe新建一個(gè)java project項(xiàng)目,項(xiàng)目名稱為spidHandle,注意下面VC的項(xiàng)目名稱也是spidHandle,他們分別是用eclispe和VC6.0創(chuàng)建的,不是同個(gè)項(xiàng)目。
          編寫一個(gè)JNI入口類SpidHandle.java:
          Java代碼  收藏代碼
          1. package com.spidHandle.api;  
          2. public class SpidHandle {  
          3.         static {  
          4.                 System.loadLibrary("spidhandle");  
          5.         }  
          6.           
          7.         public String buildSpID(String path, String login_name, String password, String key)  
          8.         {  
          9.             return getSPID(path, login_name, password, key);  
          10.         }  
          11.           
          12.         public native String getSPID(String path, String login_name, String password, String key);  
          13.   
          14.     /** 
          15.      * @param args 
          16.      *  
          17.      * 供測(cè)試用 
          18.      */  
          19.     public static void main(String[] args) {  
          20.         // TODO Auto-generated method stub  
          21.         String keyforMD5 = "A6EIo8tuaKS";  
          22.         String s = new SpidHandle().buildSpID("/test", "test", "test", keyforMD5);  
          23.         System.out.println(s);  
          24.     }  
          25.   
          26. }  


          通過(guò)CMD命令窗口,CMD命令窗口定位到SpidHandle.java的目錄下,編譯SpidHandle.java文件:
          Java代碼  收藏代碼
          1. javac SpidHandle.java  

          執(zhí)行JAVAC命令后,在同個(gè)文件目錄下生成SpidHandle.class
          將CMD窗口退回到包的根目錄下,如spidHandle工程路徑為:
          Z:\project\work_workspace\spidhandle
          其中通過(guò)編譯后的SpidHandle.class存在于目錄下:
          Z:\project\work_workspace\spidhandle\src\com\spidHandle\api
          由于SpidHandle類所在的包是com.spidHandle.api,所以CMD命令窗口要退回到Z:\project\work_workspace\spidhandle\src目錄
          然后在CMD窗口中執(zhí)行
          Java代碼  收藏代碼
          1. javah com.spidHandle.api.SpidHandle  

          執(zhí)行后在Z:\project\work_workspace\spidhandle\src目錄下生成文件
          com_spidHandle_api_SpidHandle.h文件。
          安裝VC6.0開發(fā)工具。如果你是在windows下開發(fā),那可以先生成DLL,這樣你就可以在Windows下調(diào)試。其實(shí)JNI調(diào)用DLL和SO是一樣的,只是運(yùn)行的操作系統(tǒng)不一樣而已。下面是如何用VC6.0創(chuàng)建一個(gè)DLL項(xiàng)目。
          創(chuàng)建一個(gè)項(xiàng)目工程,名為spidhandle的工程,創(chuàng)建過(guò)程如下:
          1、打開VC6.0->文件->新建
          2、在彈出窗口中的工程選項(xiàng)卡中選擇Win32 Dynamic-Link Library;工程名命名為spidhandle;點(diǎn)擊確定。
          3、在新的提示窗口中選擇一個(gè)空白的DLL工程,點(diǎn)擊完成。
          4、在菜單的工具欄中選擇選項(xiàng),彈出選項(xiàng)窗口。切換到目錄選項(xiàng)卡
          5、在目錄選項(xiàng)卡中新建目錄,新建的目錄為你JDK所在的目錄下的include目錄,如:
             D:\Program Files\Java\jdk1.6.0_16\include
            再新建一個(gè)目錄,新建的目錄為include文件夾下的win32目錄,如
             D:\Program Files\Java\jdk1.6.0_16\include\win32
            此步主要是向工程引入jni所需要的頭文件,如include中包含了jni.h,jni_md.h
          6、將com_spidHandle_api_SpidHandle.h頭文件拷貝到vc6.0工程spidHandle根目錄下,將其添加到工 程的Header Files,右鍵工程窗口中的Header Files,選擇添加文件到目錄下,選擇工程路徑下的com_spidHandle_api_SpidHandle.h文件。
          7、在spidHandle工程根目錄的文件夾中新建com_spidHandle_api_SpidHandle.h頭文件對(duì)應(yīng)的cpp文件, 文件名稱為com_spidHandle_api_SpidHandle.cpp,然后返回VC6.0操作界面,將其添加到工程的Source Files,右鍵工程窗口中的Source Files,選擇添加文件到目錄下,選擇工程路徑下的com_spidHandle_api_SpidHandle.cpp文件。
          Java代碼  收藏代碼
          1. #include "com_spidHandle_api_SpidHandle.h"  
          2. #include <string.h>  
          3.   
          4. #include "MD5.h"  
          5.   
          6. const static char* version = "1201.01";  
          7.   
          8. JNIEXPORT jstring JNICALL Java_com_spidHandle_api_SpidHandle_getSPID  
          9.  (JNIEnv *env , jobject obj, jstring path, jstring login_name, jstring password, jstring key)  
          10. {  
          11.     printf("-= com_spidHandle_api_SpidHandle Version  %s =- \n", version);  
          12.     char icpid[256];  
          13.     const char * md5="A6EIo8tuaKS";  
          14.   
          15.     const char* login_user = env->GetStringUTFChars(login_name, false);  
          16.     const char* login_pwd = env->GetStringUTFChars(password, false);  
          17.     const char* md5_key = env->GetStringUTFChars(key, false);  
          18.     const char* path_str = env->GetStringUTFChars(path, false);  
          19.       
          20.     memset(icpid, 0, 256);  
          21.   
          22.     printf("login_user = %s\n", login_user);  
          23.     printf("path = %s\n", path_str);  
          24.     printf("login_pwd = %s\n", login_pwd);  
          25.     printf("md5_key = %s\n", md5_key);    
          26.   
          27.     // 不管播放哪個(gè)url 直接用這個(gè)加密  -_-||   
          28.     // pPath = "tmes_224";  
          29.     // 組建加密部分  
          30.     char *p=icpid;  
          31.     *p=strlen(login_user);  
          32.     p++;  
          33.     strcpy(p,login_user);  
          34.     p+=strlen(login_user);  
          35.     *p=strlen(path_str);  
          36.     p++;  
          37.     strcpy(p,path_str);  
          38.     p+=strlen(path_str);  
          39.       
          40.     if(strlen(md5_key) > 1)  
          41.         md5 = md5_key;  
          42.     *p=strlen(md5);  
          43.     p++;  
          44.     strcpy(p,md5);  
          45.     p+=strlen(md5);  
          46.   
          47.     MD5 m1;  
          48.     m1 << md5 << login_user << login_pwd;  
          49.   
          50.     const char *pmd5 = m1.HexDigest();  // symbian專用  
          51.     char md5buf[256];  
          52.     memset(md5buf,0,256);  
          53.     memcpy( md5buf,pmd5,strlen(pmd5) ); // 結(jié)束symbian專用  
          54.   
          55.     printf("md5buf = %s\n", md5buf);  
          56.       
          57.     int pmd5_len = strlen(pmd5);  
          58.   
          59.     *p=strlen(md5buf);  
          60.     p++;  
          61.     strcpy(p,md5buf);  
          62.     p+=strlen(md5buf);  
          63.   
          64.     printf("spid = %s\n", icpid);  
          65.   
          66.     return env->NewStringUTF(icpid);  
          67. }  

          8、將MD5.h,MD5.cpp拷貝到工程目錄下,即跟com_spidHandle_api_SpidHandle.h文件同在項(xiàng)目根目錄下。這兩個(gè)文件其實(shí)是我用到的加密類。不是VC自有的,是另外同事開發(fā)的。
          9、在VC6.0的菜單欄中選擇組建;在工程文件夾下的Debug文件夾中生成spidHandle.dll
          10、可以將spidHandle.dll拷貝到JAVA PROJECT的spidHandle的項(xiàng)目里,放在項(xiàng)目的根目錄,即Z:\project\work_workspace\spidhandle目錄 下,用eclispe運(yùn)行SpidHandle.java文件。在輸出窗口中會(huì)打印com_spidHandle_api_SpidHandle.cpp
          的printf輸出部分。

          生成so文件,此步需要在linux上操作。
          1、將com_spidHandle_api_SpidHandle.h, MD5.h,com_spidHandle_api_SpidHandle.cpp,MD5.cpp文件拷貝到linux下,如拷貝到/home/spidHandle目錄中去;
          2、在linux下,命令切換到spidHandle文件夾下,執(zhí)行:
          g++ com_spidHandle_api_SpidHandle.cpp MD5.cpp -I/usr/java/jdk1.6.0_16/include -I/usr/java/jdk1.6.0_16/include/linux -fPIC -shared -o libspidhandle.so
          命令。其中-I/usr/java/jdk1.6.0_16/include
          -I/usr/java/jdk1.6.0_16/include/linux 表示需要引入的頭文件。相當(dāng)于生成DLL引入了jni.h等文件。-fPIC表示生成共享庫(kù)文件,libspidhandle.so表示庫(kù)文件名。
          3、執(zhí)行export LD_LIBRARY_PATH=/home/spidHandle
            此步是設(shè)置將庫(kù)文件所在路徑加入LD_LIBRARY_PATH中去,如果不執(zhí)行此步,在運(yùn)行中就會(huì)出現(xiàn)異常:
          Java代碼  收藏代碼
          1. java.lang.UnsatisfiedLinkError: no XXX in java.library.path  

          4、可以在Linux中部署一個(gè)簡(jiǎn)單的web 應(yīng)用,如一個(gè)簡(jiǎn)單的test項(xiàng)目,在servlet中調(diào)用該so,調(diào)用代碼如下:
          Java代碼  收藏代碼
          1. String spid = new SpidHandle().buildSpID(pathforMD5, user,pwd,keyforMD5);  

          spid為加密后返回的結(jié)果。


          補(bǔ)充:
          過(guò)程中所碰到的問(wèn)題:

          問(wèn)題1
          java.lang.UnsatisfiedLinkError: /home/spidhandle/libspidhandle.so: /home/spidhandle/libspidhandle.so: wrong ELF class: ELFCLASS64 (Possible cause: architecture word width mismatch)

          在linux中,用servlet調(diào)用該so,出現(xiàn)上面的異常,主要因?yàn)槲宜渴饝?yīng)用的linux服務(wù)器是64位的,而所生成的so是32位的,后來(lái)將項(xiàng)目部署到32位的服務(wù)器上就解決問(wèn)題了。
          如何查看linux操作系統(tǒng)是32位還是64位的,可以運(yùn)行下面命令:
          查看操作系統(tǒng)位數(shù)
          Java代碼  收藏代碼
          1. file /bin/ls  


          問(wèn)題2
          運(yùn)行servlet,JVM崩潰,并輸出JVM異常,異常文件在tomcat啟動(dòng)文件startup.sh同個(gè)目錄下,如tomcat/bin下,文件格式為hs_err_pid*.log 如,hs_err_pid23600.log
          錯(cuò)誤日志內(nèi)容:
          #
          # A fatal error has been detected by the Java Runtime Environment:
          #
          #  SIGSEGV (0xb) at pc=0xb6e5a1ef, pid=23600, tid=2431036272
          #
          # JRE version: 6.0_16-b01
          # Java VM: Java HotSpot(TM) Server VM (14.2-b01 mixed mode linux-x86 )
          # Problematic frame:
          # V  [libjvm.so+0x3931ef]
          #
          # If you would like to submit a bug report, please visit:
          #   http://java.sun.com/webapps/bugreport/crash.jsp
          #

          ---------------  T H R E A D  ---------------

          Current thread (0x085bbc00):  JavaThread "http-8080-1" daemon [_thread_in_vm, id=23622, stack(0x90e1a000,0x90e6b000)]

          siginfo:si_signo=SIGSEGV: si_errno=0, si_code=1 (SEGV_MAPERR), si_addr=0x00000000

          Registers:
          EAX=0x00000000, EBX=0xb71dd7c0, ECX=0xb71f87e0, EDX=0x00000ffc
          ESP=0x90e696d4, EBP=0x90e69748, ESI=0x0825b0a8, EDI=0x00090e69
          EIP=0xb6e5a1ef, CR2=0x00000000, EFLAGS=0x00010296

          Top of Stack: (sp=0x90e696d4)
          0x90e696d4:   b71d5ec8 00000000 b6e5a127 b7783a30
          0x90e696e4:   b77624c0 00000000 90e69700 0825b0a8
          0x90e696f4:   080de058 080de060 080de44c 085bbc00
          0x90e69704:   00000000 b77d8ff4 9106c730 085bbc00
          0x90e69714:   90e69750 b77c7f56 9106c8e8 085bbc00
          0x90e69724:   00000001 00000005 00000000 90dd6601
          0x90e69734:   90dd6000 00004044 90dd9ff4 927ec5f4
          0x90e69744:   085bbc00 90e69768 90dd6fbd 085bbd10

          Instructions: (pc=0xb6e5a1ef)
          0xb6e5a1df:   ac 8b 46 08 89 45 b0 8b 46 0c 89 45 b4 8b 45 0c
          0xb6e5a1ef:   8b 00 50 e8 09 ae fd ff 83 ec 0c 89 c7 50 e8 aa

          Stack: [0x90e1a000,0x90e6b000],  sp=0x90e696d4,  free space=317k
          Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
          V  [libjvm.so+0x3931ef]
          C  [libspidhandle.so+0xfbd]  _ZN7JNIEnv_17GetStringUTFCharsEP8_jstringPh+0x27
          C  [libspidhandle.so+0xc6e]  Java_com_spidHandle_api_SpidHandle_getSPID+0x52
          j  com.spidHandle.api.SpidHandle.getSPID(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;+0
          j  com.spidHandle.api.SpidHandle.buildSpID(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;+6
          j  com.play.servlet.PlayServlet.service(Ljavax/servlet/ServletRequest;Ljavax/servlet/ServletResponse;)V+1044
          j  org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(Ljavax/servlet/ServletRequest;Ljavax/servlet/ServletResponse;)V+376
          j  org.apache.catalina.core.ApplicationFilterChain.doFilter(Ljavax/servlet/ServletRequest;Ljavax/servlet/ServletResponse;)V+101
          j  org.apache.catalina.core.StandardWrapperValve.invoke(Lorg/apache/catalina/connector/Request;Lorg/apache/catalina/connector/Response;)V+804
          j  org.apache.catalina.core.StandardContextValve.invoke(Lorg/apache/catalina/connector/Request;Lorg/apache/catalina/connector/Response;)V+365
          j  org.apache.catalina.core.StandardHostValve.invoke(Lorg/apache/catalina/connector/Request;Lorg/apache/catalina/connector/Response;)V+64
          j  org.apache.catalina.valves.ErrorReportValve.invoke(Lorg/apache/catalina/connector/Request;Lorg/apache/catalina/connector/Response;)V+6
          j  org.apache.catalina.core.StandardEngineValve.invoke(Lorg/apache/catalina/connector/Request;Lorg/apache/catalina/connector/Response;)V+42
          j  org.apache.catalina.connector.CoyoteAdapter.service(Lorg/apache/coyote/Request;Lorg/apache/coyote/Response;)V+158
          j  org.apache.coyote.http11.Http11Processor.process(Ljava/net/Socket;)V+514
          j  org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Ljava/net/Socket;)Z+82
          j  org.apache.tomcat.util.net.JIoEndpoint$Worker.run()V+41
          j  java.lang.Thread.run()V+11
          v  ~StubRoutines::call_stub
          V  [libjvm.so+0x36ca20]
          V  [libjvm.so+0x530828]
          V  [libjvm.so+0x36c227]
          V  [libjvm.so+0x36c2da]
          V  [libjvm.so+0x3e95f5]
          V  [libjvm.so+0x61097e]
          V  [libjvm.so+0x531cce]
          C  [libpthread.so.0+0x6725]

          Java frames: (J=compiled Java code, j=interpreted, Vv=VM code)
          j  com.spidHandle.api.SpidHandle.getSPID(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;+0
          j  com.spidHandle.api.SpidHandle.buildSpID(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;+6
          j  com.play.servlet.PlayServlet.service(Ljavax/servlet/ServletRequest;Ljavax/servlet/ServletResponse;)V+1044
          j  org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(Ljavax/servlet/ServletRequest;Ljavax/servlet/ServletResponse;)V+376
          j  org.apache.catalina.core.ApplicationFilterChain.doFilter(Ljavax/servlet/ServletRequest;Ljavax/servlet/ServletResponse;)V+101
          j  org.apache.catalina.core.StandardWrapperValve.invoke(Lorg/apache/catalina/connector/Request;Lorg/apache/catalina/connector/Response;)V+804
          j  org.apache.catalina.core.StandardContextValve.invoke(Lorg/apache/catalina/connector/Request;Lorg/apache/catalina/connector/Response;)V+365
          j  org.apache.catalina.core.StandardHostValve.invoke(Lorg/apache/catalina/connector/Request;Lorg/apache/catalina/connector/Response;)V+64
          j  org.apache.catalina.valves.ErrorReportValve.invoke(Lorg/apache/catalina/connector/Request;Lorg/apache/catalina/connector/Response;)V+6
          j  org.apache.catalina.core.StandardEngineValve.invoke(Lorg/apache/catalina/connector/Request;Lorg/apache/catalina/connector/Response;)V+42
          j  org.apache.catalina.connector.CoyoteAdapter.service(Lorg/apache/coyote/Request;Lorg/apache/coyote/Response;)V+158
          j  org.apache.coyote.http11.Http11Processor.process(Ljava/net/Socket;)V+514
          j  org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Ljava/net/Socket;)Z+82
          j  org.apache.tomcat.util.net.JIoEndpoint$Worker.run()V+41
          j  java.lang.Thread.run()V+11
          v  ~StubRoutines::call_stub

          ---------------  P R O C E S S  ---------------

          Java Threads: ( => current thread )
          =>0x085bbc00 JavaThread "http-8080-1" daemon [_thread_in_vm, id=23622, stack(0x90e1a000,0x90e6b000)]
            0x912ecc00 JavaThread "TP-Monitor" daemon [_thread_blocked, id=23619, stack(0x90e6b000,0x90ebc000)]
            0x91069c00 JavaThread "TP-Processor4" daemon [_thread_in_native, id=23618, stack(0x90ebc000,0x90f0d000)]
            0x9105f400 JavaThread "TP-Processor3" daemon [_thread_blocked, id=23617, stack(0x90f0d000,0x90f5e000)]
            0x9102f800 JavaThread "TP-Processor2" daemon [_thread_blocked, id=23616, stack(0x90f5e000,0x90faf000)]
            0x912ea400 JavaThread "TP-Processor1" daemon [_thread_blocked, id=23615, stack(0x90faf000,0x91000000)]
            0x912da000 JavaThread "http-8080-Acceptor-0" daemon [_thread_in_native, id=23614, stack(0x9113c000,0x9118d000)]
            0x91036000 JavaThread "ContainerBackgroundProcessor[StandardEngine[Catalina]]" daemon [_thread_blocked, id=23613, stack(0x9118d000,0x911de000)]
            0x912ac400 JavaThread "GC Daemon" daemon [_thread_blocked, id=23612, stack(0x91305000,0x91356000)]
            0x91615c00 JavaThread "Low Memory Detector" daemon [_thread_blocked, id=23610, stack(0x9141d000,0x9146e000)]
            0x91613c00 JavaThread "CompilerThread1" daemon [_thread_blocked, id=23609, stack(0x9146e000,0x914ef000)]
            0x91612000 JavaThread "CompilerThread0" daemon [_thread_blocked, id=23608, stack(0x914ef000,0x91570000)]
            0x91610800 JavaThread "Signal Dispatcher" daemon [_thread_blocked, id=23607, stack(0x91570000,0x915c1000)]
            0x91600800 JavaThread "Finalizer" daemon [_thread_blocked, id=23606, stack(0x9170f000,0x91760000)]
            0x080d8400 JavaThread "Reference Handler" daemon [_thread_blocked, id=23605, stack(0x91760000,0x917b1000)]
            0x08058400 JavaThread "main" [_thread_in_native, id=23601, stack(0xb6a4e000,0xb6a9f000)]

          Other Threads:
            0x080d4400 VMThread [stack: 0x917b1000,0x91832000] [id=23604]
            0x91617800 WatcherThread [stack: 0x9139c000,0x9141d000] [id=23611]

          VM state:not at safepoint (normal execution)

          VM Mutex/Monitor currently owned by a thread: None

          Heap
          PSYoungGen      total 24448K, used 339K [0xb0420000, 0xb1da0000, 0xb3900000)
            eden space 23168K, 1% used [0xb0420000,0xb0474cf8,0xb1ac0000)
            from space 1280K, 0% used [0xb1c20000,0xb1c20000,0xb1d60000)
            to   space 1408K, 0% used [0xb1ac0000,0xb1ac0000,0xb1c20000)
          PSOldGen        total 27072K, used 8597K [0x95d00000, 0x97770000, 0xb0420000)
            object space 27072K, 31% used [0x95d00000,0x96565510,0x97770000)
          PSPermGen       total 19200K, used 11186K [0x91d00000, 0x92fc0000, 0x95d00000)
            object space 19200K, 58% used [0x91d00000,0x927ec980,0x92fc0000)

          Dynamic libraries:
          08048000-08052000 r-xp 00000000 08:03 5775425    /usr/java/jdk1.6.0_16/bin/java
          08052000-08053000 rwxp 00009000 08:03 5775425    /usr/java/jdk1.6.0_16/bin/java
          08053000-08c64000 rwxp 00000000 00:00 0          [heap]
          90cac000-90cb9000 r-xp 00000000 08:03 28295296   /lib/libgcc_s.so.1
          90cb9000-90cba000 r-xp 0000c000 08:03 28295296   /lib/libgcc_s.so.1
          90cba000-90cbb000 rwxp 0000d000 08:03 28295296   /lib/libgcc_s.so.1
          90cbb000-90da3000 r-xp 00000000 08:03 5337022    /usr/lib/libstdc++.so.6.0.10
          90da3000-90da7000 r-xp 000e7000 08:03 5337022    /usr/lib/libstdc++.so.6.0.10
          90da7000-90da8000 rwxp 000eb000 08:03 5337022    /usr/lib/libstdc++.so.6.0.10
          90da8000-90dae000 rwxp 00000000 00:00 0
          90dd6000-90dd9000 r-xp 00000000 08:03 27729947   /home/play/lib/libspidhandle.so
          90dd9000-90dda000 r-xp 00002000 08:03 27729947   /home/play/lib/libspidhandle.so
          90dda000-90ddb000 rwxp 00003000 08:03 27729947   /home/play/lib/libspidhandle.so
          90ddb000-90ddc000 r-xs 0000e000 08:03 5808917    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/spidhandle.jar
          90ddc000-90ddd000 r-xs 00001000 08:03 5808916    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/slf4j-simple-1.5.8.jar
          90ddd000-90ddf000 r-xs 00004000 08:03 5808915    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/slf4j-api-1.5.6.jar
          90ddf000-90de5000 r-xs 00035000 08:03 5808914    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/logback-core-0.9.15.jar
          90de5000-90dea000 r-xs 00023000 08:03 5808913    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/logback-classic-0.9.15.jar
          90dea000-90df1000 r-xs 00059000 08:03 5808912    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/log4j-1.2.15.jar
          90df1000-90dfd000 r-xs 000a2000 08:03 5808911    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/jxl.jar
          90dfd000-90e07000 r-xs 0005c000 08:03 5808910    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/jstl-1.2.jar
          90e07000-90e1a000 r-xs 00114000 08:03 5808909    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/jsf-impl.jar
          90e1a000-90e1d000 ---p 00000000 00:00 0
          90e1d000-90e6b000 rwxp 00000000 00:00 0          [threadstack:0004d494]
          90e6b000-90e6e000 ---p 00000000 00:00 0
          90e6e000-90ebc000 rwxp 00000000 00:00 0
          90ebc000-90ebf000 ---p 00000000 00:00 0
          90ebf000-90f0d000 rwxp 00000000 00:00 0
          90f0d000-90f10000 ---p 00000000 00:00 0
          90f10000-90f5e000 rwxp 00000000 00:00 0
          90f5e000-90f61000 ---p 00000000 00:00 0
          90f61000-90faf000 rwxp 00000000 00:00 0
          90faf000-90fb2000 ---p 00000000 00:00 0
          90fb2000-91000000 rwxp 00000000 00:00 0
          91000000-910b3000 rwxp 00000000 00:00 0
          910b3000-91100000 ---p 00000000 00:00 0
          91100000-91105000 r-xs 0004a000 08:03 5808908    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/jsf-api.jar
          91105000-91107000 r-xs 0000d000 08:03 5808907    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/commons-logging-1.1.1.jar
          91107000-9113c000 r-xs 00000000 08:03 20439789   /var/run/nscd/dbl5FOXp (deleted)
          9113c000-9113f000 ---p 00000000 00:00 0
          9113f000-9118d000 rwxp 00000000 00:00 0
          9118d000-91190000 ---p 00000000 00:00 0
          91190000-911de000 rwxp 00000000 00:00 0
          911de000-911f1000 r-xp 00000000 08:03 5784005    /usr/java/jdk1.6.0_16/jre/lib/i386/libnet.so
          911f1000-911f2000 rwxp 00013000 08:03 5784005    /usr/java/jdk1.6.0_16/jre/lib/i386/libnet.so
          911f2000-911f5000 r-xs 00027000 08:03 5783936    /usr/java/jdk1.6.0_16/jre/lib/ext/sunjce_provider.jar
          911f5000-911fc000 r-xs 00091000 08:03 5784036    /usr/java/jdk1.6.0_16/jre/lib/jsse.jar
          911fc000-91200000 r-xs 00035000 08:03 5783937    /usr/java/jdk1.6.0_16/jre/lib/ext/sunpkcs11.jar
          91200000-912f8000 rwxp 00000000 00:00 0
          912f8000-91300000 ---p 00000000 00:00 0
          91300000-91302000 r-xs 0000a000 08:03 5808906    /usr/apache-tomcat-6.0.32/webapps/play/WEB-INF/lib/commons-codec-1.3.jar
          91302000-91305000 r-xs 00013000 08:03 5784024    /usr/java/jdk1.6.0_16/jre/lib/jce.jar
          91305000-91308000 ---p 00000000 00:00 0
          91308000-91356000 rwxp 00000000 00:00 0
          91356000-91359000 r-xs 000cb000 08:03 5783821    /usr/java/jdk1.6.0_16/jre/lib/ext/localedata.jar
          91359000-9135d000 r-xs 00036000 08:03 5808320    /usr/apache-tomcat-6.0.32/lib/catalina-tribes.jar
          9135d000-91360000 r-xs 0000f000 08:03 5808331    /usr/apache-tomcat-6.0.32/lib/tomcat-i18n-es.jar
          91360000-9136a000 r-xs 000b1000 08:03 5808329    /usr/apache-tomcat-6.0.32/lib/tomcat-coyote.jar
          9136a000-91371000 r-xs 0007a000 08:03 5808325    /usr/apache-tomcat-6.0.32/lib/jasper.jar
          91371000-91380000 r-xs 0011a000 08:03 5808321    /usr/apache-tomcat-6.0.32/lib/catalina.jar
          91380000-91382000 r-xs 0001e000 08:03 5808319    /usr/apache-tomcat-6.0.32/lib/catalina-ha.jar
          91382000-91386000 r-xs 0003a000 08:03 5808330    /usr/apache-tomcat-6.0.32/lib/tomcat-dbcp.jar
          91386000-91388000 r-xs 0000c000 08:03 5808318    /usr/apache-tomcat-6.0.32/lib/catalina-ant.jar
          91388000-9138a000 r-xs 00007000 08:03 5808323    /usr/apache-tomcat-6.0.32/lib/el-api.jar
          9138a000-9138c000 r-xs 00014000 08:03 5808328    /usr/apache-tomcat-6.0.32/lib/servlet-api.jar
          9138c000-9139a000 r-xs 00170000 08:03 5808322    /usr/apache-tomcat-6.0.32/lib/ecj-3.3.1.jar
          9139a000-9139c000 r-xs 0000c000 08:03 5808333    /usr/apache-tomcat-6.0.32/lib/tomcat-i18n-ja.jar
          9139c000-9139d000 ---p 00000000 00:00 0
          9139d000-9141d000 rwxp 00000000 00:00 0
          9141d000-91420000 ---p 00000000 00:00 0
          91420000-9146e000 rwxp 00000000 00:00 0
          9146e000-91471000 ---p 00000000 00:00 0
          91471000-914ef000 rwxp 00000000 00:00 0
          914ef000-914f2000 ---p 00000000 00:00 0
          914f2000-91570000 rwxp 00000000 00:00 0
          91570000-91573000 ---p 00000000 00:00 0
          91573000-915c1000 rwxp 00000000 00:00 0
          915c1000-91600000 r-xp 00000000 08:03 5546089    /usr/lib/locale/en_US.utf8/LC_CTYPE
          91600000-916ff000 rwxp 00000000 00:00 0
          916ff000-91700000 ---p 00000000 00:00 0
          91700000-91701000 rwxp 00000000 00:00 0
          91701000-91703000 r-xs 00011000 08:03 5808326    /usr/apache-tomcat-6.0.32/lib/jsp-api.jar
          91703000-91705000 r-xs 0000b000 08:03 5808332    /usr/apache-tomcat-6.0.32/lib/tomcat-i18n-fr.jar
          91705000-91708000 r-xs 00019000 08:03 5808324    /usr/apache-tomcat-6.0.32/lib/jasper-el.jar
          91708000-9170e000 r-xp 00000000 08:03 5784001    /usr/java/jdk1.6.0_16/jre/lib/i386/libmanagement.so
          9170e000-9170f000 rwxp 00005000 08:03 5784001    /usr/java/jdk1.6.0_16/jre/lib/i386/libmanagement.so
          9170f000-91712000 ---p 00000000 00:00 0
          91712000-91760000 rwxp 00000000 00:00 0
          91760000-91763000 ---p 00000000 00:00 0
          91763000-917b1000 rwxp 00000000 00:00 0
          917b1000-917b2000 ---p 00000000 00:00 0
          917b2000-91865000 rwxp 00000000 00:00 0
          91865000-919fb000 r-xs 02fb3000 08:03 5784038    /usr/java/jdk1.6.0_16/jre/lib/rt.jar
          919fb000-919fc000 ---p 00000000 00:00 0
          919fc000-91a7c000 rwxp 00000000 00:00 0
          91a7c000-91a7d000 ---p 00000000 00:00 0
          91a7d000-91b07000 rwxp 00000000 00:00 0
          91b07000-91b1d000 rwxp 00000000 00:00 0
          91b1d000-91b2b000 rwxp 00000000 00:00 0
          91b2b000-91bf1000 rwxp 00000000 00:00 0
          91bf1000-91bfb000 rwxp 00000000 00:00 0
          91bfb000-91c11000 rwxp 00000000 00:00 0
          91c11000-91c1f000 rwxp 00000000 00:00 0
          91c1f000-91ce4000 rwxp 00000000 00:00 0
          91ce4000-91cf2000 rwxp 00000000 00:00 0
          91cf2000-91cff000 rwxp 00000000 00:00 0
          91cff000-92fc0000 rwxp 00000000 00:00 0
          92fc0000-95d00000 rwxp 00000000 00:00 0
          95d00000-97770000 rwxp 00000000 00:00 0
          97770000-b0420000 rwxp 00000000 00:00 0
          b0420000-b1da0000 rwxp 00000000 00:00 0
          b1da0000-b3900000 rwxp 00000000 00:00 0
          b3900000-b3901000 r-xs 00003000 08:03 5808317    /usr/apache-tomcat-6.0.32/lib/annotations-api.jar
          b3901000-b3902000 r-xs 00006000 08:03 5808298    /usr/apache-tomcat-6.0.32/bin/tomcat-juli.jar
          b3902000-b3903000 r-xs 00005000 08:03 5808288    /usr/apache-tomcat-6.0.32/bin/commons-daemon.jar
          b3903000-b390a000 r-xs 00000000 08:03 5523095    /usr/lib/gconv/gconv-modules.cache
          b390a000-b3913000 rwxp 00000000 00:00 0
          b3913000-b39ca000 rwxp 00000000 00:00 0
          b39ca000-b3c0a000 rwxp 00000000 00:00 0
          b3c0a000-b69ca000 rwxp 00000000 00:00 0
          b69ca000-b69d9000 r-xp 00000000 08:03 5784014    /usr/java/jdk1.6.0_16/jre/lib/i386/libzip.so
          b69d9000-b69db000 rwxp 0000e000 08:03 5784014    /usr/java/jdk1.6.0_16/jre/lib/i386/libzip.so
          b69db000-b69e3000 rwxs 00000000 08:03 6743707    /tmp/hsperfdata_root/23600
          b69e3000-b6a18000 r-xs 00000000 08:03 20439787   /var/run/nscd/passwd
          b6a18000-b6a1e000 r-xp 00000000 08:03 5784018    /usr/java/jdk1.6.0_16/jre/lib/i386/native_threads/libhpi.so
          b6a1e000-b6a1f000 rwxp 00006000 08:03 5784018    /usr/java/jdk1.6.0_16/jre/lib/i386/native_threads/libhpi.so
          b6a1f000-b6a42000 r-xp 00000000 08:03 5783990    /usr/java/jdk1.6.0_16/jre/lib/i386/libjava.so
          b6a42000-b6a44000 rwxp 00023000 08:03 5783990    /usr/java/jdk1.6.0_16/jre/lib/i386/libjava.so
          b6a44000-b6a4c000 r-xp 00000000 08:03 28295217   /lib/librt-2.11.1.so
          b6a4c000-b6a4d000 r-xp 00007000 08:03 28295217   /lib/librt-2.11.1.so
          b6a4d000-b6a4e000 rwxp 00008000 08:03 28295217   /lib/librt-2.11.1.so
          b6a4e000-b6a51000 ---p 00000000 00:00 0
          b6a51000-b6a9f000 rwxp 00000000 00:00 0
          b6a9f000-b6ac5000 r-xp 00000000 08:03 28295195   /lib/libm-2.11.1.so
          b6ac5000-b6ac6000 r-xp 00026000 08:03 28295195   /lib/libm-2.11.1.so
          b6ac6000-b6ac7000 rwxp 00027000 08:03 28295195   /lib/libm-2.11.1.so
          b6ac7000-b7194000 r-xp 00000000 08:03 5784022    /usr/java/jdk1.6.0_16/jre/lib/i386/server/libjvm.so
          b7194000-b71e2000 rwxp 006cc000 08:03 5784022    /usr/java/jdk1.6.0_16/jre/lib/i386/server/libjvm.so
          b71e2000-b7605000 rwxp 00000000 00:00 0
          b7605000-b7760000 r-xp 00000000 08:03 28295187   /lib/libc-2.11.1.so
          b7760000-b7762000 r-xp 0015b000 08:03 28295187   /lib/libc-2.11.1.so
          b7762000-b7763000 rwxp 0015d000 08:03 28295187   /lib/libc-2.11.1.so
          b7763000-b7767000 rwxp 00000000 00:00 0
          b7767000-b776a000 r-xp 00000000 08:03 28295193   /lib/libdl-2.11.1.so
          b776a000-b776b000 r-xp 00002000 08:03 28295193   /lib/libdl-2.11.1.so
          b776b000-b776c000 rwxp 00003000 08:03 28295193   /lib/libdl-2.11.1.so
          b776c000-b7773000 r-xp 00000000 08:03 5783973    /usr/java/jdk1.6.0_16/jre/lib/i386/jli/libjli.so
          b7773000-b7775000 rwxp 00006000 08:03 5783973    /usr/java/jdk1.6.0_16/jre/lib/i386/jli/libjli.so
          b7775000-b778c000 r-xp 00000000 08:03 28295213   /lib/libpthread-2.11.1.so
          b778c000-b778d000 r-xp 00016000 08:03 28295213   /lib/libpthread-2.11.1.so
          b778d000-b778e000 rwxp 00017000 08:03 28295213   /lib/libpthread-2.11.1.so
          b778e000-b7790000 rwxp 00000000 00:00 0
          b7790000-b7791000 r-xs 00005000 08:03 5808283    /usr/apache-tomcat-6.0.32/bin/bootstrap.jar
          b7791000-b7792000 rwxp 00000000 00:00 0
          b7792000-b7793000 r-xp 00000000 00:00 0
          b7793000-b77a8000 r-xp 00000000 08:03 28295198   /lib/libnsl-2.11.1.so
          b77a8000-b77a9000 r-xp 00014000 08:03 28295198   /lib/libnsl-2.11.1.so
          b77a9000-b77aa000 rwxp 00015000 08:03 28295198   /lib/libnsl-2.11.1.so
          b77aa000-b77ac000 rwxp 00000000 00:00 0
          b77ac000-b77b7000 r-xp 00000000 08:03 5784013    /usr/java/jdk1.6.0_16/jre/lib/i386/libverify.so
          b77b7000-b77b8000 rwxp 0000b000 08:03 5784013    /usr/java/jdk1.6.0_16/jre/lib/i386/libverify.so
          b77b8000-b77b9000 rwxp 00000000 00:00 0
          b77b9000-b77d8000 r-xp 00000000 08:03 28295180   /lib/ld-2.11.1.so
          b77d8000-b77d9000 r-xp 0001e000 08:03 28295180   /lib/ld-2.11.1.so
          b77d9000-b77da000 rwxp 0001f000 08:03 28295180   /lib/ld-2.11.1.so
          bfcc6000-bfcdb000 rwxp 00000000 00:00 0          [stack]
          ffffe000-fffff000 r-xp 00000000 00:00 0          [vdso]

          VM Arguments:
          jvm_args: -Djava.util.logging.config.file=/usr/apache-tomcat-6.0.32/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/usr/apache-tomcat-6.0.32/endorsed -Dcatalina.base=/usr/apache-tomcat-6.0.32 -Dcatalina.home=/usr/apache-tomcat-6.0.32 -Djava.io.tmpdir=/usr/apache-tomcat-6.0.32/temp
          java_command: org.apache.catalina.startup.Bootstrap start
          Launcher Type: SUN_STANDARD

          Environment Variables:
          JAVA_HOME=/usr/java/jdk1.6.0_16
          CLASSPATH=/usr/apache-tomcat-6.0.32/bin/bootstrap.jar
          PATH=/sbin:/usr/sbin:/usr/local/sbin:/root/bin:/usr/local/bin:/usr/bin:/bin:/usr/bin/X11:/usr/X11R6/bin:/usr/games:/usr/lib/mit/bin:/usr/lib/mit/sbin:/usr/java/jdk1.6.0_16/bin:/usr/java/jdk1.6.0_16/jre/bin
          LD_LIBRARY_PATH=/usr/java/jdk1.6.0_16/jre/lib/i386/server:/usr/java/jdk1.6.0_16/jre/lib/i386:/usr/java/jdk1.6.0_16/jre/../lib/i386:/home/play/lib
          SHELL=/bin/bash
          HOSTTYPE=i386
          OSTYPE=linux
          MACHTYPE=i686-suse-linux

          Signal Handlers:
          SIGSEGV: [libjvm.so+0x650710], sa_mask[0]=0x7ffbfeff, sa_flags=0x10000004
          SIGBUS: [libjvm.so+0x650710], sa_mask[0]=0x7ffbfeff, sa_flags=0x10000004
          SIGFPE: [libjvm.so+0x52f600], sa_mask[0]=0x7ffbfeff, sa_flags=0x10000004
          SIGPIPE: [libjvm.so+0x52f600], sa_mask[0]=0x7ffbfeff, sa_flags=0x10000004
          SIGXFSZ: [libjvm.so+0x52f600], sa_mask[0]=0x7ffbfeff, sa_flags=0x10000004
          SIGILL: [libjvm.so+0x52f600], sa_mask[0]=0x7ffbfeff, sa_flags=0x10000004
          SIGUSR1: SIG_DFL, sa_mask[0]=0x00000000, sa_flags=0x00000000
          SIGUSR2: [libjvm.so+0x5321f0], sa_mask[0]=0x00000000, sa_flags=0x10000004
          SIGHUP: [libjvm.so+0x531f20], sa_mask[0]=0x7ffbfeff, sa_flags=0x10000004
          SIGINT: SIG_IGN, sa_mask[0]=0x00000000, sa_flags=0x00000000
          SIGTERM: [libjvm.so+0x531f20], sa_mask[0]=0x7ffbfeff, sa_flags=0x10000004
          SIGQUIT: [libjvm.so+0x531f20], sa_mask[0]=0x7ffbfeff, sa_flags=0x10000004


          ---------------  S Y S T E M  ---------------

          OS:SUSE Linux Enterprise Server 11 (i586)
          VERSION = 11
          PATCHLEVEL = 1

          uname:Linux 2.6.32.12-0.7-pae #1 SMP 2010-05-20 11:14:20 +0200 i686
          libc:glibc 2.11.1 NPTL 2.11.1
          rlimit: STACK 8192k, CORE 1k, NPROC 15118, NOFILE 8192, AS 3192000k
          load average:0.00 0.04 0.05

          CPU:total 2 (2 cores per cpu, 1 threads per core) family 6 model 23 stepping 10, cmov, cx8, fxsr, mmx, sse, sse2, sse3, ssse3

          Memory: 4k page, physical 1941704k(213752k free), swap 2048276k(1540564k free)

          vm_info: Java HotSpot(TM) Server VM (14.2-b01) for linux-x86 JRE (1.6.0_16-b01), built on Jul 31 2009 06:03:51 by "java_re" with gcc 3.2.1-7a (J2SE release)

          time: Sat Mar 12 17:13:08 2011
          elapsed time: 27 seconds

          一開始以為是JVM無(wú)法釋放C的對(duì)象,但后來(lái)發(fā)現(xiàn)
          Java代碼  收藏代碼
          1. Heap  
          2.  PSYoungGen      total 24448K, used 339K [0xb0420000, 0xb1da0000, 0xb3900000)  
          3.   eden space 23168K, 1% used [0xb0420000,0xb0474cf8,0xb1ac0000)  
          4.   from space 1280K, 0% used [0xb1c20000,0xb1c20000,0xb1d60000)  
          5.   to   space 1408K, 0% used [0xb1ac0000,0xb1ac0000,0xb1c20000)  
          6.  PSOldGen        total 27072K, used 8597K [0x95d00000, 0x97770000, 0xb0420000)  
          7.   object space 27072K, 31% used [0x95d00000,0x96565510,0x97770000)  
          8.  PSPermGen       total 19200K, used 11186K [0x91d00000, 0x92fc0000, 0x95d00000)  
          9.   object space 19200K, 58% used [0x91d00000,0x927ec980,0x92fc0000)  


          并沒有出現(xiàn)堆棧縊出的現(xiàn)象,所以排除該原因。

          查閱 文檔:
                JavaTM 2 Platform, Standard Edition 5.0
                Troubleshooting and Diagnostic Guide
                文檔中提到:
               
                If you get a crash in a native application library (like the above examples) then you may be able to
                attach the native debugger (dbx, gdb, windbg depending on the operating system) to the core file/crash
                dump if it is available. Another approach is run with the -Xcheck:jni option added to the command
                line (section 1.17.3). The -Xcheck:jni option is not guaranteed to find all issues with JNI code but it
                can help identify a significant number of issues.
               
                解決方法:
                啟動(dòng)JVM時(shí)增加啟動(dòng)參數(shù) -Xcheck:jni
                日志中輸出JNI的錯(cuò)誤日志:
               
          Java代碼  收藏代碼
          1. FATAL ERROR in native method: JNI string operation received a non-string  
          2. at com.spidHandle.api.SpidHandle.getSPID(Native Method)  
          3. at com.spidHandle.api.SpidHandle.buildSpID(SpidHandle.java:12)  
          4. at com.play.servlet.PlayServlet.service(PlayServlet.java:190)  
          5. at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)  
          6. at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)  
          7. at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)  
          8. at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)  
          9. at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)  
          10. at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)  
          11. at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)  
          12. at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)  
          13. at org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:861)  
          14. at org.apache.coyote.http11.Http11AprProtocol$Http11ConnectionHandler.process(Http11AprProtocol.java:579)  
          15. at org.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint.java:1584)  
          16. at java.lang.Thread.run(Thread.java:619)
          JVM崩潰的原因找到了.是由于傳入C方法體中某個(gè)參數(shù)值為NULL,如buildSpID(String path, String login_name, String password, String key)中l(wèi)ogin_name為NULL,導(dǎo)致傳遞給C程序的參數(shù)為NULL.NULL值傳遞給C,C不能識(shí)別他為字符串,所以JVM崩潰.

          http://zhxmyself.iteye.com/blog/961249
          posted @ 2011-09-27 14:42 temper 閱讀(6196) | 評(píng)論 (0)編輯 收藏
            2011年8月18日
          今天客戶發(fā)過(guò)來(lái)一個(gè)新的jar包B.jar,讓我替換原來(lái)的進(jìn)行測(cè)試,但是替換完畢執(zhí)行后,出現(xiàn)如下錯(cuò)誤:
          C:\Program Files\Java\jdk1.5.0_16
          Exception in thread "main" java.lang.SecurityException: class "xx.xx"'s signer information does not match signer information of other classes in the same package
                  at java.lang.ClassLoader.checkCerts(ClassLoader.java:775)
                  at java.lang.ClassLoader.preDefineClass(ClassLoader.java:487)
                  at java.lang.ClassLoader.defineClass(ClassLoader.java:614)
                  at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:12
          4)
                  at java.net.URLClassLoader.defineClass(URLClassLoader.java:260)
                  at java.net.URLClassLoader.access$100(URLClassLoader.java:56)
                  at java.net.URLClassLoader$1.run(URLClassLoader.java:195)
                  at java.security.AccessController.doPrivileged(Native Method)
                  at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
                  at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
                  at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:268)
                  at java.lang.ClassLoader.loadClass(ClassLoader.java:251)
                  at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:319)
                  at xx.xx(xx.java:80)

          網(wǎng)上搜了一圈,大部分說(shuō)引入的jar包呢有相同類名的類,所以loader的時(shí)候出現(xiàn)錯(cuò)誤。

          但是目前做的一個(gè)小產(chǎn)品,只有兩個(gè)jar包,A.jar和前文提到的B.jar,沒有引入第三方包。我仔細(xì)查了一下兩個(gè)jar包,不存在相同類名的情況。

          最后發(fā)現(xiàn)這個(gè)問(wèn)題很多時(shí)候和數(shù)字簽名這個(gè)關(guān)鍵字一起出現(xiàn)。然后仔細(xì)檢查,發(fā)現(xiàn)新的B.jar里面忘記加數(shù)字簽名了。

          把A.jar里面的數(shù)字簽名刪除,運(yùn)行正常。

          目前在等待加完數(shù)字簽名的B.jar,也在查資料尋找出現(xiàn)此問(wèn)題的原因,未完待續(xù)。
          posted @ 2011-08-18 18:53 temper 閱讀(5114) | 評(píng)論 (0)編輯 收藏
            2011年1月26日

          進(jìn)程只是提供了一段地址空間和內(nèi)核對(duì)象,其運(yùn) 行時(shí)通過(guò)其他地址空間內(nèi)的主線程來(lái)體現(xiàn)的。當(dāng)主線程的進(jìn)入點(diǎn)函數(shù)返回時(shí),進(jìn)程也就隨之而技術(shù)。這種進(jìn)程的種植方式是進(jìn)程的正常退出。進(jìn)程中的所有縣城資源 都能夠得到正確的清除。除了這種進(jìn)程的正常退出方式之外,優(yōu)勢(shì)還需要在程序中通過(guò)代碼來(lái)強(qiáng)制結(jié)束本進(jìn)程或其他進(jìn)程的運(yùn)行。

          ExitProcess

          void ExitProcess(UINT uExitCode);

          其 參數(shù)uExitCode為進(jìn)城設(shè)置了退出代碼。該函數(shù)具有強(qiáng)制性,在執(zhí)行完畢后進(jìn)程即被結(jié)束,因此位于其后的任何代碼將不能被執(zhí)行。雖然 ExitProcess()函數(shù)可以再結(jié)束進(jìn)程同時(shí)通知與其關(guān)聯(lián)的動(dòng)態(tài)鏈接庫(kù),但是由于他的這種強(qiáng)制性,使得ExitProcess()函數(shù)在使用上將存 有安全隱患。例如,如果最親愛程序調(diào)用ExitProcess()函數(shù)之前曾用new操作,申請(qǐng)一段空間,那么敬愛那個(gè)會(huì)由于ExitProcess() 函數(shù)的強(qiáng)制性而無(wú)法通過(guò)delete操作符將其釋放,從而造成內(nèi)存泄露。

          有鑒于ExitProcess()函數(shù)的強(qiáng)制性和安全性,在使用時(shí)一定要引起注意。

          Terminateprocess()

          ExitProcess 只能強(qiáng)制本進(jìn)程的推出,如果要在一個(gè)進(jìn)程中強(qiáng)制結(jié)束其他的進(jìn)程就需要用TerminateProcess()來(lái)實(shí)現(xiàn),與ExitProcess()不 同,TerminateProcess()函數(shù)執(zhí)行后,被終止的進(jìn)程不會(huì)得到任何關(guān)于程序退出的通知。也就是說(shuō),被終止的進(jìn)程是無(wú)法再結(jié)束運(yùn)行前進(jìn)程推出 前的收尾工作的。所以,通常只有在其他任何地方都無(wú)法迫使進(jìn)程退出時(shí)才會(huì)考慮使用TerminateProcess()去強(qiáng)制結(jié)束進(jìn)程。

          BOOL TerminateProcess(HANDLE hProcess, UINT uExitCode);

          參 數(shù)hProcess和uExitCode分別為進(jìn)城句柄和退出代碼。如果被結(jié)束的是本進(jìn)程,可以通過(guò)GetCurrentProcess()獲取到句柄。 TerminateProcess()是異步執(zhí)行的,在調(diào)用后返回并不能確定被終止進(jìn)程是否已經(jīng)真的退出,如果調(diào)用TerminateProcess() 的進(jìn)程對(duì)此細(xì)節(jié)關(guān)心,可以通過(guò)WaitForSingleObject()來(lái)等待進(jìn)程的真正結(jié)束。

          在VC中如何結(jié)束系統(tǒng)正在運(yùn)行的其他進(jìn)程(該進(jìn)程必須有窗口界面),其實(shí)很簡(jiǎn)單,按照如下步驟進(jìn)程:

          1)取得進(jìn)程的句柄(利用FindWindow函數(shù)得到);

          2)獲取進(jìn)程ID號(hào)(用GetWindowThreadProcessId函數(shù)獲取);

          3)打開進(jìn)程,OpenProcess函數(shù)中的第一個(gè)參數(shù)設(shè)為PROCESS_TERMINATE,就可以獲取處理該進(jìn)程的句柄;

          4)利用TerminateProcess函數(shù)結(jié)束進(jìn)程,將該函數(shù)的第二個(gè)參數(shù)設(shè)為4.

          posted @ 2011-01-26 15:53 temper 閱讀(4391) | 評(píng)論 (0)編輯 收藏
            2010年12月20日

          Java 語(yǔ)言中的 volatile 變量可以被看作是一種 “程度較輕的 synchronized”;與 synchronized 塊相比,volatile 變量所需的編碼較少,并且運(yùn)行時(shí)開銷也較少,但是它所能實(shí)現(xiàn)的功能也僅是 synchronized 的一部分。本文介紹了幾種有效使用 volatile 變量的模式,并強(qiáng)調(diào)了幾種不適合使用 volatile 變量的情形。

          鎖提供了兩種主要特性:互斥(mutual exclusion)可見性(visibility)。互斥即一次 只允許一個(gè)線程持有某個(gè)特定的鎖,因此可使用該特性實(shí)現(xiàn)對(duì)共享數(shù)據(jù)的協(xié)調(diào)訪問(wèn)協(xié)議,這樣,一次就只有一個(gè)線程能夠使用該共享數(shù)據(jù)。可見性要更加復(fù)雜一些, 它必須確保釋放鎖之前對(duì)共享數(shù)據(jù)做出的更改對(duì)于隨后獲得該鎖的另一個(gè)線程是可見的 —— 如果沒有同步機(jī)制提供的這種可見性保證,線程看到的共享變量可能是修改前的值或不一致的值,這將引發(fā)許多嚴(yán)重問(wèn)題。

          Volatile 變量

          Volatile 變量具有 synchronized 的可見性特性,但是不具備原子特性。這就是說(shuō)線程能夠自動(dòng)發(fā)現(xiàn) volatile 變量的最新值。Volatile 變量可用于提供線程安全,但是只能應(yīng)用于非常有限的一組用例:多個(gè)變量之間或者某個(gè)變量的當(dāng)前值與修改后值之間沒有約束。因此,單獨(dú)使用 volatile 還不足以實(shí)現(xiàn)計(jì)數(shù)器、互斥鎖或任何具有與多個(gè)變量相關(guān)的不變式(Invariants)的類(例如 “start <=end”)。

          出于簡(jiǎn)易性或可伸縮性的考慮,您可能傾向于使用 volatile 變量而不是鎖。當(dāng)使用 volatile 變量而非鎖時(shí),某些習(xí)慣用法(idiom)更加易于編碼和閱讀。此外,volatile 變量不會(huì)像鎖那樣造成線程阻塞,因此也很少造成可伸縮性問(wèn)題。在某些情況下,如果讀操作遠(yuǎn)遠(yuǎn)大于寫操作,volatile 變量還可以提供優(yōu)于鎖的性能優(yōu)勢(shì)。

          正確使用 volatile 變量的條件

          您只能在有限的一些情形下使用 volatile 變量替代鎖。要使 volatile 變量提供理想的線程安全,必須同時(shí)滿足下面兩個(gè)條件:

          • 對(duì)變量的寫操作不依賴于當(dāng)前值。
          • 該變量沒有包含在具有其他變量的不變式中。

          實(shí)際上,這些條件表明,可以被寫入 volatile 變量的這些有效值獨(dú)立于任何程序的狀態(tài),包括變量的當(dāng)前狀態(tài)。

          第一個(gè)條件的限制使 volatile 變量不能用作線程安全計(jì)數(shù)器。雖然增量操作(x++)看上去類似一個(gè)單獨(dú)操作,實(shí)際上它是一個(gè)由讀取-修改-寫入操作序列組成的組合操作,必須以原子方式執(zhí)行,而 volatile 不能提供必須的原子特性。實(shí)現(xiàn)正確的操作需要使 x 的值在操作期間保持不變,而 volatile 變量無(wú)法實(shí)現(xiàn)這點(diǎn)。(然而,如果將值調(diào)整為只從單個(gè)線程寫入,那么可以忽略第一個(gè)條件。)

          大多數(shù)編程情形都會(huì)與這兩個(gè)條件的其中之一沖突,使得 volatile 變量不能像 synchronized 那樣普遍適用于實(shí)現(xiàn)線程安全。清單 1 顯示了一個(gè)非線程安全的數(shù)值范圍類。它包含了一個(gè)不變式 —— 下界總是小于或等于上界。


          清單 1. 非線程安全的數(shù)值范圍類
                          
          @NotThreadSafe
          public class NumberRange {
          private int lower, upper;

          public int getLower() { return lower; }
          public int getUpper() { return upper; }

          public void setLower(int value) {
          if (value > upper)
          throw new IllegalArgumentException(...);
          lower = value;
          }

          public void setUpper(int value) {
          if (value < lower)
          throw new IllegalArgumentException(...);
          upper = value;
          }
          }

          這種方式限制了范圍的狀態(tài)變量,因此將 lower 和 upper 字段定義為 volatile 類型不能夠充分實(shí)現(xiàn)類的線程安全;從而仍然需要使用同步。否則,如果湊巧兩個(gè)線程在同一時(shí)間使用不一致的值執(zhí)行 setLowersetUpper 的話,則會(huì)使范圍處于不一致的狀態(tài)。例如,如果初始狀態(tài)是 (0, 5),同一時(shí)間內(nèi),線程 A 調(diào)用 setLower(4) 并且線程 B 調(diào)用 setUpper(3),顯然這兩個(gè)操作交叉存入的值是不符合條件的,那么兩個(gè)線程都會(huì)通過(guò)用于保護(hù)不變式的檢查,使得最后的范圍值是 (4, 3) —— 一個(gè)無(wú)效值。至于針對(duì)范圍的其他操作,我們需要使 setLower()setUpper() 操作原子化 —— 而將字段定義為 volatile 類型是無(wú)法實(shí)現(xiàn)這一目的的。

          性能考慮

          使用 volatile 變量的主要原因是其簡(jiǎn)易性:在某些情形下,使用 volatile 變量要比使用相應(yīng)的鎖簡(jiǎn)單得多。使用 volatile 變量次要原因是其性能:某些情況下,volatile 變量同步機(jī)制的性能要優(yōu)于鎖。

          很難做出準(zhǔn)確、全面的評(píng)價(jià),例如 “X 總是比 Y 快”,尤其是對(duì) JVM 內(nèi)在的操作而言。(例如,某些情況下 VM 也許能夠完全刪除鎖機(jī)制,這使得我們難以抽象地比較 volatilesynchronized 的開銷。)就是說(shuō),在目前大多數(shù)的處理器架構(gòu)上,volatile 讀操作開銷非常低 —— 幾乎和非 volatile 讀操作一樣。而 volatile 寫操作的開銷要比非 volatile 寫操作多很多,因?yàn)橐WC可見性需要實(shí)現(xiàn)內(nèi)存界定(Memory Fence),即便如此,volatile 的總開銷仍然要比鎖獲取低。

          volatile 操作不會(huì)像鎖一樣造成阻塞,因此,在能夠安全使用 volatile 的情況下,volatile 可以提供一些優(yōu)于鎖的可伸縮特性。如果讀操作的次數(shù)要遠(yuǎn)遠(yuǎn)超過(guò)寫操作,與鎖相比,volatile 變量通常能夠減少同步的性能開銷。

          正確使用 volatile 的模式

          很多并發(fā)性專家事實(shí)上往往引導(dǎo)用戶遠(yuǎn)離 volatile 變量,因?yàn)槭褂盟鼈円仁褂面i更加容易出錯(cuò)。然而,如果謹(jǐn)慎地遵循一些良好定義的模式,就能夠在很多場(chǎng)合內(nèi)安全地使用 volatile 變量。要始終牢記使用 volatile 的限制 —— 只有在狀態(tài)真正獨(dú)立于程序內(nèi)其他內(nèi)容時(shí)才能使用 volatile —— 這條規(guī)則能夠避免將這些模式擴(kuò)展到不安全的用例。

          模式 #1:狀態(tài)標(biāo)志

          也許實(shí)現(xiàn) volatile 變量的規(guī)范使用僅僅是使用一個(gè)布爾狀態(tài)標(biāo)志,用于指示發(fā)生了一個(gè)重要的一次性事件,例如完成初始化或請(qǐng)求停機(jī)。

          很多應(yīng)用程序包含了一種控制結(jié)構(gòu),形式為 “在還沒有準(zhǔn)備好停止程序時(shí)再執(zhí)行一些工作”,如清單 2 所示:


          清單 2. 將 volatile 變量作為狀態(tài)標(biāo)志使用
                          
          volatile boolean shutdownRequested;

          ...

          public void shutdown() { shutdownRequested = true; }

          public void doWork() {
          while (!shutdownRequested) {
          // do stuff
          }
          }

          很可能會(huì)從循環(huán)外部調(diào)用 shutdown() 方法 —— 即在另一個(gè)線程中 —— 因此,需要執(zhí)行某種同步來(lái)確保正確實(shí)現(xiàn) shutdownRequested 變量的可見性。(可能會(huì)從 JMX 偵聽程序、GUI 事件線程中的操作偵聽程序、通過(guò) RMI 、通過(guò)一個(gè) Web 服務(wù)等調(diào)用)。然而,使用 synchronized 塊編寫循環(huán)要比使用清單 2 所示的 volatile 狀態(tài)標(biāo)志編寫麻煩很多。由于 volatile 簡(jiǎn)化了編碼,并且狀態(tài)標(biāo)志并不依賴于程序內(nèi)任何其他狀態(tài),因此此處非常適合使用 volatile。

          這種類型的狀態(tài)標(biāo)記的一個(gè)公共特性是:通常只有一種狀態(tài)轉(zhuǎn)換;shutdownRequested 標(biāo)志從 false 轉(zhuǎn)換為 true,然后程序停止。這種模式可以擴(kuò)展到來(lái)回轉(zhuǎn)換的狀態(tài)標(biāo)志,但是只有在轉(zhuǎn)換周期不被察覺的情況下才能擴(kuò)展(從 falsetrue,再轉(zhuǎn)換到 false)。此外,還需要某些原子狀態(tài)轉(zhuǎn)換機(jī)制,例如原子變量。

          模式 #2:一次性安全發(fā)布(one-time safe publication)

          缺乏同步會(huì)導(dǎo)致無(wú)法實(shí)現(xiàn)可見性,這使得確定何時(shí)寫入對(duì)象引用而不是原語(yǔ)值變得更加困難。在缺乏同步的情況下,可能會(huì)遇到某個(gè)對(duì)象引用的更新值(由另一個(gè)線 程寫入)和該對(duì)象狀態(tài)的舊值同時(shí)存在。(這就是造成著名的雙重檢查鎖定(double-checked-locking)問(wèn)題的根源,其中對(duì)象引用在沒有 同步的情況下進(jìn)行讀操作,產(chǎn)生的問(wèn)題是您可能會(huì)看到一個(gè)更新的引用,但是仍然會(huì)通過(guò)該引用看到不完全構(gòu)造的對(duì)象)。

          實(shí)現(xiàn)安全發(fā)布對(duì)象的一種技術(shù)就是將對(duì)象引用定義為 volatile 類型。清單 3 展示了一個(gè)示例,其中后臺(tái)線程在啟動(dòng)階段從數(shù)據(jù)庫(kù)加載一些數(shù)據(jù)。其他代碼在能夠利用這些數(shù)據(jù)時(shí),在使用之前將檢查這些數(shù)據(jù)是否曾經(jīng)發(fā)布過(guò)。


          清單 3. 將 volatile 變量用于一次性安全發(fā)布
                          
          public class BackgroundFloobleLoader {
          public volatile Flooble theFlooble;

          public void initInBackground() {
          // do lots of stuff
          theFlooble = new Flooble(); // this is the only write to theFlooble
          }
          }

          public class SomeOtherClass {
          public void doWork() {
          while (true) {
          // do some stuff...
          // use the Flooble, but only if it is ready
          if (floobleLoader.theFlooble != null)
          doSomething(floobleLoader.theFlooble);
          }
          }
          }

          如果 theFlooble 引用不是 volatile 類型,doWork() 中的代碼在解除對(duì) theFlooble 的引用時(shí),將會(huì)得到一個(gè)不完全構(gòu)造的 Flooble

          該模式的一個(gè)必要條件是:被發(fā)布的對(duì)象必須是線程安全的,或者是有效的不可變對(duì)象(有效不可變意味著對(duì)象的狀態(tài)在發(fā)布之后永遠(yuǎn)不會(huì)被修改)。volatile 類型的引用可以確保對(duì)象的發(fā)布形式的可見性,但是如果對(duì)象的狀態(tài)在發(fā)布后將發(fā)生更改,那么就需要額外的同步。

          模式 #3:獨(dú)立觀察(independent observation)

          安全使用 volatile 的另一種簡(jiǎn)單模式是:定期 “發(fā)布” 觀察結(jié)果供程序內(nèi)部使用。例如,假設(shè)有一種環(huán)境傳感器能夠感覺環(huán)境溫度。一個(gè)后臺(tái)線程可能會(huì)每隔幾秒讀取一次該傳感器,并更新包含當(dāng)前文檔的 volatile 變量。然后,其他線程可以讀取這個(gè)變量,從而隨時(shí)能夠看到最新的溫度值。

          使用該模式的另一種應(yīng)用程序就是收集程序的統(tǒng)計(jì)信息。清單 4 展示了身份驗(yàn)證機(jī)制如何記憶最近一次登錄的用戶的名字。將反復(fù)使用 lastUser 引用來(lái)發(fā)布值,以供程序的其他部分使用。


          清單 4. 將 volatile 變量用于多個(gè)獨(dú)立觀察結(jié)果的發(fā)布
                          
          public class UserManager {
          public volatile String lastUser;

          public boolean authenticate(String user, String password) {
          boolean valid = passwordIsValid(user, password);
          if (valid) {
          User u = new User();
          activeUsers.add(u);
          lastUser = user;
          }
          return valid;
          }
          }

          該模式是前面模式的擴(kuò)展;將某個(gè)值發(fā)布以在程序內(nèi)的其他地方使用,但是與一次性事件的發(fā)布不同,這是一系列獨(dú)立事件。這個(gè)模式要求被發(fā)布的值是有效不可變的 —— 即值的狀態(tài)在發(fā)布后不會(huì)更改。使用該值的代碼需要清楚該值可能隨時(shí)發(fā)生變化。

          模式 #4:“volatile bean” 模式

          volatile bean 模式適用于將 JavaBeans 作為“榮譽(yù)結(jié)構(gòu)”使用的框架。在 volatile bean 模式中,JavaBean 被用作一組具有 getter 和/或 setter 方法 的獨(dú)立屬性的容器。volatile bean 模式的基本原理是:很多框架為易變數(shù)據(jù)的持有者(例如 HttpSession)提供了容器,但是放入這些容器中的對(duì)象必須是線程安全的。

          在 volatile bean 模式中,JavaBean 的所有數(shù)據(jù)成員都是 volatile 類型的,并且 getter 和 setter 方法必須非常普通 —— 除了獲取或設(shè)置相應(yīng)的屬性外,不能包含任何邏輯。此外,對(duì)于對(duì)象引用的數(shù)據(jù)成員,引用的對(duì)象必須是有效不可變的。(這將禁止具有數(shù)組值的屬性,因?yàn)楫?dāng)數(shù)組 引用被聲明為 volatile 時(shí),只有引用而不是數(shù)組本身具有 volatile 語(yǔ)義)。對(duì)于任何 volatile 變量,不變式或約束都不能包含 JavaBean 屬性。清單 5 中的示例展示了遵守 volatile bean 模式的 JavaBean:


          清單 5. 遵守 volatile bean 模式的 Person 對(duì)象
                          
          @ThreadSafe
          public class Person {
          private volatile String firstName;
          private volatile String lastName;
          private volatile int age;

          public String getFirstName() { return firstName; }
          public String getLastName() { return lastName; }
          public int getAge() { return age; }

          public void setFirstName(String firstName) {
          this.firstName = firstName;
          }

          public void setLastName(String lastName) {
          this.lastName = lastName;
          }

          public void setAge(int age) {
          this.age = age;
          }
          }

          volatile 的高級(jí)模式

          前面幾節(jié)介紹的模式涵蓋了大部分的基本用例,在這些模式中使用 volatile 非常有用并且簡(jiǎn)單。這一節(jié)將介紹一種更加高級(jí)的模式,在該模式中,volatile 將提供性能或可伸縮性優(yōu)勢(shì)。

          volatile 應(yīng)用的的高級(jí)模式非常脆弱。因此,必須對(duì)假設(shè)的條件仔細(xì)證明,并且這些模式被嚴(yán)格地封裝了起來(lái),因?yàn)榧词狗浅P〉母囊矔?huì)損壞您的代碼!同樣,使用更高級(jí) 的 volatile 用例的原因是它能夠提升性能,確保在開始應(yīng)用高級(jí)模式之前,真正確定需要實(shí)現(xiàn)這種性能獲益。需要對(duì)這些模式進(jìn)行權(quán)衡,放棄可讀性或可維護(hù)性來(lái)?yè)Q取可能的性 能收益 —— 如果您不需要提升性能(或者不能夠通過(guò)一個(gè)嚴(yán)格的測(cè)試程序證明您需要它),那么這很可能是一次糟糕的交易,因?yàn)槟芸赡軙?huì)得不償失,換來(lái)的東西要比放棄的 東西價(jià)值更低。

          模式 #5:開銷較低的讀-寫鎖策略

          目前為止,您應(yīng)該了解了 volatile 的功能還不足以實(shí)現(xiàn)計(jì)數(shù)器。因?yàn)?++x 實(shí)際上是三種操作(讀、添加、存儲(chǔ))的簡(jiǎn)單組合,如果多個(gè)線程湊巧試圖同時(shí)對(duì) volatile 計(jì)數(shù)器執(zhí)行增量操作,那么它的更新值有可能會(huì)丟失。

          然而,如果讀操作遠(yuǎn)遠(yuǎn)超過(guò)寫操作,您可以結(jié)合使用內(nèi)部鎖和 volatile 變量來(lái)減少公共代碼路徑的開銷。清單 6 中顯示的線程安全的計(jì)數(shù)器使用 synchronized 確保增量操作是原子的,并使用 volatile 保證當(dāng)前結(jié)果的可見性。如果更新不頻繁的話,該方法可實(shí)現(xiàn)更好的性能,因?yàn)樽x路徑的開銷僅僅涉及 volatile 讀操作,這通常要優(yōu)于一個(gè)無(wú)競(jìng)爭(zhēng)的鎖獲取的開銷。


          清單 6. 結(jié)合使用 volatile 和 synchronized 實(shí)現(xiàn) “開銷較低的讀-寫鎖”
                          
          @ThreadSafe
          public class CheesyCounter {
          // Employs the cheap read-write lock trick
          // All mutative operations MUST be done with the 'this' lock held
          @GuardedBy("this") private volatile int value;

          public int getValue() { return value; }

          public synchronized int increment() {
          return value++;
          }
          }

          之所以將這種技術(shù)稱之為 “開銷較低的讀-寫鎖” 是因?yàn)槟褂昧瞬煌耐綑C(jī)制進(jìn)行讀寫操作。因?yàn)楸纠械膶懖僮鬟`反了使用 volatile 的第一個(gè)條件,因此不能使用 volatile 安全地實(shí)現(xiàn)計(jì)數(shù)器 —— 您必須使用鎖。然而,您可以在讀操作中使用 volatile 確保當(dāng)前值的可見性, 因此可以使用鎖進(jìn)行所有變化的操作,使用 volatile 進(jìn)行只讀操作。其中,鎖一次只允許一個(gè)線程訪問(wèn)值,volatile 允許多個(gè)線程執(zhí)行讀操作,因此當(dāng)使用 volatile 保證讀代碼路徑時(shí),要比使用鎖執(zhí)行全部代碼路徑獲得更高的共享度 —— 就像讀-寫操作一樣。然而,要隨時(shí)牢記這種模式的弱點(diǎn):如果超越了該模式的最基本應(yīng)用,結(jié)合這兩個(gè)競(jìng)爭(zhēng)的同步機(jī)制將變得非常困難。

          結(jié)束語(yǔ)

          與鎖相比,Volatile 變量是一種非常簡(jiǎn)單但同時(shí)又非常脆弱的同步機(jī)制,它在某些情況下將提供優(yōu)于鎖的性能和伸縮性。如果嚴(yán)格遵循 volatile 的使用條件 —— 即變量真正獨(dú)立于其他變量和自己以前的值 —— 在某些情況下可以使用 volatile 代替 synchronized 來(lái)簡(jiǎn)化代碼。然而,使用 volatile 的代碼往往比使用鎖的代碼更加容易出錯(cuò)。本文介紹的模式涵蓋了可以使用 volatile 代替 synchronized 的最常見的一些用例。遵循這些模式(注意使用時(shí)不要超過(guò)各自的限制)可以幫助您安全地實(shí)現(xiàn)大多數(shù)用例,使用 volatile 變量獲得更佳性能。



          http://www.ibm.com/developerworks/cn/java/j-jtp06197.html

          posted @ 2010-12-20 14:02 temper 閱讀(245) | 評(píng)論 (0)編輯 收藏
            2010年7月26日
          java調(diào)用bat,用xcopy拷貝系統(tǒng)日志到指定目錄。如果jdk版本是32位,因?yàn)槲④涀隽讼到y(tǒng)重定向,不能拷貝過(guò)去。
          將%WinDir%\System32\Winevt\Logs\Application.evtx修改為%WinDir%\Sysnative\Winevt\Logs\Application.evtx,即可實(shí)現(xiàn)。
          參考資料:http://support.microsoft.com/kb/942589/

          posted @ 2010-07-26 13:09 temper 閱讀(1023) | 評(píng)論 (0)編輯 收藏
          僅列出標(biāo)題  下一頁(yè)
          主站蜘蛛池模板: 万宁市| 罗源县| 邛崃市| 甘德县| 晋江市| 东乌珠穆沁旗| 武山县| 定兴县| 东山县| 孝义市| 宜州市| 定远县| 贵州省| 奇台县| 永城市| 固阳县| 西林县| 蒙城县| 普洱| 康平县| 崇义县| 怀化市| 荔波县| 和硕县| 金门县| 镇江市| 弋阳县| 丽江市| 水富县| 新田县| 乳山市| 望谟县| 西畴县| 麻城市| 睢宁县| 琼中| 监利县| 迁安市| 普定县| 安图县| 师宗县|