写点什么

通过 Jets 框架在 AWS Lambda 上实现无服务化 Ruby

  • 2019-06-05
  • 本文字数:3764 字

    阅读完需:约 12 分钟

通过Jets框架在AWS Lambda上实现无服务化Ruby

本文将构建一个 SMS 应用。为了让其更加有趣,本文将加入一些幽默元素。当用户在应用中打字时,它将会回复您一个由icanhazdadjoke API 免费提供的笑话。该应用会展示如何上手 Jets,以及创建控制器、动作和线路。我们将构建一个单端点,当某个号码接收到 SMS 信息时,这个端点会对来自 Twilio 的 HTTP 请求做出反应。端点每次都会返回TwiML,以及一个随机的、令人爆笑的笑话。



当 AWS 在 2014 年发布Lambda时,没有支持 Ruby,而 Python、Node.js 和 Java 等平台开始了针对云托管和云运行功能的无服务化革命。在 2018 年底,对 Ruby 的支持终于发布。


开发者可以使用原始功能和无服务应用模型(SAM)模板,通过 Ruby on Lambda 构建任何东西,正如《Ruby on Lambda的开始指南》中描述的那样。但是,Ruby 的主要目的在于让开发者更快乐,而不是更痛苦。因为,当配置文件比程序还长时,整个流程可以说会让人非常痛苦。Jets 框架是一个利用 Ruby 来让无服务化更加快乐的框架。


从 Rails 过渡到 Jets

Jets 将构建Rails 应用体验和部署 AWS Lambda,并和相关服务能力加以结合。相关服务包括:API Gateway, S3 和 DynamoDB。在本帖中,我们将看看如何使用 Jets 并部署一个基于 Lambda、用 Ruby 编写的的 Twilio 应用。

我们构建的是什么

为了简便,我们将要构建一个 SMS 应用。而且,为了让其更加有趣,我们还将加入一些幽默元素。当你在该应用中打字时,它将会回复一个笑话,由icanhazdadjoke API 免费提供。


这个应用会向我们展示如何上手 Jets,以及如何创建控制器、动作和线路。我们将构建一个单端点,当某个号码接收到 SMS 信息时,这个端点会对来自 Twilio 的 HTTP 请求做出反应。每次,这个端点会返回TwiML,以及一个随机的、令人爆笑的笑话。

需要什么

为了完成这个项目,开发者需要准备:


开始

首先,全局安装 jets gem。在命令行中键入:


gem install jets
复制代码


然后,Jets 可执行文件就可以被当做生成器使用,如同 Rails,用来发起一个新项目,并运行该项目中的命令。我们现在会创建一个新项目,但是鉴于本帖子的范围有限,我们会对该项目适当进行限制。首先,我们将在 API 模式下创建项目,因为在这个应用中,我们不需要 HTML 视图。而且,我们也无需通过webpacker来进行资产编译,所以,这会节省我们的构建时间。我们也不需要数据库。运行以下命令,创建一个新的项目:


jets new dad-jokes-sms --mode api --no-database
复制代码


在生成器完成运行后,切换到 dad-jokes-sms 目录下,运行以下命令,以本地运行你的应用:


jets serve
复制代码


打开http://localhost:8888,你会看到以下的页面:



如果看到了这个页面,说明新 Jets 项目运行成功。

第一个 Jets 控制器

现在已经有了 Jets 应用,因此可以使用 gem 来生成应用部件,从模型和控制器到完整架构。对于应用来说,需要只有一个动作的控制器。怎么生成它呢?运行以下命令:


jets generate controller Messages create
复制代码


生成器将创建和编辑一些文件。开发者需要检查新的路径,因此请打开 config/routes.rb。


Jets 生成了一个 GET 线路,但是 Twilio webhook 会默认生成 POST 请求,而我宁可让它保持现在这样。设置应用,使之在/messages 端点上接收 POST 请求 webhook,像这样:


Jets.application.routes.draw do post 'messages', to: 'messages#create' root "jets/public#show"
复制代码


jets/public#show 控制器可以提供来自公共文件夹的静态 utf8 内容。注意,作为部署流程的一部分,Jets 会将公共文件夹下的文件上传到 s3 中,并且从 s3 中直接提供这些文件。S3 非常适合提供静态资产。此处有更多信息: http://rubyonjets.com/docs/assets-serving/


 any "*catchall", to: "jets/public#show"end
复制代码


