如何用Python一门语言通吃高性能并发,GPU计算和深度学习

第一个就是并发本身所带来的开销即新开处理线程、关闭处理线程、多个处理线程时间片轮转所带来的开销。实际上对于一些逻辑不那么复杂的场景来说这些开销甚至比真正的处理逻辑部分代码的开销更大。所以我们决定采用基于协程的并发方式,即服务进程只有一个(单cpu)所有的请求数据都由这个服务进程内部来维护,同...
如何用Python一门语言通吃高性能并发,GPU计算和深度学习
第一个就是并发本身所带来的开销即新开处理线程、关闭处理线程、多个处理线程时间片轮转所带来的开销。

实际上对于一些逻辑不那么复杂的场景来说这些开销甚至比真正的处理逻辑部分代码的开销更大。所以我们决定采用基于协程的并发方式,即服务进程只有一个(单cpu)所有的请求数据都由这个服务进程内部来维护,同时服务进程自行调度不同请求的处理顺序,这样避免了传统多线程并发方式新建、销毁以及系统调度处理线程的开销。基于这样的考虑我们选择了基于Tornado框架实现api服务的开发。Tornado的实现非常简洁明了,使用python的生成器作为协程,利用IOLoop实现了调度队列。

第二个问题是数据库的性能,这里说的数据库包括MongoDB和Redis,我这里分开讲。

先讲MongoDB的问题,MongoDB主要存储不同的用户对于验证的不同设置,比如该显示什么样的图片。
一开始每次验证请求都会查询MongoDB,当时我们的MongoDB是纯内存的,同时三台机器组成一个复制集,这样的组合大概能稳定承载八九千的qps,后来随着我们验证量越来越大,这个承载能力逐渐就成为了我们的瓶颈。
为了彻底搞定这个问题,我们提出了最极端的解决方案,干脆直接把数据库中的数据完全缓存到服务进程里定期批量更新,这样查询的开销将大大降低。但是因为我们用的是Python,由于GIL的存在,在8核服务器上会fork出来8个服务进程,进程之间不像线程那么方便,所以我们基于mmap自己写了一套伙伴算法构建了一个跨进程共享缓存。自从这套缓存上线之后,Mongodb的负载几乎变成了零。
说完了MongoDB再说Redis的问题,Redis代码简洁、数据结构丰富、性能强大,唯一的问题是作为一个单进程程序,终究性能是有上限的。
虽然今年Redis发布了官方的集群版本,但是经过我们的测试,认为这套分布式方案的故障恢复时间不够优秀并且运维成本较高。在Redis官方集群方案面世之前,开源世界有不少proxy方案,比如Twtter的TwemProxy和豌豆荚的Codis。这两种方案测试完之后给我们的感觉TwemProxy运维还是比较麻烦,Codis使用起来让人非常心旷神怡,无论是修改配置还是扩容都可以在配置页面上完成,并且性能也还算不错,但无奈当时Codis还有比较严重的BUG只能放弃之。
几乎尝试过各种方案之后,我们还是下决心自己实现一套分布式方案,目的是高度贴合我们的需求并且运维成本要低、扩容要方便、故障切换要快最重要的是数据冗余一定要做好。
基于上面的考虑,我们确定基于客户端的分布式方案,通过zookeeper来同步状态保证高可用。具体来说,我们修改Redis源码,使其向zookeeper注册,客户端由zookeeper上获取Redis服务器集群信息并根据统一的一致性哈希算法来计算数据应该存储在哪台Redis上,并在哈希环的下一台Redis上写入一份冗余数据,当读取原始数据失败时可以立即尝试读取冗余数据而不会造成服务中断。2017-07-31
python本来就不具备高并发性,想要性能好就用java和C++吧。没有看不起python的意思2020-08-04
mengvlog 阅读 33 次 更新于 2025-09-10 06:51:11 我来答关注问题0
  • 具体来说,我们修改Redis源码,使其向zookeeper注册,客户端由zookeeper上获取Redis服务器集群信息并根据统一的一致性哈希算法来计算数据应该存储在哪台Redis上,并在哈希环的下一台Redis上写入一份冗余数据,当读取原始数据失败时可以立即尝试读取冗余数据而不会造成服务中断。

  •  猪八戒网 python和java的区别及应用领域?

    当然,如果仅是对编程感兴趣,可以两者都学习一下,每一门语言都有自己的设计思想,没有好坏之分,只有是否适合,一个合格的程序员多学几门编程语言,了解不同的方法和思维去解决问题也是一件很好的事情。JAVA和Python有啥区别? 最本质区别就是一个是脚本可以解释执行,一个是需要编译通过才能执行。 相同点就是,它们都...

  •  湖北倍领科技 编写B/S程序使用哪种编程语言简单一些

    学习一些脚本语言是满足B/S程序开发需求的不错选择。JavaScript,一种前后端通吃的语言,可以作为B/S程序的前端与后端开发工具,简化了开发流程,提高了开发效率。Python则因其现成的库众多,非常适合用于爬虫和数据分析,是处理大量数据的理想工具。此外,shell脚本用于编写操作系统执行命令,适用于自动化系统...

  •  公园二校 http的共享怎么开

    1、打开IIS,打开“网站 --> 默认网站”,右键点击“属性”,点击“主目录”,勾选“目录浏览”选项,如下图所示:2、进入文件夹C:\Inetpub\wwwroot,拷贝文件“1.7z“到这个目录:3、打开浏览器,输入本机ip(比如我的:192.168.1.123),即可看到共享的文件并可以下载:点击“1.7z”即可下载。...

  •  猪八戒网 java与python的区别和作用(python和java的区别及应用领域)

    如果你只是编程爱好者,或者把编程语言作为一个工作中的应用工具,Python是个不错的选择。如果你想在程序员的道路上稳步发展,建议先学习Java,再学python,C++,JavaScript,PHP等其他语言,会事半功倍。一名优秀的程序员,绝不会只靠一门语言走到黑,通吃它们就完了!兼容并蓄,触类旁通,这才是一个...

檬味博客在线解答立即免费咨询

Python相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部