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

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

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

    chen4765654

    2014年9月15日 #

    Get請求參數(shù)中文亂碼解決

    因為在jsp中對中文進行了編碼的時候用的是UTF-8的編碼方式,而在servlet中調(diào)用request.getParameter();方法的時候使用服務(wù)器指定的編碼格式自動解碼一次,所以前臺編碼一次后臺解碼一次而解碼和編碼的方式不用所以造成了亂碼的出現(xiàn)。

    所以需要先編碼再解碼,代碼如下:
    fileName=java.net.URLDecoder.decode(java.net.URLEncoder.encode(fileName,"iso8859-1"),"utf-8");

    posted @ 2016-07-12 17:13 紫色心情 閱讀(1538) | 評論 (0)編輯 收藏

    JVM參數(shù)配置

    set JAVA_OPTS=-server -Xmn4096m -Xms8192m -Xmx8192m -Xss256k -XX:PermSize=128m -XX:MaxPermSize=256m  -XX:SurvivorRatio=8 -XX:+UseCompressedOops -XX:+UseConcMarkSweepGC -XX:+CMSParallelRemarkEnabled -XX:+UseParNewGC  -XX:TargetSurvivorRatio=90 -XX:MaxTenuringThreshold=30 -XX:+UseCMSInitiatingOccupancyOnly -XX:CMSInitiatingOccupancyFraction=70 -XX:+DisableExplicitGC  -XX:+UseCMSCompactAtFullCollection -XX:CMSFullGCsBeforeCompaction=2 -XX:GCTimeRatio=20 -XX:SoftRefLRUPolicyMSPerMB=0 -Xnoclassgc -XX:LargePageSizeInBytes=128m -XX:+UseFastAccessorMethods

    –XX:ParallelGCThreads=20:設(shè)置 20 個線程進行垃圾回收;
    –XX:+UseParNewGC:年輕代使用并行回收器;
    –XX:+UseConcMarkSweepGC:年老代使用 CMS 收集器降低停頓;
    –XX:+SurvivorRatio:設(shè)置 Eden 區(qū)和 Survivor 區(qū)的比例為 8:1。稍大的 Survivor 空間可以提高在年輕代回收生命周期較短的對象的可能性,如果 Survivor 不夠大,一些短命的對象可能直接進入年老代,這對系統(tǒng)來說是不利的。
    –XX:TargetSurvivorRatio=90:設(shè)置 Survivor 區(qū)的可使用率。這里設(shè)置為 90%,則允許 90%的 Survivor 空間被使用。默認(rèn)值是 50%。故該設(shè)置提高了 Survivor 區(qū)的使用率。當(dāng)存放的對象超過這個百分比,則對象會向年老代壓縮。因此,這個選項更有助于將對象留在年輕代。
    –XX:MaxTenuringThreshold:設(shè)置年輕對象晉升到年老代的年齡。默認(rèn)值是 15 次,即對象經(jīng)過 15 次 Minor GC 依然存活,則進入年老代。這里設(shè)置為 31,目的是讓對象盡可能地保存在年輕代區(qū)域。
    -XX:GCTimeRatio
    通過-XX:GCTimeRatio=<value>我們告訴JVM吞吐量要達到的目標(biāo)值。 更準(zhǔn)確地說,-XX:GCTimeRatio=N指定目標(biāo)應(yīng)用程序線程的執(zhí)行時間(與總的程序執(zhí)行時間)達到N/(N+1)的目標(biāo)比值。 例如,通過-XX:GCTimeRatio=9我們要求應(yīng)用程序線程在整個執(zhí)行時間中至少9/10是活動的(因此,GC線程占用其余1/10)。 基于運行時的測量,JVM將會嘗試修改堆和GC設(shè)置以期達到目標(biāo)吞吐量。 -XX:GCTimeRatio的默認(rèn)值是99,也就是說,應(yīng)用程序線程應(yīng)該運行至少99%的總執(zhí)行時間


    JDK7可以用使用G1垃圾回收器,最好堆棧大于4G情況下使用。
    -Xmx24g -Xms24g -XX:PermSize=96m -XX:MaxPermSize=96m -XX:+UseG1GC -XX:SurvivorRatio=6 -XX:MaxGCPauseMillis=400 -XX:G1ReservePercent=15  -XX:InitiatingHeapOccupancyPercent=40 -XX:ConcGCThreads=8
    使用G1時的最佳實踐
    1、不要設(shè)置年輕代的大?。?Xmn),否則會擾亂G1的缺省行為,JVM也不會滿足用戶指定的暫停時間。而且設(shè)置了固定值的話,G1將無法隨需擴展年輕代的大小
    2、GC暫停時間不是100%能保證的
    3、如果GC的晉升過程中遇到堆區(qū)域溢出(使用-XX:+PrintGCDetails看到to-space overflow),可以通過下面幾種方式避免:
    增加-XX:G1ReservePercent=n,缺省值是10。這可以增加可用的to-space內(nèi)存
    使用-XX:ConcGCThreads=n增加標(biāo)記線程數(shù)目

    G1常用參數(shù)

    參數(shù) 描述
    -XX:+UseG1GC 開啟G1
    -XX:MaxGCPauseMillis=n 設(shè)置GC暫停的最大時間,這只是目標(biāo),盡量達到,默認(rèn)值是 200 毫秒,過小影響吞吐量
    -XX:InitiatingHeapOccupancyPercent=n 整個堆(而不是某個年代)使用量達到此值,便會觸發(fā)并發(fā)GC周期.值為0則是連續(xù)觸發(fā),默認(rèn)值為45
    -XX:NewRatio=n 老年代與新生代的比值,默認(rèn)值為2
    -XX:SurvivorRatio=n 伊甸園代與生存代的比率,默認(rèn)值為8
    -XX:MaxTenuringThreshold=n 生存代存活的最大門限,默認(rèn)值為15
    -XX:ParallelGCThreads=n 設(shè)置垃圾回收器并行階段的線程數(shù),默認(rèn)值與JVM運行的平臺有關(guān),將 n 的值設(shè)置為邏輯處理器的數(shù)量
    -XX:ConcGCThreads=n 設(shè)置并發(fā)垃圾回收器使用的線程數(shù),默認(rèn)值與JVM運行的平臺有關(guān)
    -XX:G1ReservePercent=n 設(shè)置剩余的內(nèi)存量,減少躍遷失敗的可能,默認(rèn)值為10
    -XX:G1HeapRegionSize=n 設(shè)置G1平分java堆而產(chǎn)生區(qū)域的大小,默認(rèn)值可以提供最大的工效性.最小值為1M,最大為32M,最多劃分1024個,建議使用默認(rèn)值

    posted @ 2015-09-18 17:52 紫色心情 閱讀(1251) | 評論 (0)編輯 收藏

    Extjs的對齊方法alignTo介紹

    alignTo( String/HTMLElement/Ext.Element element, [String position], [Number[] offsets], [Boolean/Object animate] ) : Ext.Element
    通過指定的錨點將此元素與另一個元素對齊. 如果另一個元素時文檔document本身,則對齊到 viewport. 參數(shù) position 是可選的, 并可以指定為以下的格式:

    空白: 默認(rèn)將此元素的左上角(top-left)對齊到目標(biāo)元素的左下角(bottom-left),即("tl-bl").
    一個錨點anchor (此設(shè)置已被廢棄,deprecated): 傳遞的錨點位置被用做目標(biāo)元素的 錨點位置. 此元素將其左上角定位到另一個元素的指定的錨點. 此方法已被廢棄,最好使用下面的兩個錨點的格式.
    兩個錨點anchor: 如下面的表格所示,如果參數(shù)是用破折號(-)分隔的兩個值, 那么第一個值用作此元素的錨點, 而第二個值用作目標(biāo)元素的錨點(anchor point)
    除了錨點, 參數(shù) position 也支持 "?" 字符. 如果問號字符 "?" 出現(xiàn)在position 字符串的末尾, 則元素將試圖對齊指定的位置, 如果必要,則會被適當(dāng)調(diào)整以限制在viewport中. 注意: 為了執(zhí)行 viewport 的限制,被對齊的元素將可能被對齊到其他的位置. 下表是所有支持的錨點位置(anchor positions):

     值      說明
    -----  -----------------------------
    tl     左上角(top left corner) (默認(rèn)值)
    t      上邊界(top edge)的中心
    tr     右上角(top right)
    l      左邊界(left edge)的中心
    c      元素的中心(center)
    r      右邊界(right edge)的中心
    bl     左下角(bottom left)
    b      下邊界(bottom edge)的中心
    br     左下角(bottom right)
    用法示例:

    // 使用默認(rèn)的對齊位置("tl-bl", 不受限制) 將 el 對齊到 other-el 
    el.alignTo("other-el");

    // 對齊el元素的左上角到other-el元素的右上角 (受viewport限制)
    el.alignTo("other-el", "tr?");

    // 對齊el元素的右下角到other-el元素的左邊界中心
    el.alignTo("other-el", "br-l?");

    // 對齊el元素的中心點center到other-el元素的左下角,
    // 并調(diào)整 x 的位置偏移為 -6 pixels (y 位置偏移為 0)
    el.alignTo("other-el", "c-bl", [-6, 0]);

    posted @ 2015-03-18 11:51 紫色心情 閱讀(3602) | 評論 (0)編輯 收藏

    BTrace跟蹤DBCP泄漏腳本

    import static com.sun.btrace.BTraceUtils.println;
    import static com.sun.btrace.BTraceUtils.str;
    import static com.sun.btrace.BTraceUtils.strcat;
    import static com.sun.btrace.BTraceUtils.timeMillis;
    import java.sql.Connection;
    import java.util.HashMap;
    import java.util.Map;
    import com.sun.btrace.BTraceUtils;
    import com.sun.btrace.annotations.BTrace;
    import com.sun.btrace.annotations.Kind;
    import com.sun.btrace.annotations.Location;
    import com.sun.btrace.annotations.OnMethod;
    import com.sun.btrace.annotations.ProbeClassName;
    import com.sun.btrace.annotations.ProbeMethodName;
    import com.sun.btrace.annotations.Return;
    import com.sun.btrace.annotations.OnEvent;
    import com.sun.btrace.annotations.Self;
    import com.sun.btrace.annotations.TLS;
    import java.lang.Appendable;
    @BTrace public class DataSourceTrace {
     private static Map map = BTraceUtils.newHashMap();
     
     @OnMethod(clazz = "org.apache.commons.dbcp.BasicDataSource", method = "getConnection", location = @Location(Kind.RETURN))
     public static void traceExecute(@ProbeClassName String name,@ProbeMethodName String method, @Return Connection conn) {
      //BTraceUtils.println(strcat("獲取連接:",BTraceUtils.str(conn)));
      Appendable buffer=BTraceUtils.Strings.newStringBuilder();
      BTraceUtils.Strings.append(buffer,BTraceUtils.timestamp("yyyy-MM-dd HH:mm:ss"));
      BTraceUtils.Strings.append(buffer," - ");
      BTraceUtils.Strings.append(buffer,BTraceUtils.jstackStr());
      BTraceUtils.put(map, conn,str(buffer));
     }
     
     
     @OnMethod(clazz = "org.apache.commons.dbcp.PoolingDataSource$PoolGuardConnectionWrapper", method = "close")
     public static void traceExecute2(@ProbeClassName String name,@ProbeMethodName String method, @Self Connection conn) {
      //BTraceUtils.println(strcat("釋放連接:",BTraceUtils.str(conn)));
      BTraceUtils.remove(map, conn);
     }
     
     @OnEvent
     public static void exit(){  
      //這里打印泄漏連接的方法堆棧,運行一段時間后通過Ctrl+C,選擇2,發(fā)送事件打印
      BTraceUtils.printMap(map);
     }
     
     
    }

    posted @ 2014-12-16 16:20 紫色心情 閱讀(546) | 評論 (0)編輯 收藏

    ORACLE大數(shù)據(jù)量生成語句

    為了更好的測試我們的系統(tǒng)在一定數(shù)據(jù)量下的運行情況,時常需要準(zhǔn)備大量的測試數(shù)據(jù)。如果有靈活的方法可以使用,那就可以事半功倍了。
    以下介紹如何在ORACLE數(shù)據(jù)庫中進行大數(shù)據(jù)量的構(gòu)造方法,數(shù)據(jù)量大小均為500萬。
    '''基本主鍵列'''
    SELECT LEVEL AS ID
      FROM DUAL
    CONNECT BY LEVEL <= 5000000
    '''基本的單據(jù)列'''
    SELECT 'SO20121123' || LPAD(LEVEL, 5, 0) AS ORDER_NO
      FROM DUAL
    CONNECT BY LEVEL <= 5000000;
    '''基本的日期列'''
    SELECT TO_DATE(TRUNC(DBMS_RANDOM.VALUE(TO_NUMBER(TO_CHAR(SYSDATE, 'J')),
                                           TO_NUMBER(TO_CHAR(SYSDATE, 'J')))),
                   'J') + DBMS_RANDOM.VALUE(1, 360000) / 3600 AS ENTRYDATE
      FROM DUAL
    CONNECT BY LEVEL < 5000000;
    '''特定時間范圍內(nèi)'''
    SELECT TO_DATE(TRUNC(DBMS_RANDOM.VALUE(TO_NUMBER(TO_CHAR(SYSDATE - 10, 'J')),
                                           TO_NUMBER(TO_CHAR(SYSDATE, 'J')))),
                   'J') + DBMS_RANDOM.VALUE(1, 360000) / 3600 / 24 AS ENTRYDATE
      FROM DUAL
    CONNECT BY LEVEL < 5000000;
    '''隨機數(shù)據(jù)'''
    SELECT DBMS_RANDOM.VALUE FROM DUAL CONNECT BY LEVEL < 5000000;
    '''隨機數(shù)據(jù)范圍'''
    SELECT TRUNC(DBMS_RANDOM.VALUE(0, 100))
      FROM DUAL
    CONNECT BY LEVEL < 5000000;
    '''隨機字符串'''
    SELECT DBMS_RANDOM.STRING('A', 8) FROM DUAL CONNECT BY LEVEL < 5000000;
    '''復(fù)雜組合(訂單)'''
    SELECT 'P-' ||
           TO_CHAR((TO_DATE(TRUNC(DBMS_RANDOM.VALUE(TO_NUMBER(TO_CHAR(SYSDATE - 30,
                                                                      'J')),
                                                    TO_NUMBER(TO_CHAR(SYSDATE,
                                                                      'J')))),
                            'J') + DBMS_RANDOM.VALUE(1, 360000) / 3600 / 24),
                   'YYMMDD') || '-' ||
           LPAD(TRUNC(DBMS_RANDOM.VALUE(1, 100)), 5, '0') AS 訂單號,
           '一般采購' AS 訂單類型,
           'SO20121123' || LPAD(LEVEL, 4, 0) AS 外部訂單號,
           'admin' AS 變更人,
           TO_DATE(TRUNC(DBMS_RANDOM.VALUE(TO_NUMBER(TO_CHAR(SYSDATE, 'J')),
                                           TO_NUMBER(TO_CHAR(SYSDATE, 'J')))),
                   'J') + DBMS_RANDOM.VALUE(1, 360000) / 3600 AS 更新時間
      FROM DUAL
    CONNECT BY LEVEL < 5000000;
    '''加入隨機用戶或者字符'''
    SELECT 'P-' ||
           TO_CHAR((TO_DATE(TRUNC(DBMS_RANDOM.VALUE(TO_NUMBER(TO_CHAR(SYSDATE - 30,
                                                                      'J')),
                                                    TO_NUMBER(TO_CHAR(SYSDATE,
                                                                      'J')))),
                            'J') + DBMS_RANDOM.VALUE(1, 360000) / 3600 / 24),
                   'YYMMDD') || '-' ||
           LPAD(TRUNC(DBMS_RANDOM.VALUE(1, 100)), 5, '0') AS 訂單號,
           '一般采購' AS 訂單類型,
           CASE TRUNC(DBMS_RANDOM.VALUE(0, 2))
             WHEN 0 THEN
              ('SO20121123' || LPAD(LEVEL, 4, 0))
             ELSE
              ('')
           END AS 外部訂單號,
           CASE TRUNC(DBMS_RANDOM.VALUE(0, 3))
             WHEN 0 THEN
              'admin'
             WHEN 1 THEN
              'steven'
             ELSE
              'joseph'
           END AS 變更人,
           TO_DATE(TRUNC(DBMS_RANDOM.VALUE(TO_NUMBER(TO_CHAR(SYSDATE, 'J')),
                                           TO_NUMBER(TO_CHAR(SYSDATE, 'J')))),
                   'J') + DBMS_RANDOM.VALUE(1, 360000) / 3600 AS 更新時間
      FROM DUAL
    CONNECT BY LEVEL < 5000000;

    posted @ 2014-09-15 13:50 紫色心情 閱讀(1099) | 評論 (0)編輯 收藏

    主站蜘蛛池模板: 亚洲成a人片毛片在线| 亚洲第一中文字幕| 亚洲欧美国产欧美色欲| 九九精品免费视频| ass亚洲**毛茸茸pics| 成人免费午夜无码视频| 亚洲人成自拍网站在线观看| 免费无码肉片在线观看| 亚洲av中文无码乱人伦在线观看| 日韩精品视频免费在线观看| 国产精品无码亚洲精品2021 | 免费无码婬片aaa直播表情| 免费观看午夜在线欧差毛片| 日韩亚洲综合精品国产| 国产精品网站在线观看免费传媒 | 少妇太爽了在线观看免费视频| 亚洲av乱码一区二区三区按摩| 亚洲欧洲久久精品| 香蕉97碰碰视频免费| 成人奭片免费观看| 成人毛片免费观看视频| 日韩免费精品视频| 久久九九兔免费精品6| 蜜臀AV免费一区二区三区| 99ee6热久久免费精品6| 最近在线2018视频免费观看| 中文字幕免费高清视频| 97视频热人人精品免费| 在线免费观看视频你懂的| fc2成年免费共享视频18| 精品亚洲成a人在线观看| 免费人成视网站在线观看不卡| 久久精品夜色噜噜亚洲A∨| 国产亚洲欧洲精品| 国产成人亚洲综合一区| 在线观看亚洲精品专区| 在线看片免费人成视频播 | 区三区激情福利综合中文字幕在线一区亚洲视频1 | 白白色免费在线视频| 免费无码又爽又刺激一高潮| 99热在线精品免费全部my|