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

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

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

    csusky

    常用鏈接

    統(tǒng)計(jì)

    最新評(píng)論

    2008年10月27日 #

    異步IO的關(guān)閉事件

    JAVA SOCKET只定義了四種事件

    public static final int OP_READ = 1 << 0;
    public static final int OP_WRITE = 1 << 2;
    public static final int OP_CONNECT = 1 << 3;
    public static final int OP_ACCEPT = 1 << 4;

    是沒有關(guān)閉事件的,我們?cè)趺磁袛嘁粋€(gè)連接是否關(guān)閉呢?
    如果你的selector注冊(cè)了一個(gè)OP_READ事件,那么在連接關(guān)閉的時(shí)候?qū)?huì)產(chǎn)生一個(gè)OP_READ事件
    也就是說本來阻塞的selector此時(shí)將會(huì)被喚醒,但是如果試圖在此事件的通道中讀取數(shù)據(jù)將會(huì)返回-1
    如下:

    Set<SelectionKey> readyKeys = selector.selectedKeys();

    = readyKeys.iterator()

    SelectionKey key 
    = (SelectionKey)i.next();

    if (operation == SelectionKey.OP_READ &&
                             key.isReadable())
                    
    {
                        ReadableByteChannel incomingChannel 
    = (ReadableByteChannel)key.channel(); 
    //此時(shí)將會(huì)得到-1,表明該鏈接已關(guān)閉
    int n = incomingChannel.read(readBuffer);
    }
    此時(shí)我們需要取消該KEY 如下:
    if (n == -1)
                
    {
                    key.cancel();
                      //關(guān)閉輸入輸出 
                      sc.socket().shutdownOutput();
                      sc.socket().shutdownInput();
                       //關(guān)閉SOCKET
                       sc.socket().close();
                      //關(guān)閉通道
                       incomingChannel.close();
                }

    posted @ 2009-11-10 22:28 曉宇 閱讀(424) | 評(píng)論 (1)編輯 收藏

    ExecutorFilter

    1 . 用Executors構(gòu)造一個(gè)新的線程池
    ExecutorService executor = Executors.newCachedThreadPool();

    方法 newCachedThreadPool();
    創(chuàng)建一個(gè)可根據(jù)需要?jiǎng)?chuàng)建新線程的線程池,但是在以前構(gòu)造的線程可用時(shí)將重用它們,并在需要時(shí)使用提供的 ThreadFactory 創(chuàng)建新線程。
    2. 用構(gòu)造的線程池創(chuàng)建ExecutorFilter
    ExecutorFilter es= new ExecutorFilter(executor));

    在ExecutorFilter內(nèi)部:
    只需要將相應(yīng)的事件分發(fā)到到線程池的相應(yīng)線程即可,但是SessionCreated事件只能在主線程中,不能分發(fā)
    觸發(fā)方法
    1 .
    首先構(gòu)造一個(gè)IoFilterEvent,這個(gè)IoFilterEvent包含1、事件的類型,2、下一個(gè)過濾器
    然后觸發(fā)該時(shí)間的處理方法。
     if (eventTypes.contains(IoEventType.SESSION_OPENED)) {
                fireEvent(
    new IoFilterEvent(nextFilter, IoEventType.SESSION_OPENED,
                        session, 
    null));
            }

    2 .
    從線程池中取出一個(gè)線程執(zhí)行事件處理
    protected void fireEvent(IoFilterEvent event) {
            getExecutor().execute(event);
        }


    在構(gòu)造ExecutorFilter 時(shí)如果沒有傳入IoEventType則默認(rèn)只對(duì)如下幾種幾件感興趣
    EXCEPTION_CAUGHT
    MESSAGE_RECEIVED
    MESSAGE_SENT
    SESSION_CLOSED
    SESSION_IDLE
    SESSION_OPENED
    當(dāng)然還需要覆蓋相應(yīng)的事件處理方法 如上所示

    posted @ 2008-12-12 11:33 曉宇 閱讀(1557) | 評(píng)論 (0)編輯 收藏

    ORACLE的塊大小

    參數(shù)db_block_size;
    這個(gè)參數(shù)只能設(shè)置成底層操作系統(tǒng)物理塊大小的整數(shù)倍,最好是2的n次方倍。
    如WINDOWS下4KB,8KB,16KB
    且該參數(shù)需要在建庫的時(shí)候指定,一旦指定不能更改。
    雖然在ORACLE9I以上可以指定表空間的數(shù)據(jù)庫大小,允許同時(shí)使用包括非默認(rèn)大小在內(nèi)的數(shù)據(jù)庫塊大小。不過需要設(shè)置指定大小數(shù)據(jù)塊的buffer_cache.

    小的塊:
    小的塊降低塊競(jìng)爭(zhēng),因?yàn)槊總€(gè)塊中的行較少.
    小的塊對(duì)于小的行有益.
    小的塊對(duì)于隨意的訪問較好.如果一個(gè)塊不太可能在讀入內(nèi)存后被修改,那么塊的大小越小使用buffer cache越有效率。當(dāng)內(nèi)存資源很珍貴時(shí)尤為重要,因?yàn)閿?shù)據(jù)庫的buffer cache是被限制大小的。
    劣勢(shì):
    小塊的管理消費(fèi)相對(duì)大.
    因?yàn)樾械拇笮∧憧赡苤辉趬K中存儲(chǔ)很小數(shù)目的行,這可能導(dǎo)致額外的I/O。
    小塊可能導(dǎo)致更多的索引塊被讀取

    大的塊
    好處:
    更少的管理消費(fèi)和更多存儲(chǔ)數(shù)據(jù)的空間.
    大塊對(duì)于有順序的讀取較好.  譬如說全表掃描
    大塊對(duì)很大的行較好
    大塊改進(jìn)了索引讀取的性能.大的塊可以在一個(gè)塊中容納更多的索引條目,降低了大的索引級(jí)的數(shù)量.越少的index level意味著在遍歷索引分支的時(shí)候越少的I/O。
    劣勢(shì):
    大塊不適合在OLTP中用作索引塊,因?yàn)樗鼈冊(cè)黾恿嗽谒饕~塊上的塊競(jìng)爭(zhēng)。
    如果你是隨意的訪問小的行并有大的塊,buffer cache就被浪費(fèi)了。例如,8 KB的block size 和50 byte row size,你浪費(fèi)了7,950



     

    posted @ 2008-11-25 15:45 曉宇 閱讀(1768) | 評(píng)論 (0)編輯 收藏

    TIPS

    將進(jìn)酒  杯莫停  -------> 亭名:  悲默亭

    全球通史

    《詩經(jīng)·采薇》

    昔我往矣,楊柳依依 今我來思,雨雪霏霏

    posted @ 2008-11-10 16:31 曉宇 閱讀(185) | 評(píng)論 (0)編輯 收藏

    SPRING整合IBMMQ實(shí)現(xiàn)全局事物

         摘要: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance...  閱讀全文

    posted @ 2008-10-27 17:01 曉宇 閱讀(2412) | 評(píng)論 (0)編輯 收藏

    主站蜘蛛池模板: 亚洲精品国产成人99久久| 日本亚洲高清乱码中文在线观看| 免费一区二区三区| 亚洲国产美女精品久久久久| 永久免费看bbb| 中国一级毛片免费看视频| 亚洲精品在线播放| 亚洲精品A在线观看| 97在线视频免费| 另类小说亚洲色图| 久久亚洲精品无码AV红樱桃| 香蕉高清免费永久在线视频| 免费看一区二区三区四区| 国产日本亚洲一区二区三区| 亚洲午夜日韩高清一区| 免费国产作爱视频网站| 成人一区二区免费视频| 亚洲色成人四虎在线观看| 亚洲成A人片在线观看无码不卡| 四虎成人免费大片在线| 日本中文字幕免费高清视频| 国产成人精品久久亚洲高清不卡| 亚洲国产一区在线| 亚洲国产日韩在线观频| 毛片a级毛片免费观看品善网| 182tv免费视频在线观看| 免费观看四虎精品成人| 亚洲国产成人久久| 亚洲av无码专区国产乱码在线观看| 四虎免费大片aⅴ入口| 最近最好最新2019中文字幕免费| 成人免费网站久久久| 久久人午夜亚洲精品无码区| 亚洲精品视频在线免费| 国产亚洲一区二区手机在线观看| 日本一区二区三区日本免费| 国产成人免费在线| 色猫咪免费人成网站在线观看| 一级女人18片毛片免费视频| 在线观看国产一区亚洲bd| 亚洲情A成黄在线观看动漫软件|