当前位置:首页 > 技术分析 > 正文内容

Spring Cloud Function 快速入门(spring-cloud)

ruisui882个月前 (04-30)技术分析22

环境:SpringBoot2.3.12.RELEASE + Spring Cloud 2020.0.5


简介

Spring Cloud Function是一个具有以下高层目标的项目:

  1. 通过函数促进业务逻辑的实现。
  2. 将业务逻辑的开发生命周期与任何特定的运行时目标解耦,这样相同的代码就可以作为web端点、流处理器或任务运行。
  3. 支持跨无服务器(serverless)提供商的统一编程模型,以及独立运行(本地或PaaS中)的能力。
  4. 在无服务(serverless)提供商上启用Spring Boot特性(自动配置、依赖注入、指标)。

它抽象了所有的传输细节和基础设施,允许开发人员保留所有熟悉的工具和流程,并将重点牢牢地放在业务逻辑上。如下示例:

@SpringBootApplication
public class Application {
  @Bean
  public Function<Flux<String>, Flux<String>> uppercase() {
    return flux -> flux.map(value -> value.toUpperCase());
  }

  public static void main(String[] args) {
    SpringApplication.run(Application.class, args);
  }
}

如上,它只是一个Spring Boot应用程序,所以它可以在本地和CI构建中构建、运行和测试,就像其他Spring Boot应用程序一样。该 Function来自 java.utilFlux反应流发布者Publisher。可以通过HTTP或消息传递访问该功能。

Spring Cloud Function 有4个主要的功能:

简而言之,Spring Cloud Function提供了以下功能:Function、Consumer和Supplier类型的@Beans的包装器,将它们作为HTTP端点或消息流侦听器/发布者与RabbitMQ、Kafka等一起公开给外部使用。

  1. 编程风格的选择——反应式、命令式或混合式。
  2. 函数组合和适配(例如,组合命令式函数和响应式函数)。
  3. 支持响应式函数,具有多个输入和输出,允许函数处理合并、连接和其他复杂的流操作。
  4. 输入和输出的透明类型转换。
  5. 针对目标平台(例如,Project Riff, AWS Lambda等)的部署打包功能
  6. 将函数作为HTTP端点等对外公开的适配器。
  7. 使用独立的类加载器部署包含此类应用程序上下文的JAR文件,以便可以将它们打包到单个JVM中。
  8. 将作为Java函数体的字符串编译成字节码,然后将它们转换成可以像上面那样包装的@bean。
  9. 适用于AWS Lambda、Azure、Google Cloud Functions、Apache OpenWhisk和其他可能的“serverless”服务提供商的适配器。

案例应用

函数可以自动导出为HTTP端点。

Spring -cloud-function-web模块具有自动配置功能,当它被包含在Spring Boot web应用程序中时(带有MVC支持)就会被激活。如果你只是想要一个简单的入门体验,spring-cloud-starter- functional -web也可以收集所有可选的依赖项。

激活web配置后,你的应用将会有一个MVC端点(默认值为"/",但可以通过
spring.cloud.function.web.path配置),它可以用来访问应用上下文中的函数,其中函数名成为URL路径的一部分。支持的内容类型是纯文本和JSON。

编号

Method

Path

Request

Response

Status

1

GET

/{supplier}

-

Items from the named supplier

200 OK

2

POST

/{consumer}

JSON object or text

Mirrors input and pushes request body into consumer

202 Accepted

3

POST

/{consumer}

JSON array or text with new lines

Mirrors input and pushes body into consumer one by one

202 Accepted

4

POST

/{function}

JSON object or text

The result of applying the named function

200 OK

5

POST

/{function}

JSON array or text with new lines

The result of applying the named function

200 OK

6

GET

/{function}/{item}

-

Convert the item into an object and return the result of applying the function

200 OK

针对以上6中情况,演示示例如下:

  • 1 GET /{supplier}
@Bean
public Function<Flux<String>, Flux<String>> uppercase() {
  return flux -> flux.map(value -> value.toUpperCase());
}

请求结果:

  • 2 POST /{consumer}
@Bean
public Consumer<Person> consumer1() {
  return person -> System.out.println("阻塞式调用:" + person) ;
}

请求结果:

  • 3 POST /{consumer}
@Bean
public Consumer<Flux<Person>> consumer2() {
  return person -> {
    person.subscribe(System.out::println) ;
  } ;
}

请求结果:

  • 4 POST /{consumer}
@Bean
public Consumer<Flux<Person>> consumer3() {
  return person -> {
    person.subscribe(System.out::println) ;
  } ;
}

请求结果:

  • 6 GET /{function}/{item}
@Bean
public Function<Flux<Person>, Flux<Map<String, Object>>> function1() {
  return person -> person.map(p -> {
    Map<String, Object> result = new HashMap<>() ;
    result.put("姓名", p.getName()) ;
    result.put("年龄", p.getAge()) ;
    return result ;
  }) ;
}

请求结果:

完毕!!!

spring data jpa 高级应用

Spring Retry重试框架的应用

Spring容器这些扩展点你都清楚了吗?

Spring MVC 异步请求方式

Spring MVC 异常处理方式

Spring事务实现原理源码分析

Spring 自定义Advisor以编程的方式实现AOP


SpringBoot WebFlux整合Spring Security进行权限认证

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/3715.html

分享给朋友:

“Spring Cloud Function 快速入门(spring-cloud)” 的相关文章

「 VUE3 + TS + Vite 」父子组件间如何通信?

组件之间传值,大家都很熟悉,涉及到 VUE3 +TS 好多同学就无从下手了,所以分享这篇文章,希望看完后提起 VUE3+TS 能够不慌不忙。平时使用的函数如:ref、reactive、watch、computed 等需要先引入才能使用,但是本篇文章介绍的 defineProps、withDefaul...

「干货」通俗易懂的Deno 入门教程

作者: semlinker转发链接:https://mp.weixin.qq.com/s/2eqRTsf_z7Bcs6dziXe73Q一、Deno 简介Deno 是一个 JavaScript/TypeScript 的运行时,默认使用安全环境执行代码,有着卓越的开发体验。Deno 含有以下功能亮点:默...

10分钟搞定gitlab-ci自动化部署

gitlab-ci 是持续集成工具/自动化部署工具,类似 jenkins。持续集成 是将代码集成到共享存储库并尽可能早地自动构建/测试每个更改的实践 - 通常一天几次。概述在编码完成时都会进行打包发布过程,如果每次都手动操作这一步骤就会浪费时间,效率低下。所以就有了持续集成。准备事项请提前安装以下软...

15款测试html5响应式的在线工具

手机、平板灯手持设备的增多,网站要顺应变化,就必须要做响应式开发,响应式网站最大的特点在于可以在不同设备下呈现不同的布局,是基于html5+css3技术,目前越来越多的网站开始采用了响应式设计,而下面15款工具可以方便测试你的html5响应式效果。Responsinatorhttp://www.re...

Excel中的FILTER函数详细介绍及使用示例

在Excel中处理大量数据时,经常需要根据特定条件筛选出符合条件的数据行或列。这正是Excel的FILTER函数发挥作用的地方。FILTER函数是Excel中一个非常强大的工具,它可以基于一个或多个条件动态地过滤数据,使数据分析和报告制作变得更加高效和准确。本文将详细介绍FILTER函数的用法,并提...

Vue进阶(幺叁捌):vue路由传参的几种基本方式

1、动态路由(页面刷新数据不丢失)methods:{ insurance(id) { //直接调用$router.push 实现携带参数的跳转 this.$router.push({ path: `/particulars/${id}`,...