【问题标题】:Understanding difference between Custom Handler and SpringBootApiGatewayRequestHandler了解自定义处理程序和 SpringBootApiGatewayRequestHandler 之间的区别
【发布时间】:2020-04-09 12:21:29
【问题描述】:

我是 Spring Cloud Function 的新手,并将其视为开发基于 FaaS 的解决方案的最佳解决方案之一。我正在专门为 API Gateway 后端的 AWS Lambda 服务编写应用程序。我的测试应用程序遇到了一个非常有趣的问题,它在处理程序周围。我的测试应用程序可以很好地与编写为的自定义处理程序配合使用 -

public class UserProfileHandler extends SpringBootRequestHandler<APIGatewayProxyRequestEvent, APIGatewayProxyResponseEvent> {
}

在 AWS Lambda 中配置为处理程序时效果很好。然后我遇到了org.springframework.cloud.function.adapter.aws.SpringBootApiGatewayRequestHandler,它在 Spring Cloud Function 依赖项中可用,所以我想摆脱 UserProfileHandler 因此我将 AWS Lambda 中的 Handler 配置更改为 org.springframework.cloud.function.adapter.aws.SpringBootApiGatewayRequestHandler 而不是 ...UserProfileHandler 现在 lambda 失败并出现以下错误信息。有人遇到过这个问题吗?

{
  "errorMessage": "java.util.Optional cannot be cast to com.amazonaws.services.lambda.runtime.events.APIGatewayProxyRequestEvent",
  "errorType": "java.lang.ClassCastException",
  "stackTrace": [
    "com.transformco.hs.css.userprofile.function.UserProfileFunction.apply(UserProfileFunction.java:16)",
    "org.springframework.cloud.function.context.catalog.BeanFactoryAwareFunctionRegistry$FunctionInvocationWrapper.invokeFunction(BeanFactoryAwareFunctionRegistry.java:499)",
    "org.springframework.cloud.function.context.catalog.BeanFactoryAwareFunctionRegistry$FunctionInvocationWrapper.lambda$doApply$1(BeanFactoryAwareFunctionRegistry.java:543)",
    "reactor.core.publisher.FluxMapFuseable$MapFuseableSubscriber.onNext(FluxMapFuseable.java:107)",
    "reactor.core.publisher.FluxMapFuseable$MapFuseableSubscriber.onNext(FluxMapFuseable.java:121)",
    "reactor.core.publisher.FluxJust$WeakScalarSubscription.request(FluxJust.java:99)",
    "reactor.core.publisher.FluxMapFuseable$MapFuseableSubscriber.request(FluxMapFuseable.java:162)",
    "reactor.core.publisher.FluxMapFuseable$MapFuseableSubscriber.request(FluxMapFuseable.java:162)",
    "reactor.core.publisher.BlockingIterable$SubscriberIterator.onSubscribe(BlockingIterable.java:218)",
    "reactor.core.publisher.FluxMapFuseable$MapFuseableSubscriber.onSubscribe(FluxMapFuseable.java:90)",
    "reactor.core.publisher.FluxMapFuseable$MapFuseableSubscriber.onSubscribe(FluxMapFuseable.java:90)",
    "reactor.core.publisher.FluxJust.subscribe(FluxJust.java:70)",
    "reactor.core.publisher.InternalFluxOperator.subscribe(InternalFluxOperator.java:53)",
    "reactor.core.publisher.BlockingIterable.iterator(BlockingIterable.java:80)",
    "org.springframework.cloud.function.adapter.aws.SpringBootRequestHandler.result(SpringBootRequestHandler.java:59)",
    "org.springframework.cloud.function.adapter.aws.SpringBootRequestHandler.handleRequest(SpringBootRequestHandler.java:52)",
    "org.springframework.cloud.function.adapter.aws.SpringBootApiGatewayRequestHandler.handleRequest(SpringBootApiGatewayRequestHandler.java:140)",
    "org.springframework.cloud.function.adapter.aws.SpringBootApiGatewayRequestHandler.handleRequest(SpringBootApiGatewayRequestHandler.java:43)"
  ]
}

【问题讨论】:

    标签: spring-boot spring-cloud-function


    【解决方案1】:

    Ganesh,我相信你已经在 SCF 的 Github 上提出了这个问题。正如我在那里所说的,我们最近做了一些改进,通过添加Getting Started guide 来完善示例和修改文档。

    也就是说,有了新的通用请求处理程序,您不再需要提供 AWS 请求处理程序的实现,包括 SpringBootApiGatewayRequestHandler

    只需编写启动应用程序以包含函数 bean

    @SpringBootApplication
    public class FunctionConfiguration {
    
        public static void main(String[] args) {
            SpringApplication.run(FunctionConfiguration.class, args);
        }
    
        @Bean
        public Function<String, String> uppercase() {
            return value -> value.toUpperCase();
        }
    }
    

    。 . .并在 AWS 仪表板中指定 org.springframework.cloud.function.adapter.aws.FunctionInvoker 作为处理程序。我们将为您完成剩下的工作。

    【讨论】:

    • 升级到3.0.1,解决了一个问题。感谢您的帮助。
    • 如何在本地测试函数?我们是否必须依赖包含spring boot web?
    • 我不确定我是否理解您的问题。它是一个函数,你可以在单元测试中调用它的apply 方法。
    猜你喜欢
    • 1970-01-01
    • 2018-05-10
    • 1970-01-01
    • 1970-01-01
    • 2013-06-22
    • 2016-08-17
    • 2017-01-29
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多