写点什么

利用 JS 在 AWS 上构建大规模弹性 Web 应用

  • 2015-08-07
  • 本文字数:1136 字

    阅读完需:约 4 分钟

JAWS 是一个高度可扩展的 Web 应用程序模板,由个人数据库提供商 Servant 开源。它使用 Amazon Web Services 提供的新工具( DynamoDB Lambda API Gateway AWS S3 )重新定义了如何使用 JS(后台 Node.js ,前端 jQuery )构建大规模弹性 Web 应用程序,其目标是:

  • 不使用服务器:永远不需要处理服务器扩展、部署、维护和监控方面的问题;
  • 组件隔离:JAWS 后台完全由 AWS Lambda 函数构成。每个函数可以单独开发、更新和配置;
  • 无限扩展:由 Lambda 函数构成的后台支持高并发,很容易实现跨区域冗余;
  • 成本尽可能低:Lambda 函数只有被调用时才会运行,而只有运行时才需要付费。

JAWS 主要包含如下四个部分:

  • API:JAWS 整个后台都是由 Lambda 函数构成,组织在api文件夹中。每个 API URL 指向一个 Lambda 函数。这样,每个 API Route 的代码都是完全隔离的,开发者可以针对特定的 API URL 开发、更新、配置、部署及维护代码。其作用相当于传统 MVC 结构中的“Controller”。
  • Liblib是一个 npm 模块,其中包含了可以在所有 Lambda 函数中重用的代码,可以认为是传统 MVC 结构中的“Model”。按照设计,Lambda 可以按需requrire它的代码,而不是全部代码,例如,只加载 User 模型需要的代码:var ModelUser=require('jaws-lib').models.User;
  • CLI:JAWS 提供了一个命令行接口,用于 Lambda 函数的测试和部署
  • Site:网站或客户端应用程序文件夹。为了缩短响应时间,静态资产可以上传到 AWS S3 上。

下一步,Servant 计划在 JAWS 中引入 AWS API Gateway Swagger 导入工具,为现有的 API 函数编写 swagger.json,向 CLI 添加 Swagger 导入命令。在同Hacker News 网友进行讨论的过程中,项目作者 ac360 指出:

下一步,开发者可以通过 Swagger 在 JSON 中定义 API,然后导入 AWS API Gateway,实现 API 的即时创建 / 更新。这应该会极大地缩短开发时间,简化 JAWS REST API 的构建。

这意味着,你仍然可以进行大规模的版本化发布,而且只需要简单地更新 Swagger 文件中的 JSON。这将使 JAWS 工作流有一个优美的结构,而且非常简单。

有许多网友都认为 JAWS 是一个不错的项目,ahallock 就是其中之一。不过,他希望 JAWS 提供 Lambda 与 RDS 的集成,因为他不想使用 DynamoDB。对此,ac360 回复说:

我一直计划增加 RDS 集成,尤其是 Aurora 支持。计划一直没变! 只是需要一些时间。

另外,ac360 指出:

我在 AWS Pop-Up Loft 上增加了一个 JAWS 优化章节……这个页面非常受欢迎。

感兴趣的读者可以安装试用并继续关注


感谢魏星对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群)。

2015-08-07 08:002518
用户头像

发布了 1008 篇内容, 共 398.1 次阅读, 收获喜欢 345 次。

关注

评论

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

架构师训练营 - 第四周 - 作业

Anrika

极客大学架构师训练营

Week 04- 作业一:一个典型的大型互联网应用系统使用了哪些技术方案和手段

dean

极客大学架构师训练营

一个典型的大型互联网应用系统使用了哪些技术方案和手段,主要解决什么问题?请列举描述。

娄江国

极客大学架构师训练营

架构学习第四周作业

云峰

第四周作业

数字

第4周总结

娄江国

极客大学架构师训练营

架构师训练营第四周作业

fenix

一个典型的大型互联网应用系统使用了哪些技术

L001

极客大学架构师训练营

从软件架构演进“看”做好事情的三条边

学习 架构模式 极客大学架构师训练营 架构演进 三条边

架构师训练营第四周-总结

王权富贵

极客大学架构师训练营

互联网系统架构

陈皮

写给大忙人看的进程和线程

苹果看辽宁体育

后端 操作系统

第四周感想

数字

大型互联网应用解决问题的技术方案和手段

GAC·DU

第四周作业

changtai

极客大学架构师训练营

大型互联网应用系统浅析

飞雪

大型互联网应用系统使用的方案

ashuai1106

架构师 极客大学架构师训练营

架构师训练营 第四周【作业】

小K

面向对象学习

一叶知秋

架构师训练营第 0 期第四周作业

无名氏

第四章作业

小胖子

互联网系统的问题与方案 - 第四周作业

X﹏X

week4.学习总结

个人练习生niki👍

第4周作业

大型互联网应用系统案例

戴维斯

极客大学架构师训练营

【架构师第四周作业】

浪浪

架构师训练营 - 学习笔记 - 第四周

小遵

学习总结 - 架构师训练营 - 第四周

走过路过飞过

第 04 周作业提交

白杨

架构师训练营 第四周 学习总结

RZC

【架构师第四周】总结

浪浪

利用JS在AWS上构建大规模弹性Web应用_JavaScript_谢丽_InfoQ精选文章