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

    文章

    221

    浏览量

    24763
  • python
    +关注

    关注

    58

    文章

    4883

    浏览量

    90294

原文标题:榨干python性能之服务优化

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    解析onsemi FDC6318P:高性能双P沟道MOSFET的卓越

    解析onsemi FDC6318P:高性能双P沟道MOSFET的卓越选 在电子设计领域,MOSFET是不可或缺的关键元件,其性能直接影响着电路的效率与稳定性。今天,我们就来深入剖析o
    的头像 发表于 04-21 15:15 29次阅读

    解析 onsemi FDC638P:高性能 P 沟道 MOSFET 的卓越

    解析 onsemi FDC638P:高性能 P 沟道 MOSFET 的卓越选 在电子设计领域,MOSFET 作为关键元件,其性能直接影响着电路的效率和稳定性。今天,我们来深入了解 o
    的头像 发表于 04-21 14:50 30次阅读

    使用PYTHON进行的跨平台仿真

    快速物理光学软件VirtualLab Fusion以其“连接场求解器”方法而自豪,该方法将应用于不同组件上的专用电磁场求解器结合在一起,以实现整个系统的物理光学模拟。这种方法的逻辑扩展不仅是连接软件
    发表于 04-02 08:21

    深度解析ADSP-2126x:高性能音频处理的理想

    深度解析ADSP-2126x:高性能音频处理的理想选 在当今的电子领域,音频处理技术不断发展,对处理器的性能和功能提出了更高的要求。ADI公司的ADSP-21261/ADSP-212
    的头像 发表于 03-23 16:20 160次阅读

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

    深度解析LTC7892:高性能双路升压控制器的卓越选 一、引言 在电子设备的电源管理领域,对于高性能、高效率的升压控制器的需求始终不断攀升。特别是在面对氮化镓(GaN)场效应晶体管(
    的头像 发表于 03-02 14:05 300次阅读

    1688 商品详情 API 调用与数据解析 Python 实战

    你想要的是 1688 商品详情 API 的 Python 调用与数据解析实战方案,核心是完成 API 凭证配置、接口请求(含签名)、响应数据解析、异常处理 的全流程落地,我会提供可直接运行的代码,并
    的头像 发表于 02-10 11:23 378次阅读

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

    深入解析TRF3761:高性能集成频率合成器的卓越选 在当今的电子设计领域,高性能频率合成器是众多无线通信和射频应用的核心组件。TI推出的TRF3761系列整数 - N PLL频率合
    的头像 发表于 02-10 09:40 443次阅读

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

    深入解析TRF3761:高性能集成频率合成器的卓越选 在无线通信技术飞速发展的今天,高性能的频率合成器对于各类无线设备的稳定运行至关重要。TI推出的TRF3761系列频率合成器,以其
    的头像 发表于 02-10 09:40 445次阅读

    Python运行本地Web服务并实现远程访问

    本文介绍使用Python搭建本地Web服务并结合 ZeroNews 实现公网访问。
    的头像 发表于 02-06 11:39 322次阅读
    <b class='flag-5'>Python</b>运行本地Web<b class='flag-5'>服务</b>并实现远程访问

    华纳云服务器Linux系统电源管理与节能优化配置方法

    在云计算时代,Linux系统的电源管理优化成为提升云服务器能效的关键环节。本文将深入解析Linux内核的电源管理机制,从CPU调频策略到磁盘休眠设置,提供一套完整的节能配置方案。通过调整系统参数
    的头像 发表于 08-21 15:09 1096次阅读

    从电机优化性能飞升!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