• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            牽著老婆滿街逛

            嚴以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            Network Programming Using Libevent - (I)

            from:http://blog.gslin.info/2005/11/network-programming-using-libevent-i.html

            在課堂上學過 Unix Network Programming 後,我們知道在處理多 User 時會有幾種方法解決:
            1. 一個新的 Connection 進來,用 fork() 產生一個 Process 處理。
            2. 一個新的 Connection 進來,用 pthread_create() 產生一個 Thread 處理。
            3. 一個新的 Connection 進來,丟入 Event-based Array,由 Main Process 以 Nonblocking 的方式處理所有的 I/O。
            這三種方法當然也都有各自的缺點:
            1. fork() 的問題在於每一個 Connection 進來時的成本太高。
            2. 用 Multi-thread 的問題在於 Thread-safe 與 Deadlock 問題難以解決,另外有 Memory-leak 的問題要處理。
            3. 用 Event-based 的方式在於實做上不好寫,尤其是要注意到事件產生時必須 Nonblocking,於是會需要實做 Buffering 的問題,而 Multi-thread 所會遇到的 Memory-leak 問題在這邊會更嚴重。而在多 CPU 的系統上沒有辦法使用到所有的 CPU resource。
            當然,針對前面兩項有各自的解法:
            1. 以 Poll 的方式解決:當一個 Process 處理完一個 Connection 後,不直接死掉,而繼續回到 accept() 的狀態繼續處理,但這樣會遇到 Memory-leak 的問題,於是採用這種方式的人通常會再加上「處理過 N 個 Connection 後死掉,由 Parent Process 再 fork() 一隻新的」。最有名的例子是 Apache 1.3。
            2. Thread-safe 的問題可以透過自己撰寫,或是尋找其他 Thread-safe Library 直接使用。Memory-leak 的問題可以試著透過 Garbage Collection Library 分析出來。Apache 2.0 的 Thread MPM 就是使用這個模式。
            然而,目前高效率的 Server 都偏好採用 Event-based,一方面是沒有 Create Process/Thread 所造成的 Overhead,另外一方面是不需要透過 Shared Memory 或是 Mutex 在不同的 Process/Thread 之間交換資料。

            然而,Event-based 在實做上的幾個複雜的地方在於:
            1. select()poll() 的效率過慢,造成每次要判斷「有哪些 Event 發生」這件事情的成本很高,這在 BSD 支援 kqueue()、Linux 支援 epoll()、Solaris 支援 /dev/poll 後就解決了,但這兩組 Function 都不是 Standard,於是在不同的平臺上就必須再改一次。
            2. 因為 Nonblocking,所以在 write() 或是 send() 時滿了需要自己 Buffering。
            3. 因為 Nonblocking,所以不能使用 fgets() 或是其他類似的 function,於是需要自己刻一個 Nonblocking 的 fgets()。但是使用者所丟過來的資料又不能保證在一次 read()recv() 就有一行,於是要自己做 Buffering。
            實際上這三件事情在 libevent 都有 Library 處理掉了。

            另外值得注意的一點在於 libevent 使用的是 3-clause BSD license 而非 GPL,所以在不想公開程式碼 (像是商業用途) 的情況下會比其他的 Library 適合。

            posted on 2007-08-21 00:58 楊粼波 閱讀(1568) 評論(1)  編輯 收藏 引用

            評論

            # re: Network Programming Using Libevent - (I) 2008-10-23 16:23 浪跡天涯

            http://blog.gslin.info/2005/11/network-programming-using-libevent-i.html
            好像打不開了 博主還有后續文章嗎?謝謝!  回復  更多評論   

            99热都是精品久久久久久| 久久久99精品一区二区| 久久天天躁狠狠躁夜夜2020老熟妇 | 国产成人无码精品久久久久免费 | 久久电影网2021| 久久久亚洲AV波多野结衣| 国产精品成人久久久久三级午夜电影 | 99久久精品国产免看国产一区| 亚洲七七久久精品中文国产| 狠狠色婷婷综合天天久久丁香| 狠狠色综合网站久久久久久久高清| 久久久久久久亚洲精品| 久久久久夜夜夜精品国产| 亚洲综合伊人久久综合| 欧美精品九九99久久在观看| 久久精品国产精品亚洲下载| 亚洲国产精品一区二区久久| www久久久天天com| 久久久久久无码Av成人影院| 中文国产成人精品久久不卡| 久久久久久久精品妇女99| 久久久久久久综合狠狠综合| 免费一级欧美大片久久网| 久久精品无码免费不卡| 国产精品久久久久乳精品爆| 大蕉久久伊人中文字幕| 国产亚洲精午夜久久久久久| 办公室久久精品| 久久免费国产精品| 无码精品久久一区二区三区| 亚洲国产小视频精品久久久三级| 久久综合色区| 日本欧美国产精品第一页久久| 久久天天躁狠狠躁夜夜2020老熟妇 | 久久午夜夜伦鲁鲁片免费无码影视 | 久久久久亚洲AV无码专区首JN| 中文字幕无码久久久| 伊人久久精品无码av一区| 奇米影视7777久久精品| 国产精品久久久久久福利漫画 | 久久精品中文騷妇女内射|