国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

python性能之服務優化的方法解析

馬哥Linux運維 ? 2017-12-31 01:04 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

初看這個標題,相信很多同學都笑了,python有性能可言么,呵呵噠...確實哦,python其實就是為了快速開發應用而出生的,雖然python的服務都以性能低而聞名全世界,但是總該有優化的地方吧,呵呵噠....

這不,這兩天本作者就碰見了這樣一個問題,首先自我介紹下,我是干嘛的,肯定是屌絲程序員了,這個猜都不用猜,要不然也不會蛋疼的寫這篇文章了,我們組是基礎開發組,就是專門開發一些剝離業務的組件讓其他部門去用,比如業務監控,業務報警,服務數據采集等等一堆搬磚的活.好了,廢話不多說了,估計看到這的也都看煩了...你們真的煩了么

這樣滴,我們這有個收集業務數據的組件簡稱M好啦,首先他要在業務服務器上建個udpserver,然后就靜靜的等業務的客戶端上報數據過來,數據格式是key-value形式的,然而就在最近幾天,有人在給業務機器做壓測的時候,發現一個問題,隨著并發的增加,這個M組件的cpu使用率也在不斷上升,擦,這下服務器不愿意了,開始瘋狂報警,然后做壓測的那個人就找我這來了,巴拉巴拉一堆,意思就是我給業務做壓測,你收集數據的組件飚個毛啊......

然而我是那么容易被打倒的么,就解釋說當然啊,你在給業務壓測的時候,同時你的client也在請求我啊,相當于我的并發量也在上升啊,不飚才怪呢,好吧,說歸說,抱著工匠精神,開始找問題吧...

這個M組件是用python寫的多線程的udpserver,經本人測試,當并發達到2000的時候,cpu就100%左右了,其實udp相比tcp而言性能已經很高了,不過這個并發還是有點感人啊,改成多進程也試了下,cpu占用還是70%左右,畢竟多進程適用計算密集型的,于是就想到了協程,協程像是一種在程序級別來模擬系統級別 的進程,由于是單進程,并且少了上下文切換,于是相對來說系統消耗很少,而網上的各種測試也表明,協程確實擁有驚人的速度。并且在實現過程中,協程可以 用以前同步思路的寫法,而運行起來確是異步的,挺有意思。

聽說python有個模塊叫做eventlet很強大,eventlet的核心是協程(也叫做green thread)。協程的好處是沒有線程開銷來的大(比如切換代價很小)。同時協程由于調度都由開發者自己決定,所以對lock的需求就很低了

010F5O38-0.png

上面是一個uds(unix domian socket)的例子,這里也是通過一個pool限制資源的使用。當每個請求來的時候通過spawn_n方法把對這個請求的handle方法放到獨立的協程中去處理。而handle中的recv這些方法都是被綠化過的,所以如果讀取不到數據這些方法就會把cpu時間交出來給別的協程使用,eventlet還有一個衍生品gevent,先看看例子:

010F55c7-1.png

上面是官方的例子,gevent是一個基于libev的python并發框架,以微線程greenlet為核心,使用了epoll事件監聽機制以及諸多其他優化而變得高效.而且其中有個monkey類, 將現有基于Python線程直接轉化為greenlet(類似于打patch)。

我自己測試了下,無論是eventlet寫的uds還是gevent寫的udpserver 并發達到2000時,cpu大概占用到30%左右,性能比之前降了2/3,效果還是很顯著的,不過這個還是沒有達到理想效果,后期準備嘗試下日志的方式,應該會比現在更省資源,就怕磁盤受不了,更何況我們用的還是所謂的云主機~

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 優化
    +關注

    關注

    0

    文章

    220

    瀏覽量

    24711
  • python
    +關注

    關注

    57

    文章

    4876

    瀏覽量

    90025

