适用于无服务器Java开发人员的AWS Lambda:它为您带来了什么?

无服务器计算如何帮助您的生产基础架构?

在过去的几年中,无服务器计算架构一直受到关注,因为它专注于应用程序的主要组件之一:服务器。 这种体系结构采用了不同的方法。

在下面的文章中,我们将解释无服务器的含义,并尝试了解它是否以及何时可以为您的应用程序提供帮助。 系好安全带。

云的新衣

无服务器计算的概念谈论的是部署代码,而不是服务器。 一开始听起来可能有些混乱,因为这意味着您可以将服务器整体丢弃,并在没有服务器的情况下运行应用程序。 但您可以猜到,事实并非如此。

云提供商无需购买,管理和扩展它们,而是处理对VM的请求的提供商。 因此,您仍然需要服务器,但是这种新模型使您无需承担责任。 换句话说,处理服务器上的部署或任何类型的已安装软件都没有麻烦。 基本上,您需要的只是托管的云服务和计算机。

输入AWS Lambda

该模型由Amazon作为AWS Lambda于2014年首次引入。该公司是第一个提供无服务器服务的人,它是Amazon Web Services套件的一部分。

AWS Lambda基于事件驱动的平台,由注册,更新等事件触发。 当事件发生时,它将调用相关函数,依次运行代码。 所有这些,同时管理和计算运行和仅使用它们所需的资源。

换句话说,基本工作流程保持不变:编写代码,将其上传到服务器以使其运行,并消除对响应时间,操作等方面的担忧。

AWS Lambda有时被称为功能即服务(FaaS),因为这些事件触发了处理请求所需的相关功能,从而使我们能够轻松运行我们的功能。

与FaaS一起,无服务器体系结构也称为后端即服务(BaaS),它消除了很大一部分数据库管理开销,并为不同的用户和级别提供了授权。

AWS Lambda总经理Tim Wagner 共享了一个图表,该图表说明了组件及其连接:一个Lambda函数作为计算资源(“后端”)和一个直接与其连接的移动应用程序,以及提供API HTTP端点的Amazon API Gateway静态的Amazon S3托管网站:

无服务器架构图

无服务器架构图。 资料来源:亚马逊

照顾好你的代码

AWS Lambda的主要目标是允许开发人员以简单的方式构建较小的,按需和事件响应型应用程序。 它为您工作,并管理“计算团队”,以平衡内存,CPU,网络,应用安全补丁,监视运行状况以及任何其他所需的资源和操作。

外包服务是一种很好的看待方式。 它不仅可以“重新安置IT”,而且甚至可以帮助您降低运营成本,因为您可以消除基础架构成本,甚至可以减少维护服务器所需的团队成员数量。

说到成本,您只需要根据使用的功能和代码执行的时间来支付使用的费用。 重要的是要声明免费层每月包括100万个免费请求,每月最多有320万秒的计算时间。

从请求开始作为对事件或调用的响应开始执行时开始计算。 而且还包括来自控制台的测试。

据亚马逊称,AWS Lambda是许多应用程序场景的平台。 但是,当然有一个陷阱,该语句仅与AWS Lambda支持的语言有关:Node.js,Java和Python。

从好的方面来说,可以使用您已经知道的工具Maven或Gradle完成使用Java构建AWS Lambda函数的过程,并且构建过程几乎相同。

给我看代码

完成基本设置后,调用AWS Lambda函数非常简单,您可以在此处查看完整说明。

它包括定义代表输入和输出JSON的POJO,指定代表我们的微服务的接口,并使用被调用时调用的Lambda函数的名称对其进行注释。

下一步将使用LambdaInvokerFactory创建此接口的实现。 这将使我们能够调用Lambda上运行的服务。 然后,我们可以使用此代理对象简单地调用我们的服务,例如……计数猫:

CountCatsInput input = new CountCatsInput();
input.setBucketName("pictures-of-cats");
input.setKey("three-cute-cats");
 
int cats = catService.countCats(input).getCount();

在你开始之前…

当然,没有什么是完美的,主要选择代码的选项也有一些缺点。 由于它仍然是一项相当新的技术,因此很容易找到用户不太满意的问题列表,例如:

控制 –您正在“移交”服务器,希望您的云主机将以最佳方式处理它们。 但是您可能会遇到一些重大问题,您必须坐下来等待它们解决,甚至可能包括停机时间和不满意的客户。

锁定 –说到将所有内容交给云主机,使用AWS Lambda意味着您必须使用AWS。 现在可能不是问题,但是如果您考虑迁移到Google或仅使用自己的服务器,它将成为一个问题。

灵活性 –您将无法登录到计算实例或自定义操作系统或语言运行时。

安全性 –使用第三者也意味着使用其安全性。 我们并不是说AWS并不安全,而是您将这项责任完全转移给了可能不太理想的第三方。 。

监视 –使用AWS Lambda,您只能使用内部工具CloudWatch监视和调试系统。 尽管您仍然可以创建自定义警报,但可以查看请求率和错误率–这是一个非常基本的工具,它可能无法帮助您了解问题的根本原因。

只是该体系结构缺点的一小部分(但很重要)。 还必须指出,如果您已经有一个应用程序,并且想要将其迁移到无服务器架构,则可能会发现自己是从头开始编写的。 因此,您可能需要考虑一下,或者只是将其积压到计划中的下一个新应用程序中。

最后的想法

亚马逊从AWS Lambda开始了无服务器的发展,如今,微软,谷歌,IBM等其他公司以及小型公司和初创公司都提供这种模式。

如果必须赌博,我们会说无服务器是未来。 如果您考虑一下,这是云计算发展的下一步,这使我们对云以及除我们自己以外的提供商完全信任。

目前,最好保留当前的云或本地服务器。 它仍然是一项新技术,在我们放弃服务器之前,亚马逊,谷歌和其他公司需要经历一些挑战。 可能是婴儿的脚步,但不管我们是否喜欢,我们都朝着这个方向前进。

翻译自: https://www.javacodegeeks.com/2016/08/aws-lambda-serverless-java-developers-whats.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值