csusky

          常用鏈接

          統(tǒng)計(jì)

          最新評(píng)論

          2008年11月25日 #

          異步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 曉宇 閱讀(430) | 評(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 曉宇 閱讀(1566) | 評(píng)論 (0)編輯 收藏

          ORACLE的塊大小

          參數(shù)db_block_size;
          這個(gè)參數(shù)只能設(shè)置成底層操作系統(tǒng)物理塊大小的整數(shù)倍,最好是2的n次方倍。
          如WINDOWS下4KB,8KB,16KB
          且該參數(shù)需要在建庫(kù)的時(shí)候指定,一旦指定不能更改。
          雖然在ORACLE9I以上可以指定表空間的數(shù)據(jù)庫(kù)大小,允許同時(shí)使用包括非默認(rèn)大小在內(nèi)的數(shù)據(jù)庫(kù)塊大小。不過需要設(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ù)庫(kù)的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 曉宇 閱讀(1774) | 評(píng)論 (0)編輯 收藏

          主站蜘蛛池模板: 靖州| 饶河县| 保德县| 敖汉旗| 苏尼特左旗| 宽甸| 台安县| 江西省| 莱西市| 加查县| 白朗县| 青铜峡市| 昌黎县| 花莲市| 高台县| 柯坪县| 景洪市| 新丰县| 鄄城县| 专栏| 重庆市| 大余县| 孟村| 长葛市| 台南县| 四会市| 衢州市| 和静县| 吉林省| 洛南县| 齐齐哈尔市| 五莲县| 榆社县| 景德镇市| 和政县| 本溪| 探索| 城市| 股票| 邳州市| 泰顺县|