关于 aws lambda 使用spring 的dependency injection 的问题

简介:

最近,有个小伙伴提了一个问题:aws lambda 能使用spring 的依赖注入(dependency injection) 吗?怎么 @Autowired 等注解都不生效?我抽空学习研究了一下,得到以下结论:

一、能用吗?

答案应该是能,但也存在限制(我还没有写代码测试);
但是我觉得没有必要用!

原因:

1、ServerLess 我觉得通常都是部署比较小的代码块,用很少的代码来实现一个或一部分关键功能;因为 aws lambda 的调用计费是按占用的内存、CPU时间来了,如果放一个很大的代码块上去,恐怕很不划算。
2、既然是实现一个或一部分关键功能,也就没必要搞那么复杂,简单一点不是更好?由于代码量较少,所以设计模式变得没那么重要,更重要的应该是效率,节省成本嘛(各种框架的引入更可能会降低性能、提高内存和CPU的占用)。

二、如何使用?

1、要明白一点

aws lambda 函数的入口点是:RequestStreamHandler 接口和 RequestHandler 接口 的实现;这也就是为什么注解没有生效的原因,因为对应的注解并没有程序去使用它们(也就是通过注解如“@AutoWired”标注的代码并没有代码去通过反射机制来检测它们(这里需要了解依赖注入的实现原理,这个更有助于理解:https://bbs.csdn.net/topics/370061827))。

2、入口点

Spring Framework 入口点参考:
spring普通java工程的配置启动方式
https://blog.csdn.net/u010476739/article/details/76696756
Spring MVC 入口点应该是:
org.springframework.web.context.ContextLoaderListener
这个没有找到调用示例,估计要去看Tomcat、JBoss、Jetty 的实现,但也应该和上面的类似。

3、限制

上面说能,但也存在限制!
明白一点:aws lambda 函数的入口点是:RequestStreamHandler 接口和 RequestHandler 接口 的实现;
也就是说Spring 相关框架的入口点并不是被最先调用的,那么在 aws lambda 的实现类上是无法使用的;
我们需要在 aws lambda 接口的实现类的具体函数(方法)中调用Spring 相关框架的入口点,调用之后相关的注解才起作用。

从官网到其它地方,没人研究这个问题,我想官方根本没考虑过这个,也不想大家用这个。官方文档 也指出了:这是以灵活性为代价的。

后记

解决一个问题的时候,可以在一定的了解之后先得出一个结论,然后再去证伪,这样就比较容易找到答案了。

相关参考:

什么是 AWS Lambda?
AWS Toolkit for Eclipse 是什么?
lambda控制台

目录
相关文章
|
8月前
|
Java API Spring
Spring6-IoC(Inversion of Control)控制反转和DI(Dependency Injection)依赖注入,手动实现IOC
Spring6-IoC(Inversion of Control)控制反转和DI(Dependency Injection)依赖注入,手动实现IOC
|
8月前
|
XML Java 开发者
Spring框架: 什么是依赖注入(Dependency Injection)?
Spring框架: 什么是依赖注入(Dependency Injection)?
181 2
|
Web App开发 IDE Java
Spring Boot 学习02-----Dependency以及配置等
继上一篇我们搭建了一个非常简单的Spring Boot的demo。接下来,我们将继续学习Spring Boot的相关知识。闲话少叙。
162 0
|
Java 程序员 Spring
@Autowired注解你真的会用吗?Spring官方有话说:Always use constructor based dependency injection in your beans
@Autowired注解你真的会用吗?Spring官方有话说:Always use constructor based dependency injection in your beans
240 0
@Autowired注解你真的会用吗?Spring官方有话说:Always use constructor based dependency injection in your beans
|
NoSQL Java Redis
Java Spring Boot2.0 连接 Redis 出错:Unsatisfied dependency expressed through field 'redisRepository'
Java Spring Boot2.0 连接 Redis 出错:Unsatisfied dependency expressed through field 'redisRepository',解决办法
11749 0
|
Java 容器 Spring
Spring Dependency
我们知道Spring的最重要的核心是Ioc,有时候也被称为DI(Dependency Injection,依赖注入),那么关于Dependency,你了解多少呢? 注入 之前我们有提到IOC和DI的关系与概念,我是把它们区分开了,所以才有了这篇文章。
|
Java 容器 Spring
Spring之对象依赖关系(依赖注入Dependency Injection)
承接上篇: Spring中,如何给对象的属性赋值:   1:通过构造函数,如下所示:           2:通过set方法给属性注入值,如下所示:                    2.1:通过set方法实现dao的注入,service的注入,action的注入;如下所示:        实现上面的前提是已经在对应的类中实现了下面的set方法和私有的类的成员变量的定义;        比如:在service层的方法中实现UserDao的定义和set方法的实现。
1066 0
|
3月前
|
人工智能 自然语言处理 前端开发
SpringBoot + 通义千问 + 自定义React组件:支持EventStream数据解析的技术实践
【10月更文挑战第7天】在现代Web开发中,集成多种技术栈以实现复杂的功能需求已成为常态。本文将详细介绍如何使用SpringBoot作为后端框架,结合阿里巴巴的通义千问(一个强大的自然语言处理服务),并通过自定义React组件来支持服务器发送事件(SSE, Server-Sent Events)的EventStream数据解析。这一组合不仅能够实现高效的实时通信,还能利用AI技术提升用户体验。
256 2
|
11天前
|
Java 数据库连接 Maven
最新版 | 深入剖析SpringBoot3源码——分析自动装配原理(面试常考)
自动装配是现在面试中常考的一道面试题。本文基于最新的 SpringBoot 3.3.3 版本的源码来分析自动装配的原理,并在文未说明了SpringBoot2和SpringBoot3的自动装配源码中区别,以及面试回答的拿分核心话术。
最新版 | 深入剖析SpringBoot3源码——分析自动装配原理(面试常考)
|
18天前
|
NoSQL Java Redis
Spring Boot 自动配置机制:从原理到自定义
Spring Boot 的自动配置机制通过 `spring.factories` 文件和 `@EnableAutoConfiguration` 注解,根据类路径中的依赖和条件注解自动配置所需的 Bean,大大简化了开发过程。本文深入探讨了自动配置的原理、条件化配置、自定义自动配置以及实际应用案例,帮助开发者更好地理解和利用这一强大特性。
68 14