18-10-29
banq
Spring Cloud云函数可以实现无服务器功能,快速浏览Spring Cloud 2.0提供的一些改进,包括更快的启动和“全函数”的能力。而且,由于它是在Spring Boot之上构建的,因此不再需要servlet容器。Spring Cloud Function 2.0是基于Spring Boot 2.1和Spring Framework 5.1以上版本实现,不同于传统的Bean的定义,显著改善了在无服务器架构中的冷启动性能。
下面是1.0版本的Spring的云函数功能应用,通过@Configuration和@Bean等声明式注解一起实现:
@SpringBootApplication public class DemoApplication { @Bean public Function<String, String> uppercase() { return value -> value.toUpperCase(); } public static void main(String args) { SpringApplication.run(DemoApplication.class, args); } } |
可以在AWS Lambda中运行,还支持 Azure Functions和Apache OpenWhisk,以及其他无服务器支持(例如Oracle Fn和Riff)。
将spring-cloud-function-starter-web放在类路径中,就能访问端点:
$ curl localhost:8080 -d foo
返回的是大写FOO,说明上面代码中@Bean注解的函数转换功能起作用了。
1.0中Web适配器是使用Spring MVC实现的,这样你就需要启动一个Servlet容器才能运行Spring MVC。在Spring Cloud Function 2.0中,如果想使用Servlet容器,默认服务器是netty;还可以使用Webflux - 只需包含 spring-cloud-starter-function-webflux依赖项。
在2.0中,云函数功能实现代码有所区别:
@SpringBootConfiguration public class DemoApplication implements ApplicationContextInitializer<GenericApplicationContext> { public static void main(String args) { FunctionalSpringApplication.run(DemoApplication.class, args); } public Function<String, String> uppercase() { return value -> value.toUpperCase(); } @Override public void initialize(GenericApplicationContext context) { context.registerBean("demo", FunctionRegistration.class, () -> new FunctionRegistration<>(uppercase()) .type(FunctionType.from(String.class).to(String.class))); } } |
主要区别是:
- 主要实现类是ApplicationContextInitializer。
- @Bean方法已被转换为调用context.registerBean()
- @SpringBootApplication已被替换@SpringBootConfiguration,表示不会让Spring启动后实现自动配置,但是仍然标记这个类作为一个启动“入口点”。
- SpringApplication已经被替换为FunctionalSpringApplication,这是云功能新类(SpringApplication的一个子类)。
在Spring Cloud Function应用程序中注册的业务逻辑bean属于类型FunctionRegistration。这是一个包装器,包含有关输入和输出类型的函数和信息。在@Bean应用程序的形式中,信息可以反射性地导出,但在函数bean注册中,除非我们使用FunctionRegistration,否则其中一些信息会丢失。
还有一种方法是使应用自己直接实现Function (或Consumer 或Supplier):
@SpringBootConfiguration public class DemoApplication implements Function<String, String> { public static void main(String args) { FunctionalSpringApplication.run(DemoApplication.class, args); } @Override public String apply(String value) { return value.toUpperCase(); } } |
Spring Boot在函数功能bean注册方面运行良好 - Spring Cloud Function在Spring Boot基础上构建和运行 - 但Spring Boot中的一些最有用的功能,即自动配置,都是以非函数性方式编码的。与整个Spring Boot相比,大多数Spring Cloud Function应用程序的范围相对较小,因此我们可以轻松地将其适应这些功能bean定义。