写点什么

PayPal 从 Java 切换到 JavaScript

  • 2013-12-03
  • 本文字数:1573 字

    阅读完需:约 5 分钟

已经决定使用 JavaScript 开发 Web 应用程序,从浏览器一直到后端服务器,并放弃了使用 JSP/Java 编写的遗留代码。

PayPal 技术总监 Jeff Harrell 在两篇博文中(解放我的UI 第一部分:Dust JavaScript 模板、开源等 PayPal 的 Node.js )解释了他们做出这一决定的原因,并对 Web 应用程序开发从 Java/JSP 切换到完全的 JavaScript/Node.js 技术栈的过程中所产生的若干结论进行了说明。

据 Harrell 说,PayPal 的网站已经积累了大量的技术债务,他们想要一种“可以使他们摆脱债务而又能带来更大产品灵活性和创新的技术栈”。最初,在使用 Web 技术的前端工程师和使用 Java 编码的后端工程师之间存在着巨大的鸿沟。当用户体验设计人员想草绘一些页面时,为了使它们运行,他们不得不要求 Java 程序员做一些后端编码。这与他们的精益用户体验开发模型不相符:

当时,我们的 UI 应用程序基于 Java 和 JSP,使用了一个无弹性、紧耦合而又难以快速行动的专有解决方案。我们的团队发现它与精益用户体验开发模型不相符,而且无法快速行动,因此,他们用脚本语言构建原型,与用户一起测试,然后将代码移植到产品栈中。

他们想要一个“从底层服务器技术解耦并能使 UI 设计独立于应用程序语言的模板 [解决方案]”,而且它可以工作在多种环境中。他们决定选用 Dust.js ——一个由 LinkedIn 支持的模板框架——,再加上 Twitter 的 Bootstrap Bower ,后者是一个面向 Web 的包管理器。之后又加入了 LESS RequireJS Backbone.js Grunt Mocha 等其它部分。

PayPal 的部分页面已经经过重新设计,但他们仍然还有部分页面使用遗留技术栈:

……我们有 C++/XSL 和 Java/JSP 两个遗留技术栈,随着继续推进,我们不打算留下这些 UI。JavaScript 模板是理想之选。在 C++ 技术栈上,我们构建了一个使用 V8 引擎执行 Dust 本地渲染的库——其速度惊人的快!在 Java 端,我们使用 Spring ViewResolver 和 Rhino 集成 Dust 来渲染页面。

当时,他们还开始用 Node.js 进行新页面的原型设计,并认为它“非常巧妙”,进而决定在生产环境对其进行试用。为了达到这一目的,他们还构建了 Kraken.js ,这是一个位于以 Node.js 为基础的 Web 框架 Express 之上的 “约定层”。(PayPal 最近开源了 Kraken.js。)第一个使用 Node.js 完成的应用程序是账户概览页,据 Harrell 说,该页面是 PayPal 的一个最经常访问页面。但是,由于担心 Node.js 应用程序可能扩展性不好,他们决定创建一个等效的 Java 应用程序,一旦 Node.js 应用程序不能正常运行,就可以回退到 Java 应用程序。下面是关于两种应用程序开发所需工作量的几个结论:

Java/Spring

JavaScript/Node.js

设置时间

复制代码
2 个月

开发

大约 5 个月

大约 3 个月

工程师

5

2

代码行数

未说明

未说明,占 Java 应用程序的 66%

JavaScript 团队需要两个月的时间进行基础设施的初始设置,但他们创建具有相同功能的应用程序用人更少、耗时更短。他们在生产环境硬件上运行测试套件,得出的结论是 Node.js 应用程序的性能要优于 Java 应用程序:

Node.js 应用程序每秒服务的请求数是 Java 应用程序的两倍。更为有趣的是,在最初的性能结果的产生过程中,Node.js 应用程序使用了单核,而 Java 应用程序使用了五核。我们打算进一步增大这种差异。

而且:

对于同一页面,Node.js 应用程序的平均响应时间减少了 35%。这使得页面提供时间快了 200 毫秒——用户可以明显地感觉到这种变化。

结果,PayPal 开始在生产环境中使用了尚处于测试阶段的 Node.js 应用程序,并决定“今后所有面向客户的 Web 应用程序均基于 Node.js 构建,”,而现有的部分应用程序也将迁移到 Node.js。

据 Harrell 说,从浏览器到服务器都使用 JavaScript 的一个好处是,形成了一个“允许我们在技术栈的任何层次理解和响应用户需求”的团队,消除了前端开发与后端开发之间的鸿沟。

查看英文原文:**** PayPal Switches from Java to JavaScript

2013-12-03 07:0511566
用户头像

发布了 256 篇内容, 共 89.2 次阅读, 收获喜欢 12 次。

关注

评论

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

SqlServer主备构建探索

Lane

SqlServer

OpenHarmony加速行业应用落地,多款软件发行版正在通过兼容性测评

OpenHarmony开发者

OpenHarmony

灵感乍现!造了个与众不同的Dubbo注册中心扩展轮子

捉虫大师

Java dubbo 注册中心 4月月更

没日没夜做需求,就能交出满分答卷吗?

LigaAI

敏捷开发 需求

TOGAF 10新鲜出炉了!

涛哥 数字产品和业务架构

企业架构 TOGAF

常见问题(FAQ)

源字节1号

[Day27]-[二叉树] 遍历

方勇(gopher)

LeetCode 算法和数据结构

如果只有一周时间,怎么快速提升线上系统的稳定性?

Samson

运维 监控 技术管理 SRE 系统稳定性

FL STUDIO20.9中文版汉化包注册激活教程

茶色酒

FL STUDIO20.9

Windows Edge 浏览器的有关 URL 链接的复制粘贴

HoneyMoose

H2 数据库采用客户/服务器端连接数据的 JDBC 参数

HoneyMoose

Redis太难?阿里P8总结的Redis灵魂拷问70题解析,还不懂我就哭了

Java架构追梦

Java 后端开发 程序员面试 Redis 数据结构

课程四

ASCE

linux之mktemp命令

入门小站

在线Excel转公式工具

入门小站

工具

使用 GoRouter 进行 Flutter 导航:Go 与 Push

坚果

4月月更

yarn add electron安装失败

空城机

YARN Electron

Flutter 网络请求 Dio 拦截器详解

岛上码农

flutter ios 安卓开发 4月月更 跨平台应用

Amazon Aurora 读写能力扩展之 ShardingSphere-JDBC 篇

SphereEx

Apache 数据库 开源 ShardingSphere SphereEx

Docker下,pinpoint环境搭建

程序员欣宸

Java Docker 4月月更 Pinpoint

融云国产化适配排坑指南

融云 RongCloud

《写作的逻辑》读书笔记

坚果

4月月更

Spring Data Elasticsearch 使用示例

Java elasticsearch 4月月更

IDC最新报告:澳鹏AI全生命周期数据解决方案在市场上具独特优势

澳鹏Appen

人工智能 大数据 数据标注 训练数据 数据训练

在线文本代码对比

入门小站

工具

Tomcat:网络请求原理分析

IT巅峰技术

APICloud数据云3.0使用教程

YonBuilder低代码开发平台

后端开发 APP开发 APICloud 数据云

redis优化系列(六)高可用集群Redis Cluster的认识

乌龟哥哥

4月月更

H2 数据库如何以服务器方式启动

HoneyMoose

PayPal从Java切换到JavaScript_Java_Abel Avram_InfoQ精选文章