Python语言在企业级应用上的十大谬误

英文原文:https://www.paypal-engineering.com/2014/12/10/10-myths-of-enterprise-python/html

翻译原文:http://www.oschina.net/translate/10-myths-of-enterprise-python?p=3#commentspython

 

语言多元化是PayPal编程文化中一个重要的组成部分。在C++和Java长期流行的同时,更多的团队选择了JvaScript和Scala。同时,Braintree的收购也引入了一个久经世故的Ruby社区。 git

Python做为一门特别的语言,在eBay和PayPal有很长的历史。并且其流行程度依然有增不减。 程序员

eBay的开发者支持Python这个应用于基层领域多年的语言。甚至在eBay管理层官方支持Python之前,技术人员就开始使用Python。我在几年前加入PayPal并选择Python来写内部应用,然而,我却发现了PayPal中将近15年之前的Python代码。 github

目前,Python 支撑着 超过50个项目, 包括: web

  • 功能和产品型, 例如 eBay NowRedLaser
  • 运营和基础设施, 从开放的 OpenStack 到专有设施
  • 中间层服务和应用, 例如 PayPal 用来设订价格以及检测用户可用功能的那个(服务/应用)
  • 监测代理和接口, 用于涉及到部署和安全的一些用例
  • 批处理任务, 例如数据导入,价格调整,及其它项目
  • 以及不可胜数的开发者工具

在接下来的文章里我将详细介绍那些使得 eBay 和 PayPal 的 Python 生态系统从2011年的不超过25个工程师到2014年超过260个工程师所使用的技术和举措。对于本文,我则会专一于10个不得不予以揭露的关于 eBay 和 PayPal 的企业环境的谬误。 django

 

谬误 #1: Python 是一门新语言

伴随着全部的初创公司正在使用它以及孩子们最近也在学习它的事实,这个谬误为什么仍然存在是能够理解的。实际上 Python 已经 超过23岁了, 它最初发布于1991年, 早于 HTTP 1.0协议 5年且早于 Java 4年. 目前比较有著名的很早就使用 Python 的例子是在1996年: Google 的第一个成功的网络爬虫. 编程

若是你对于长长的 Python 历史比较好奇,Python 的做者 Guido van Rossum 已经为你准备好整个故事了. 安全

 

谬误 #2: Python 没有被编译

不像 C++ 同样须要一个独立的编译器工具链,Python 实际上被编译成了字节码,和 Java 或者许多其余的编译型语言十分类似。更进一步的编译过程,若是有的话, 取决于运行时环境, 无论是 CPython,PyPy,Jython/JVM,IronPython/CLR,或是其它的进程式虚拟机(process virtual machine)。参考 谬误 #6 来了解更多。 性能优化

一条在 PayPal 以及其它地方的通用原则就是,(应用的)安全性不能依赖于代码的已编译状态。更为重要的是增强运行时环境的安全,由于实质上每种语言都有一个解码器,或者能被拦截并导出受保护的状态。参考下一条谬误来了解更多的 Python 安全性问题。

 

谬误 #3: Python 不安全

轻量级 Python 的亲和力可能使他看起来不怎么可怕,可是这里直觉很大程度上是受到了误导的. 安全的一个核心原则就是尽量让呈现的目标更小. 大系统是违背安全原则的,由于他们趋向于 使行为过渡集中化, 而且也 让开发者难于理解. Python 经过倡导简洁化来边缘化这些恶心的问题. 更有甚者, CPython经过让本身成为一个简单、稳定而且易于审核的虚拟机来使这些问题获得解决. 事实上,近期 Coverity Software 的一个分析结果显示 CPython 获得了他们的最高质量评级.

Python 还拥有一系列可扩展的开源、产业标准化的安全库序列. 在PayPal, 咱们把安全和授信看作是重中之重, 咱们发现 hashlib, PyCrypto, 以及OpenSSL, 经过 PyOpenSSL 和咱们本身的定制构建的结合,涵盖了 PayPal 多样化的安全和性能需求.

这些诸多的缘由,使得 Python 成为PayPal(和eBay)的应用程序安全团队在某些业务中最快的选择. 这里有把Python用在PayPal的安全第一环境中的几个以安全为基础应用程序:

  • 建立安全代理,以促进密钥的轮换以并巩固加密实现
  • 同业界领先的 HSM 技术集成
  • 为缺少兼容性的技术栈构建受TLS保护的封装代理
  • 为咱们内部的互相认证计划生成键和证书
  • 开发主动的漏洞扫描器

另外,还有无数存在安全隐患的用Python构建,面向操做的系统, 诸如防火墙和链接管理. 将来,咱们必定回去深刻的整合PayPal Python的安全事项.

 

谬误 #4: Python 是一门脚本语言

Python 确实能够用来编写脚本,而且因其简单的语法、跨平台而且无所不在于 Linux, Macs, 和其它Unix 机器而成为这个领域的领跑者之一.

事实上, Python 多是常规用途编程语言中最灵活的技术. 如下是一些实例:

  1. 电信基础设施 (Twilio)
  2. 支付系统 (PayPal, Balanced Payments)
  3. 神经科学和心理学 (许多, 许多, 例子)
  4. 数值分析和工程 (numpy, numba, 以及 更多其它)
  5. 动画(LucasArts, Disney, Dreamworks)
  6. 游戏后台 (Eve Online, Second Life, Battlefield, 以及 其它不少)
  7. Email 基础设施 (Mailman, Mailgun)
  8. 媒体存储和处理 (YouTube, Instagram, Dropbox)
  9. 操做和系统管理 (Rackspace, OpenStack)
  10. 天然语言处理(NLTK)
  11. 机器学习和计算机版本 (scikit-learn, Orange, SimpleCV)
  12. 安全性和渗透性测试 (不少不少 以及 eBay/PayPal
  13. 大数据 (Disco, Hadoop support)
  14. 如理 (Calendar Server, 它 驱动了 Apple iCal)
  15. 搜索系统 (ITA, Ultraseek, 还有 Google)
  16. Internet 基础设施 (DNS) (BIND 10)

更别提网站和web服务了,那些都不在少数. 事实上,PayPal工程师看起来像是有兴趣致力于基于Python的web特性,好比 YouTubeYelp. 若是对Python成功案例的更大清单感兴趣,那就看看官方的清单吧.

 

谬误 #5: Python 是弱类型的

Python 类型系统的特色是拥有强大、灵活的类型操做. 维基百科上对此做出的阐述.

而存在一个不争而有趣的事实是, Python 是比Java更增强类型的. Java 对于原生类型和对象区分了类型系统,它让null存在于一个灰色地带. 另外一方面,现代的 Python 拥有一个统一的强类型系统, 其中什么都没有(None) 的类型是明确指定的. 更进一步的,JVM自身也是动态类型的,由于能够把它的 根源追溯到由Sun所收购的Smalltalk VM的一个实现.

Python的类型系统 很棒,但要提供给企业级使用,目前仍然还有许多更重大的事项须要关注.

 

谬误 #6: Python 速度慢

首先是有一个重要区别: Python 是一门编程语言,而不是运行时环境. Python 拥有几个实现:

  1. CPython 是参考实现, 且也是普遍发布和使用的实现.
  2. Jython 是Python用于JVM的是一个成熟的实现.
  3. IronPython 是 Microsoft 针对其自家的通用语言运行时——又名 .NET,实现的Python .
  4. PyPy 是一个正在日趋成熟的Python实现,拥有JIT编译,增量垃圾收集诸多先进的特性.

每个运行时都有其本身的性能特色, 并且他们自己也不慢. 这里更重要的地方在于不能错误地把一个性能指标分派到一门编程语言智商. 应该老是把该评估用在一个应用程序运行时上面,最好是针对一个特定的使用场景.

清楚了那些事项以后,下面就是一些有Python提供的小项,体现其重要的性能优点:

  1. NumPy 用做 Intel 的 MKL SIMD接口
  2. PyPy的 JIT 编译能 达到比C还快的性能
  3. Disqus 能在一样的100个盒子上容纳两亿五千万到5亿用户

诚然,这些都不是最新的列子,只是我我的的最爱罢了. 这将很容易扯到高性能Python以及独立提供的运行时这些广阔的领域. 咱们不该只是专一于解决单个特殊的案例, 而是应该把注意力放在对开发人员在 最终产品性能 方面的生产力的广泛影响上面, 特别是在一种企业级环境之下.

17123037_7NAF

C++ vs Python,. 两种语言在同一个输出下的对比.

给定足够的时间,一个循规蹈矩的开发者只会按照下面这种通过论证的方式来编写精确高效的软件:

  1. 设计实现一个能够正确完成任务的软件,包括开发单独的测试
  2. 测试性能,明确瓶颈
  3. 优化,根据测试和Amdahl法则,而且利用Python与C的渊源

虽然这听起来很简单,可是即便是老道的工程师,这依旧是一个很是耗时的过程。Python设计之初就考虑到了这一套开发流程。根据咱们的经验,一般C++和Java项目完成一次迭代流程的时间,够Python项目完成三次迭代流程。今天,PayPal和eBay中不乏有Python项目使用更少的代码打败了同类C++和Java项目,这多亏了快速的开发使得仔细的裁剪和优化变得可能。

 

谬误 #7: Python没法作到大规模

大规模有许多定义,但不管怎样,YouTube是个大规模网站。每个月UV超过十亿,每分钟上传的视频时长超过100小时,占用互联网带宽的20%,全部这一切都以Python做为核心技术。Dropbox,Disqus, Eventbrite, Reddit, Twilio,Instagram, Yelp, EVE Online, Second Life,,以及,是的,以及eBay和PayPal中都有Python大规模的例子,这些证实大规模不只仅是可能:它是一种模式。

成功的关是键简单性且一致性。CPython,Python的主要虚拟机,其最大限度地放大了这些特性,从而演变出了一个精确可测的运行时。人们很难发现 Python程序员关心垃圾的收集暂停或应用地启动时间。拥有强大的平台和网络支持,Python其自己天然而然的智能水平可扩展,BitTorrent就是其充分的体现。

此外,规模化主要涵盖测量和迭代。Python是以分析和优化为要义创建的。看Myth #6了解更多Python如何垂直拓展的细节。

 

谬误 #8: Python缺乏好的并发支持

除了偶尔叫嚣性能规模化的问题,有人想提的技术些,“Python缺少并发,”或者,“GIL怎么样?“若是几十个反例仍不足以支持Python水平及垂直拓展规模的能力,那么再更深地解释CPython实现细节也不会有帮助,因此我会简短些。

Python拥有强大的并发原语,包括generators, greenlets, Deferreds, 和futures.。Python有优秀的并发框架,包括eventlet, gevent,和Twisted。Python在定制运行时尚投入了惊人的工做量,包括StacklessPyPy。全部烦人这些和更多代表,根本不存工程师们在Python并发编程方面的缺憾。同时,全部这些都正在被正式的在企业生产环境中支持或使用。例如,请参考Myth #7

全局解释器锁,或称GIL,是Python在大多数应用场景下的性能优化,也是几乎全部CPython实现代码的开发上的基础优化。GIL使得Python能够很便利地使用操做系统的线程或轻线程(一般指greenlets),且不影响使用多进程。更多相关信息,请看该主题的Q&A列表,以及Python文档中的介绍

在PayPal中,一个典型服务的部署须要多台机器,多个进程,多个线程,以及一个数字很是庞大的greenlets,至关于一个很是强大可扩展的并行环境(见下图)。在大多数的企业环境中,团队更倾向于往更高层次过分,谨慎并注重灾难恢复。然而,在某些状况下,每台机器天天Python服务仍然处理数以百万计的请求,并且轻松处理。

17123046_2xjV-1000x1007一个基于单一worker的协同异步架构草图。最外层的盒子是进程,下一个层次为线程,这里这些线程都是轻线程。操做系统处理线程间的抢占,而I/O异步协同合做。

 

谬误 #9: Python 程序员很稀缺

事实上,如今使用 Python 的 web 开发者的确没有使用 PHP 或者 Java 的 web 开发者多。这可能主要是因为企业需求和教育之间的相互做用致使的,不过 教育领域(教学所使用的编程语言)的趋势使得状况可能产生变化 。

也就是说,使用 Python 的开发者并不稀缺。如今全世界有数百万使用 Python 的开发者。已有几十个Python 技术大会、 StackOverflow 上成千上万的 Python 内容问答、雇佣大量使用 Python 的开发者的大企业好比 YouTube 、 美国银行( Bank of American )和 LucasArts/Dreamworks 等等,这些都显而易见地证明了这一点。在 eBay 和 PayPal 咱们一直保持拥有几百位使用 Python 的正式开发者,这是怎么作到的呢?

那么,当一个项目被建立时为何它会被首推?对于孩子来大学生教授们来讲,Python做为第一门程序设计语言是很是易于学习的。在eBay,仅仅须要一个星期,一个新的Python程序员就能展现一个真正的成果,而且他们开始散发光芒经常只要2-3个月,经过Internet的宝藏(互动式教程文档开源代码库)一切皆有可能。

另一个重要的考虑因素是,项目使用Python会更简单,它不会像其余项目那样须要那么多的开发者。在谬误6谬误9中提到的那样,在Python项目中,学习像Instagram那样的高效团队是一个常见的比喻,而且这确实是咱们在eBay和PayPal的经验。

 

谬误 #10: Python不适应于大项目

谬误 #7 讨论了大规模运行Python的项目,但开发Python大规模项目是什么状况呢?正如在谬误 #9中提到的,大多数Python不被人看好。 然而Instagram在其被亿元美金收购当天达到千万的点击量,而整个公司只有十几我的。Dropbox在2011年只有70个工程师,其余团队更少。因此,Python适合大规模团队吗?

美国银行实际上有超过5000的Python开发者,一个单独的项目超过一千万行Python代码。JP摩根也经历了相似的转变。YouTube也有数千的开发者和数百万行的代码。大规模产品和团队天天都在使用Python,由于它具备良好的模块化和封装特性,在特定方面许多的大规模开发建议是一致的。工具,强大的惯例以及代码审查促使了项目规模化管理的现实。

幸运的是,Python发展于上面所提到的好的奠定。咱们在检查执行使用pyflakes以及其余工具进行Python代码的静态分析,正如坚持PEP8——Python语言的基础风格指南。

最后,应该指出的是,除了调度加速Myth #6以及#7中所提到的,使用Python的项目一般须要更少的开发者。咱们常见的成功案例中,使用Java或C++的项目一般有3-5开发者耗时2-6个月,最终由单一的开发者在2-6(或小时,由于这些缘由)完成项目。

有点像奇迹,但倒是现代发展的事实,但其每每出自一个竞争激烈的行业。

 

一种干净的状态

这些谬误可能只是消遣。讨论这些谬误仍然很活跃的和受启发的,包括内部和外部, 由于隐含在每个谬误里的都是一个Python的优点的认识。 并且, 记住这些看似乏味的表现和麻烦的问题是稳步成长的表露, 并稳定地增加兴趣促进教育和持续地工做。 在这里,但愿能扑灭一场充满火焰的战争,而且使得能真正去谈论工做与Python的实现。

留心未来的帖子,我将深刻研究细节在这个概览。 那么你在那以前就必须了解细节,已经修正 或是注释起来, 个人电子邮件是mahmoud@paypal.com. 到那时,开心编码吧!

相关文章
相关标签/搜索