现在,让我们编写控制器的动作。打开 app/controllers/messages_controller.rb,你会看到“创建”动作的方法。这一动作会接收 Twilio webhook,并用 TwiML 进行回复,且返回一个笑话。

获取笑话

为了返回笑话,我们需要对icanhazdadjoke API进行调用。让我们快速写一个能够实现这一目标的私有方法。


我们将使用 open-uri,因为它在发送简单的 web 请求方面(包括下载文具和图片)十分有用。Jets 生成了一个 GET 路径,但是 Twilio webhook 会默认生成 POST 请求,而我宁可让它保持这样。在 MessagesController 中加入以下内容:


require 'open-uri'class MessagesController < ApplicationController def create end private def random_joke open('https://icanhazdadjoke.com/', { 'Accept' => 'text/plain' }).read endend
复制代码


现在,可以将笑话以 TwiML 的形式返回给 Twilio。

返回 TwiML

我们将构建一个回复,方法是使用来自 twilio-ruby 助手库中的助手程序。打开 Gemfile,添加 twilio-ruby:


source "https://rubygems.org"gem "jets"gem "twilio-ruby"
复制代码


在命令行中运行 bundle install,以安装 gem。在 create 动作中,实例化一个新的 TwiML 回复对象,使用TwiML element来回复进来的消息,并提供 XML 回复,方法如下:


require 'open-uri'class MessagesController < ApplicationController def create twiml = Twilio::TwiML::MessagingResponse.new twiml.message body: random_joke render xml: twiml.to_xml end private def random_joke open('https://icanhazdadjoke.com/', { 'Accept' => 'text/plain' }).read endend
复制代码


要知道更多关于如何使用twilio-ruby助手库来生成TwiML的信息,请阅读文档。


我们可以在本地运行以测试是否可得到预期回复。如果应用停止,请运行 jets serve 重启。使用 curl 向 localhost:8888/messages 发送 POST 请求,你便会在 TwiML 回复中看到由icanhazdadjoke提供的笑话。


curl --data "" http://localhost:8888/messages<?xml version="1.0" encoding="UTF-8"?><Response><Message>What’s the advantage of living in Switzerland? Well, the flag is a big plus.</Message></Response>
复制代码


非常好,Jets 开始工作了!现在我们要把它部署到 AWS Lambda 中。


要将 Jets 应用部署到 AWS,首先需要设置好项目和证书,以便让它可以访问 AWS 服务。一个比较好的做法是创建拥有其工作所需最少权限的用户,Jets文档描述了用户需要的最少权限。在 AWS 账户中创建一个策略,该策略包含所有这些权限。此外,还要创建一个新用户,该策略将被分配给这个用户。然后,就可以使用该用户的证书来部署应用。


AWS 控制面板中,找到 IAM 服务,或者直接跳到 IAM部分



跳转到 Policies 部分,并创建一个新的策略。



选择 JSON 选项卡,输入来自Jets文档的以下 JSON:


{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "apigateway:*", "cloudformation:*", "dynamodb:*", "events:*", "iam:*", "lambda:*", "logs:*", "route53:*", "s3:*" ], "Resource": [ "*" ] } ]}
复制代码


继续点击,检查该策略,并命名。



保存策略。现在,需要创建一个新用户,并且将策略添加给该用户,并给予该用户创建 Jets 需要部署的资源的权限。打开 IAM 控制面板中的 Users 部分,创建一个新用户。



给该用户命个名,再在 Access Type 中选择 Programmatic Access。



点击 Next,并选择给予该新用户的权限。选择 Attach existing policies directly,并筛选刚刚创建的策略。选择该策略,并点击 Next。



点击 Next,直到成功页面出现为止。



保存最终页面上显示的 Access key ID 和 Secret access key。在部署的时候,我们要用到它们。现在,我们已经做好部署准备。

在 Lambda 上进行部署

在命令行中输入:


AWS_ACCESS_KEY_ID=YOUR_USER_KEY AWS_SECRET_ACCESS_KEY=YOUR_USER_SECRET_KEY jets deploy
复制代码


Jets 将把证书作为环境变量来设置 AWS 账户中的所有资源,以方便应用运行。这会花费一些时间,但是完成后,你会得到一个 URL,而且应用会在上面运行。



你会注意到应用被部署到一个“开发”环境中。要知道更多关于Jets如何处理环境的信息,请阅读文档。


现在可以用 curl 来测试这个 URL。记住,我们使用了/messages 这条线路,所以务必在 API 网关端点末端加上它,并且发出一个 POST 请求。


$ curl --data "" https://YOUR_API_GATEWAY_ENDPOINT/messages<?xml version="1.0" encoding="UTF-8"?><Response><Message>I knew a guy who collected candy canes, they were all in mint condition</Message></Response>
复制代码


现在,我们便可以随时收到笑话了,让我们把它与 Twilio 号码连接起来。

通过 SMS 发送笑话

访问Twilio 控制面板,转到有效电话号码。如果你已经有一个号码,请编辑它,否则,请购买一个可以接收 SMS 信息的新号码。在 A message comes in 字段中,输入你的应用 URL。



保存号码,并向其发送一条信息,应该会在回复中得到一个笑话。

无服务化有趣的事情

在本帖中,我们见证了如何使用 Jets 来编写 Ruby 应用,并将它部署到 AWS Lambda 中。你可以在 GitHub 上看到完整的项目


Jets 能帮助完成的东西远不止这些,譬如:对事件作出反应将数据储存到数据库中,甚至是运行你现有的Rails应用等等。阅读 Jets 文档中的这些文章,了解更多 Jets 的功能。


查看英文原文:Serverless Ruby on AWS Lambda with the Jets framework


2019-06-05 09:1723724
用户头像

发布了 34 篇内容, 共 19.2 次阅读, 收获喜欢 47 次。

关注

评论

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

Java进阶(一)内存解析

No Silver Bullet

Java 9月月更 内存解析

iofod导入任意前端资产,以 Element UI 为例

iofod jude

小程序 前端 低代码 网页

程序员“反内卷”大法——和无效加班说再见!

博文视点Broadview

云原生游戏第 2 讲:OpenKruiseGame 设计理念详解

阿里巴巴云原生

阿里云 容器 云原生 游戏 OpenKruiseGame

艺术收藏NFT系统开发:NFT功能搭建

开源直播系统源码

数字藏品 数字藏品系统软件开发 数字藏品开发

web前端培训程序员学习什么呢

小谷哥

玩转KubeEdge保姆级攻略

乌龟哥哥

8月月更

【案例回顾】春节一次较波折的MySQL调优

京东科技开发者

MySQL 数据库 索引 RDS 调优

如何在保护用户隐私的同时实现精准广告投放?

HarmonyOS SDK

广告sdk

超大模型工程化实践打磨,百度智能云发布云原生 AI 2.0 方案

百度Geek说

云原生 人工智能’ 企业号九月金秋榜

新思科技解析Repo Jacking依赖仓库劫持如何影响供应链安全

InfoQ_434670063458

漏洞 新思科技 软件供应链 Repo Jacking

金融科技创新者的困境

木风

金融科技 数字化转型 科技创新

IDEA配置tomcat

楠羽

#开源

阿里云高性能计算负责人何万青:阿里云大计算加速HPC与AI融合

阿里云弹性计算

AI HPC 高性能计算 无影云电脑 计算巢

移动办公平台如何在企业中发挥数字化优势?

WorkPlus

私有化部署的企业IM:实现工作消息、文件的全面可控

WorkPlus

web前端培训入门难吗?

小谷哥

参加前端培训后再就业难吗?

小谷哥

客随主便-Mysql主从同步是怎样的过程?

知识浅谈

redis主从 9月月更

每日一R「21」Unsafe Rust

Samson

学习笔记 8月月更 ​Rust

【算法实践】一天路走到黑--手把手带你实现坚持不懈的线性查找

迷彩

Python 数据结构 算法实践 8月月更 线性查找

微服务网关Gateway实践总结

Java 架构

从Core Dump中提取CUDA的报错信息

OneFlow

深度学习 报错 cuda

java培训程序员靠技术来延长自己的职业周期

小谷哥

自然语言处理--神经网络的复习

IT蜗壳-Tango

自然语言处理 nlp 9月月更

基于Vue3常用代码块

青柚1943

typescript Vue3 Element Plus Pinia sortablejs

架构师的十八般武艺:合规架构

agnostic

企业架构 合规

定时任务报警通知解决方案详解

阿里巴巴云原生

阿里云 微服务 云原生 定时任务

MobTech SMSSDK iOS端快速集成指南

MobTech袤博科技

ios sdk

[教你做小游戏] 展示斗地主扑克牌,支持按出牌规则排序!支持按大小排序!

HullQin

CSS JavaScript html 前端 9月月更

大数据培训是否可以延迟工作周期

小谷哥

通过Jets框架在AWS Lambda上实现无服务化Ruby_文化 & 方法_PHIL NASH_InfoQ精选文章