原文標題:榨干python性能之服務優化

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    深度解析LTC7892:高性能雙路升壓控制器的卓越

    深度解析LTC7892:高性能雙路升壓控制器的卓越選 一、引言 在電子設備的電源管理領域,對于高性能、高效率的升壓控制器的需求始終不斷攀升。特別是在面對氮化鎵(GaN)場效應晶體管(
    的頭像 發表于 03-02 14:05 ?67次閱讀

    1688 商品詳情 API 調用與數據解析 Python 實戰

    你想要的是 1688 商品詳情 API 的 Python 調用與數據解析實戰方案,核心是完成 API 憑證配置、接口請求(含簽名)、響應數據解析、異常處理 的全流程落地,我會提供可直接運行的代碼,并
    的頭像 發表于 02-10 11:23 ?252次閱讀

    深入解析TRF3761:高性能集成頻率合成器的卓越

    深入解析TRF3761:高性能集成頻率合成器的卓越選 在當今的電子設計領域,高性能頻率合成器是眾多無線通信和射頻應用的核心組件。TI推出的TRF3761系列整數 - N PLL頻率合
    的頭像 發表于 02-10 09:40 ?335次閱讀

    深入解析TRF3761:高性能集成頻率合成器的卓越

    深入解析TRF3761:高性能集成頻率合成器的卓越選 在無線通信技術飛速發展的今天,高性能的頻率合成器對于各類無線設備的穩定運行至關重要。TI推出的TRF3761系列頻率合成器,以其
    的頭像 發表于 02-10 09:40 ?352次閱讀

    Python運行本地Web服務并實現遠程訪問

    本文介紹使用Python搭建本地Web服務并結合 ZeroNews 實現公網訪問。
    的頭像 發表于 02-06 11:39 ?149次閱讀
    <b class='flag-5'>Python</b>運行本地Web<b class='flag-5'>服務</b>并實現遠程訪問

    深入解析ISO1042:高性能隔離CAN收發器的卓越

    深入解析ISO1042:高性能隔離CAN收發器的卓越選 在工業自動化、汽車電子等領域,可靠的通信至關重要。CAN(Controller Area Network)總線作為一種廣泛應用的串行通信協議
    的頭像 發表于 01-22 11:10 ?253次閱讀

    LDO性能優化的應用技巧

    本文圍繞LDO性能優化的關鍵環節展開,系統闡述了從啟動過程控制、不同負載條件下穩定工作到瞬態響應提升的全鏈路應用技巧。內容涵蓋啟動過沖抑制、電子負載在CC/CR模式下的適應性優化、啟動震蕩改善、負載
    的頭像 發表于 01-22 10:24 ?4576次閱讀
    LDO<b class='flag-5'>性能</b><b class='flag-5'>優化</b>的應用技巧

    華納云香港服務器數據庫索引優化策略

    在香港服務器環境中,數據庫索引優化是提升整體性能的關鍵因素。隨著企業數據量的不斷增長,高效的索引管理能顯著提高查詢速度并降低服務器負載。本文將深入探討如何針對香港
    的頭像 發表于 10-16 17:06 ?518次閱讀

    華納云服務器Linux系統電源管理與節能優化配置方法

    在云計算時代,Linux系統的電源管理優化成為提升云服務器能效的關鍵環節。本文將深入解析Linux內核的電源管理機制,從CPU調頻策略到磁盤休眠設置,提供一套完整的節能配置方案。通過調整系統參數
    的頭像 發表于 08-21 15:09 ?916次閱讀

    從電機優化性能飛升!ANSYS Maxwell 低頻電磁場仿真全解析

    動機進行優化設計,以提高其效率和性能。傳統的設計方法往往需要進行大量的物理樣機試驗,成本高且周期長,而使用 ANSYS Maxwell 進行仿真分析可以在設計階段快速評估不同設計參數對電機性能
    發表于 07-24 16:52

    鴻蒙5開發寶藏案例分享---長列表性能優化解析

    鴻蒙長列表性能優化大揭秘!告別卡頓,實戰代碼解析來了! 大家好呀~今天在翻鴻蒙開發者文檔時,發現了個 性能優化寶藏案例 !官方居然悄悄放出了
    發表于 06-12 17:40

    鴻蒙5開發寶藏案例分享---Web加載時延優化解析

    鴻蒙開發寶藏:Web加載完成時延優化實戰 大家好呀!今天在翻鴻蒙開發者文檔時,發現了一個隱藏的 性能優化寶藏區 ——官方竟然悄悄提供了超多實戰案例!尤其是****Web加載完成時延分析這塊,簡直是
    發表于 06-12 17:11

    鴻蒙5開發寶藏案例分享---性能優化案例解析

    鴻蒙性能優化寶藏指南:實戰工具與代碼案例解析 大家好呀!今天在翻鴻蒙開發者文檔時,意外挖到一個 性能優化寶藏庫 ——原來官方早就提供了超多實
    發表于 06-12 16:36

    HarmonyOS優化應用內存占用問題性能優化

    應用開發過程中注重內存管理,積極采取措施來減少內存占用,以優化應用程序的性能和用戶體驗。 HarmonyOS提供了一些內存管理的工具和接口,幫助開發者有效地管理內存資源: onMemoryLevel接口
    發表于 05-21 11:27

    性能飆升!使用Python并行計算榨干樹莓派算力!

    甚至微型服務器時,你是否也遇到過程序卡頓、視頻處理延遲的尷尬?今天我們就手把手教你用Python并行處理技術,讓樹莓派的性能瞬間翻倍!歡迎在評論區曬出你的優化方案,
    的頭像 發表于 03-26 17:08 ?931次閱讀
    讓<b class='flag-5'>性能</b>飆升!使用<b class='flag-5'>Python</b>并行計算榨干樹莓派算力!