适用于无服务器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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/351173.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python的sys.stdout、sys.stdin重定向

Python的sys.stdout、sys.stdin重定向 转自:http://www.cnblogs.com/turtle-fly/p/3280519.html 本文环境:Python 2.7 使用 print obj 而非 print(obj) 一些背景 sys.stdout 与 print 当我们在 Python 中打印对象调用 print obj 时候,事实上…

Win10+Ubuntu16.04/Ubuntu18.04双系统安装教程

最近因为开发需要安装Linux系统,因为安装好几次Ubuntu18.04失败,退而安装Ubuntu16.04 安装也失败好几次,在不断尝试下终于解决,后来思考一下觉得Ubuntu 16.04/18.04安装失败原因一致,先进行分享。 先把我遇到的问题给大家看看如下…

获取XML的文件信息

1 /**2 * 获取XML文件的信息3 */4 import java.io.IOException;5 import javax.xml.parsers.DocumentBuilder;6 import javax.xml.parsers.DocumentBuilderFactory;7 import javax.xml.parsers.ParserConfigurationException;8 import org.w3c.dom.Document;9 import org.w3c…

python 中的三元表达式(三目运算符)

python中的三目运算符不像其他语言 其他的一般都是 判定条件?为真时的结果:为假时的结果 如 result5>3?1:0 这个输出1,但没有什么意义,仅仅是一个例子。 而在python中的格式为 为真时的结果 if 判定条件 else 为假时的结果 还是上面的例子 1 if 5…

Linux 命令简单介绍第一课笔记

第一: 相对路径和绝对路径 相对路径:从当前路径开始进入blog文件夹 cd blog绝对路径:从跟目录开始进入blog文件夹 cd /home/yq/Desktop/blog 全称:根目录下home文件下的yq文件下的Desktop文件下的blog文件夹cd ./blog:进入当前…

我是如何转行 AI 并且实现薪资翻倍的

大家好啊,我是董董灿。 熟悉我的小伙伴都知道,我之前在北京某211大学,本硕读了7年的机械专业,后来硕士毕业后,果断转行去做了嵌入式开发,随后瞅准了 AI 爆发的时机果断转行去做了AI。 这段经历已经过去了…

16_1

从16年开始向前,就变得简单了 一、问题 一,给定一个数n,将这个数的各位顺序颠倒,称为逆序数m。 例如1234的逆序数是4321 如果m是n的整数倍,那么输出n*km,例如: 输入: 1089 输出&…

免费网络研讨会:调试生产中Java的新方法

什么是最有用的Java生产调试技术? 您永远不知道将新代码部署到生产中时会发生什么。 曾经很好的工作代码可能会变成有问题的应用程序,无法按预期工作。 这就是为什么在生产中进行调试是了解应用程序在现实生活中的行为而不是您如何思考其行为的关键要素。…

你必须了解的session的本质

有一点我们必须承认,大多数web应用程序都离不开session的使用。这篇文章将会结合PHP以及http协议来分析如何建立一个安全的会话管理机制。我们先简单的了解一些http的知识,从而理解该协议的无状态特性。然后,学习一些关于cookie的基本操作。最…

Linux 命令简单介绍第二课笔记

第一:touch touch 1.txt 创建文件第二:ls ls 用来查看当前文件中的内容,其中加上不同参数-a,-h,-l可以有不同的显示,同事也可以将一个具体内容从定向到一个TXT文件中:具体如下 第三:grep搜索 grep:文本搜索…

人工智能实战_第一次作业_杨佳宁_16141032

项目内容这个作业属于哪个课程班级博客这个作业的要求在哪里作业要求我在这个课程的目标是对于人工智能有一定的了解这个作业在哪个具体方面帮助我实现目标能够有平台支持我对于人工智能更加深入的了解与交流作业正文见下其他参考文献无具体作业1、描述你在这门课想要达到的具体…

Linux压缩和解压缩命令汇总(tar命令汇总)

linux 中压缩文件非常常见,以下为本人对Linux压缩和解压缩命令进行了简单汇总,具体如下: 第一:打包解包 打包命令(注意打包文件大小并没有压缩) tar -cvf xxx.tar 要打包的文件解包命令 tar -xvf xxx.…

MFC程序打开控制台

转自:http://blog.csdn.NET/acaiacc/article/details/5543669 利用AllocConsole() 在你的MFC程序中添加这些代码,可以获得控制台的输入,你试试 AllocConsole(); freopen("CONOUT$","wt",stdout); freopen("…

jmeter异步请求测试_使用JMeter对异步HTTP / REST服务进行压力/负载测试

jmeter异步请求测试尽管我一直在使用JMeter进行Web应用程序的压力测试和负载测试好几次,但我们还是花了一些时间才弄清楚如何使用该工具测试基于异步HTTP / REST的服务。 对我们来说,我是一个程序员的同伴– Holger Staudacher ,我很荣幸能与…

Linux 中vim编辑器学习笔记

vim是Linux是非常常用的编辑器,也是编程开发中的神器之一。接下来,是我学习vim编辑器的一些笔记,总结如下: 首先:我们接触的vim编辑器一共有三种模式,分别为命令模式、编辑模式、末行模式。 具体架构如下 …

Python 面向对象(初级篇)

概述面向过程:根据业务逻辑从上到下写垒代码函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可面向对象:对函数进行分类和封装,让开发“更快更好更强...”面向过程编程最易被初学者接受&…

利用IDA Pro反汇编程序

IDA Pro是一款强大的反汇编软件,特有的IDA视图和交叉引用,可以方便理解程序逻辑和快速定位代码片断,以方便修改。 IDA视图 示例程序 下面会通过修改示例程序的输出字符串,来讲解如何使用IDA Pro。 #includemain() {int n;scanf (…

Neo4j:找到两个纬度/经度之间的中间点

昨天我写了一篇博客文章,展示了如何使用Cypher查找两个纬度/经度之间的中点,这是第一次尝试填补丢失位置的方法,但我意识到我可以做得更好。 正如我在上一篇文章中提到的,当我找到一个缺少经纬度坐标的停靠点时,通常可…

Linux系统更新最新版R语言方法

Linux系统更新最新版R语言方法 第一:卸载之前的版本 sudo apt remove r-base-core第二:在 /etc/apt/sources中添加源 sudo vi /etc/apt/sources对于不同系统添加不同的源具体如下: #(19.04) deb https://cloud.r-project.org/bin/linux/…

Kali Linux下安装VMware

1.Kali Linux安装VMware Workstation 10.0 首先去官网下载VMware Workstation 10.0;下载地址: https://my.vmware.com/web/vmware/details?downloadGroupWKST-1006-LX&productId362&rPId8483 然后cd到下载目录,输入: su…