百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

Spring Cloud Function 快速入门

yuyutoo 2025-01-16 21:30 8 浏览 0 评论

环境: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进行权限认证

相关推荐

IntelliJ IDEA插件开发(java开发idea插件)

引言IntelliJIDEA是JetBrains公司开发的一款广受欢迎的集成开发环境(IDE)。它不仅支持Java等多种编程语言,还通过插件系统提供了强大的扩展能力。本分享旨在介绍如何使用Java开...

如何验证自己的idea或者如何产生idea?小编教你如何检索……

申请专利前首先要做的是检索查重,如果你的构思已经被别人申请过专利,那么就不符合专利“新颖性”的要求。因此,如果你有了idea之后如何验证自己的idea具备新颖性,或者如何产生idea呢?今天,小编带着...

idea激活码失效了,这样解决,稳定使用!

最近官网封控比较严格,正式版激活码是不是又掉线了?掉线请看这里,这里有一个解决的方法,就是让工具不联网就可以继续使用激活码了。激活码本来就叫离线激活码,现在要怎么使id工具不联网?·可以打开这里帮助,...

5分钟解决 IntelliJ IDEA 使用问题(免费激活至 2100 年)

直接进入正题!效果安装1.官网下载idea...

【中高级前端必看】- 结合代码实践,全面学习前端工程化

前言前端工程化,简而言之就是软件工程+前端,以自动化的形式呈现。就个人理解而言:前端工程化,从开发阶段到代码发布生产环境,包含了以下几个内容:开发构建测试部署...

Android绘制流程(android界面绘制)

Android绘制流程来源:极客头条MFC、WTL、DuiLib、QT、Skia、OpenGL。Android里面的画图分为2D和3D两种:2D是由Skia来实现的,3D部分是由OpenGL实现...

ExpandListView 的一种巧妙写法(g的另一种写法上下两个圈连起来怎么打)

ExpandListView大家估计也用的不少了,一般有需要展开的需求的时候,大家不约而同的都想到了它然后以前自己留过记录的一般都会找找以前自己的代码,没有记录习惯的就会百度、谷歌,这里吐槽一下,好几...

通过圆形载入View了解自定义View(圆形div怎么搞)

这是自定义View的第一篇文章,通过制作简单的自定义View来了解自定义View的流程。自定义View是Android学习和开发中必不可少的一部分。通过自定义View我们可以制作丰富绚丽的控件,自定...

鸿蒙开源第三方组件——自定义流式布局组件FlowLayout_ohos

前言基于安卓平台的自定义流式布局组件FlowLayout(https://blog.csdn.net/fzhhsa/article/details/103003019),实现了鸿蒙的功能化迁移和重构...

「经典总结」一个View,从无到有会走的三个流程,你知道吗?

...

手把手带你写FlowLayout(流式布局)

流式布局在android中主要应用在搜索记录和用户标签,下面是效果图首先我们分析流式布局的原理。其实就是当一个子view加上之前的子view的宽度超过了父容器的宽度的时候就换行。接下来我们手把手书写流...

Android View(android view使用mvvm架构)

AndroidUI界面架构每个Activity包含一个PhoneWindow对象,PhoneWindow设置DecorView为应用窗口的根视图,在里面就是TitleView和ContentView...

《教你步步为营掌握自定义View》一文读后感

今天读了简书作者[milter]的一篇文章《教你步步为营掌握自定义View》,大有裨益。作者以幽默风趣、通俗易懂的大白话一步步讲述了View的来龙去脉,甚是详尽,实属自定义View文集中的一篇非常优秀...

Android面试官:你究竟有多大的勇气,在简历上写了“精通”?

所周知,简历上“了解=听过名字;熟悉=知道是啥;熟练=用过;精通=做过东西”。最近在面试,我现在十分后悔在简历上写了“精通”二字…先给大家看看我简历上的技能清单:良好的java基础,熟悉掌握面向对象思...

iOS 视图---动画渲染机制探究(动画渲染用哪个软件最好)

腾讯Bugly特约作者:陈向文终端的开发,首当其冲的就是视图、动画的渲染,切换等等。用户使用App时最直接的体验就是这个界面好不好看,动画炫不炫,滑动流不流畅。UI就是App的门面,它的体验伴...

取消回复欢迎 发表评论: