写点什么

JVM 上的 Python 现状

  • 2009-10-09
  • 本文字数:1690 字

    阅读完需:约 6 分钟

在过去的几年间有大量编程语言被“移植”到了 Java 虚拟机上,更有甚者单独为 JVM 创建了为数众多的语言。这包括 Ruby(JRuby)、JavaScript(Rhino)、Groovy 以及 Python(Jython)。特别是 Python 在 JVM 上得到了蓬勃的发展,这都得益于最近 Jython 的前进势头。

Jython 是 Python 编程语言的一种实现,运行在 JVM 上。它拥有超过 10 年的历史,然而大多数时间还是处于停滞不前的状态。最近,Jython 领域变得活跃起来,这也带动了 Python 在 JVM 上的发展。近日 InfoQ 有幸采访了 Jython 的项目领导 Frank Wierzbicki 以了解 Jython 的当前状况以及 JVM 上的 Python 现状。

过去一年多的时间里,Jython 开始变得繁荣起来,你是怎么看待这一点的?

我认为 Jython 2.5(该版本的 Jython 对 CPython 的兼容性是最好的)实在是功不可没。我们现在拥有的 Python 应用和框架的数量都是前所未有的。比如说 Django、Pylons 以及 Py2Web 等等,SQLAlchemy 0.6 很快也会与 Jython 协同工作了;除此以外,Twisted、TurboGears 以及 Grok 上的工作也都在有条不紊地进行当中。所有这些都能访问 Java 程序库,就好像访问本地 Python 一样。

Sun Microsystems 在 Jython 开发中扮演着什么角色?

Sun 允许我全职负责 Jython 开发。我也对 NetBeans 团队做出了不少贡献,使得 Python 和 Jython 成为 NetBeans IDE 上的一等公民,而且还使得 Jython、Django 以及 Pylons 能与 GlassFish 协同工作。当然了,这些团队也为 Jython 的开发做出了卓越的贡献。

Jython 2.5 最重要的变化是什么?

Jython 2.5 的关注点在于让 Jython 成为现代化、兼容于 CPython、卓越的 Python 实现。我们使劲浑身解数让尽可能多的纯 Python 框架和应用能够正常运行,但却没有把太多精力放在性能调优上,这是接下来要做的事情,换句话说,我们要使 Jython 的性能与 CPython 有一拼。

Jython 2.6 的路线图如何?

我们现在将大部分精力都放在了性能上,同时还在不断增加新的特性。比如,我们计划改进与 Java 程序库的集成,尤其是需要替换掉 Jython 2.2.x 中一个名为“jythonc”的工具,该工具使得我们可以方便地实现某些 Java 集成并将结果打包为 jar(一种 Java 分发格式)。由于内部设计的原因,jythonc 还无法支持某些新的 Python 特性。我们确信还会有越来越多的应用和框架将运行在 Jython 上。我们期待这一天的到来:一旦应用无法运行在 Jython 上,那将是应用本身的 bug 而绝非 Jython 的问题。

还会有 Jython3k 么?

当然了!3.0 是 Python 的未来,也是 Jython 的未来。坦白地说,我们还没有开始 Jython3k 的开发工作,但我希望一旦 2.6 发布后我们将会认真考虑这个问题。之所以等待 2.6 的发布是因为用于将 Python 2 移植到 Python 3 上的工具需要 2.6 作为起始点。

你认为会有人用 Jython 开发企业应用么?

我听说有人已经将包含 Pylons 或 Django 的 WAR 文件放到了产品中,还听说某些网上商店发现 Jython 与 JDBC 的集成在某些情况下要比 CPython 的数据访问更棒。Jython 2.5 是个现代化的 Python,在很多情况下都是非常不错的选择。 我不知道一般人是否了解 Jython 的历史——其首个版本发布于 1998 年 7 月。那时除了 Java,Jython 就是 JVM 上功能特性最全面的编程语言了。因此企业实际上已经使用 Jython 很长时间了。比如 IBM WebSphere 和 Oracle WebLogic 就使用 Jython 作为管理脚本语言。

你如何看待 JVM 上的 Python 现状?

对于 JVM 上的 Python 来说现在的一切都是非常美好的。由 John Rose 领导的 Da Vinci Machine 项目正致力于让 JVM 成为动态语言的最佳归宿。这项工作现在也已经融合到 JDK 7 中了,一旦我们可以利用这项工作的成果那 Jython 的执行效率就将得到极大的改进。目前我正在编写一个 Jython 原型以利用该工作的成果。

除了在 Jython 编程语言上所进行的诸多工作外,围绕着该语言还涌现了大量的资源,包括关于该语言的新书、关于使用Jython 管理WebSphere 的图书、一本在线图书、 PyCon 上的播客、访谈以及教程等等。要想学习Jython,请点击以上链接或是访问 Jython 主页,那里有关于 JVM 上 Python 的所有信息。

查看英文原文: State of Python on the JVM

2009-10-09 01:313550
用户头像

发布了 88 篇内容, 共 269.0 次阅读, 收获喜欢 8 次。

关注

评论

发布
暂无评论
发现更多内容

PD 启动主流程分析

TiDB 社区干货传送门

TiDB 底层架构

事务前沿研究丨确定性事务

TiDB 社区干货传送门

TiDB 底层架构

还在用变量去实现多维度分组排序吗?你 out 了!

TiDB 社区干货传送门

实践案例

TiDB 慢日志在伴鱼的实践

TiDB 社区干货传送门

实践案例

一篇文章带你玩转 TiDB 灾难恢复

TiDB 社区干货传送门

故障排查/诊断

TiDB Ansible 使用指南

TiDB 社区干货传送门

【精选实践】一体化无边界的大数据基础平台

TiDB 社区干货传送门

DM多库合并至TiDB

TiDB 社区干货传送门

迁移 实践案例

PD 调度器模块

TiDB 社区干货传送门

TiDB 底层架构

TiDB 的统计信息

TiDB 社区干货传送门

TiDB 热点问题详解

TiDB 社区干货传送门

038-拯救大兵瑞恩之 TiDB 如何在 TiKV 损坏的情况下恢复

TiDB 社区干货传送门

TiDB 数据一致性校验实现:Sync-diff-inspector 优化方案

TiDB 社区干货传送门

性能调优

Grafana汇总报表

TiDB 社区干货传送门

监控

TiDB 升级——ansible与tiup使用小结

TiDB 社区干货传送门

TiDB 底层架构

当数据库遇上 Kuberbetes丨「能量钛」圆桌论坛回顾

TiDB 社区干货传送门

实践案例 数据库架构选型

TiDB 集群可用性增强 —— TiDB 5.0 的 Joint Consensus 机制介绍

TiDB 社区干货传送门

TiDB 底层架构

TiDB 在汽车之家818台网互动项目中的应用

TiDB 社区干货传送门

实践案例 管理与运维 数据库架构选型

Flink on TiDB —— 便捷可靠的实时数据业务支撑

TiDB 社区干货传送门

实践案例

TiDB 热点问题定位

TiDB 社区干货传送门

故障排查/诊断

TiSpark 服务安装、部署及测试

TiDB 社区干货传送门

TiDB new feature max_execution_time

TiDB 社区干货传送门

知乎已读服务的前世今生与未来

TiDB 社区干货传送门

DM filter 实践整理

TiDB 社区干货传送门

实践案例

一张脑图让你快速了解 TiDB 5.0版本新特性

TiDB 社区干货传送门

TiDB 底层架构

接触TiDB4.0时,一些部署方式实践尝试

TiDB 社区干货传送门

安装 & 部署

Region 创建、分裂及合并的原理

TiDB 社区干货传送门

TiDB 3.0:窗口函数初体验

TiDB 社区干货传送门

在 minikube 上使用 TiDB Operator 构建 TiDB 集群(持续更新中)

TiDB 社区干货传送门

安装 & 部署

TiDB Parser模块的简单解读与改造方法

TiDB 社区干货传送门

TiDB 底层架构

从 MySQL 大量数据清洗到 TiDB 说起

TiDB 社区干货传送门

实践案例

JVM上的Python现状_Java_Craig Wickesser_InfoQ精选文章