• <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>

            socketref,再見!高德

            https://github.com/adoggie

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              246 Posts :: 4 Stories :: 312 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(54)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            gevent作為一款優(yōu)秀的網(wǎng)絡(luò)通信框架,其出色的性能得到大家一致認(rèn)可,但在處理并行任務(wù)的時候也要注意很多問題,不然您的服務(wù)器將變得異常緩慢。
            http://blog.163.com/lxl_1995/blog/static/677173392012724103742746/
            這篇
            博文講的非常清楚,建議讀一下 

            gevent的特點如下: 
             1. 單線程執(zhí)行,所有協(xié)程都在同一進程中被模擬和調(diào)度分派
             2. 可以創(chuàng)建成千上萬的 協(xié)程,而不會受任何性能影響
            3. 由于spawn的協(xié)程不是os分配和管理,所以不會有額外的線程資源分配,cpu也不用在這些線程之間調(diào)度切換
            4. 單線程執(zhí)行,無需考慮資源互斥
            5. 協(xié)程之間切換是通過gevent的io阻塞完成,例如 gevent.sleep(0), queue.get/put,event,socket....
                每調(diào)用一次gevent 的api,gevent就能獲得一次schedule的機會(這很類似操作系統(tǒng)的用戶調(diào)用中斷,由用戶態(tài)切換到內(nèi)核態(tài))

             以上特點保證gevent的性能非常出色,但當(dāng)我們的server用到第三方軟件包的時候那要非常小心了,特別是這些包內(nèi)部涉及了io操作。
            如果第三方軟件包是純python的那很簡單,只需要gevent.monkey_patch(xxx)就okay; 但如果包是擴展clib,那要當(dāng)心了,monkey_patch
            并不能將其相關(guān)io操作打上補丁,為了使用這些第三方軟件包,要求這些軟件包必須支持 協(xié)程異步 接口(調(diào)用其同步io接口,將阻塞住gevent的執(zhí)行線程,那gevent就完蛋了)。
            gevent的patch對psycopg2無效,因為psycopg2的通信部分是c接口的函數(shù)庫,還好psycopg2內(nèi)部支持協(xié)程,需要使用 到 psycogreen 這個東東
            psycogreen.gevent.patch_psycopg() 支持協(xié)程
            之后的在gevent的線程中執(zhí)行sql并等待數(shù)據(jù)返回時,gevent立馬將執(zhí)行切換到另外的線程

            gvent項目中會用到各種諸多的第三方庫,必須要求這些庫的io接口不能是阻塞的,也就是能支持到gevent異步模式

            應(yīng)用邏輯代碼在被執(zhí)行時(無系統(tǒng)api呼叫),單線程比多線程執(zhí)行速度更快。循環(huán)執(zhí)行一段計算二次函數(shù)代碼,由于期間沒有系統(tǒng)api調(diào)用,os不能進行內(nèi)核tasklet切換,所以導(dǎo)致cpu的峰值可以攀升到90%,直到硬件、時鐘等中斷產(chǎn)生,強行切換到其他線程。 多核心cpu表現(xiàn)為單個核始終異常的忙碌,其他幾個比較空閑。 
            posted on 2013-09-24 23:47 放屁阿狗 閱讀(572) 評論(0)  編輯 收藏 引用 所屬分類: gevent
            久久亚洲欧美日本精品| 热久久国产欧美一区二区精品| 伊人久久大香线蕉亚洲五月天| 欧美伊人久久大香线蕉综合 | 国产精品永久久久久久久久久 | 亚洲欧美日韩精品久久亚洲区| 久久久这里只有精品加勒比| 久久久久99精品成人片直播| 久久精品国产第一区二区| 无码八A片人妻少妇久久| 国产精品久久久久久一区二区三区| 久久成人精品| 久久久无码精品亚洲日韩蜜臀浪潮 | 国内精品伊人久久久影院| 久久久久久无码Av成人影院| 久久亚洲国产成人精品无码区| 久久精品国产亚洲AV蜜臀色欲| 国产激情久久久久影院小草| 久久久久久久久久久免费精品| 欧美黑人又粗又大久久久| 欧美伊人久久大香线蕉综合69| 久久99国产精品尤物| 国产精品久久久久久久app| 久久国产三级无码一区二区| 99久久精品国产高清一区二区| 久久99久久99精品免视看动漫| 亚洲午夜精品久久久久久app| 国产福利电影一区二区三区久久久久成人精品综合| 久久久久青草线蕉综合超碰| 色综合久久天天综线观看| 日韩精品久久久肉伦网站 | 2021久久国自产拍精品| 久久热这里只有精品在线观看| 日韩亚洲国产综合久久久| 93精91精品国产综合久久香蕉 | 国产精品久久久天天影视| 漂亮人妻被黑人久久精品| 久久久久久久精品成人热色戒| 久久婷婷五月综合成人D啪| 久久精品国产久精国产一老狼| 久久天天躁夜夜躁狠狠躁2022|