简体   繁体   English

无法在本地调用 Java 上的 Lambda AWS

[英]Cannot invoke Lambda AWS on java locally

I run the following commands:我运行以下命令:

1) sls create --template aws-java-maven
2) mvn clean install
3) sls invoke local -f hello

I got this error:我收到此错误:

Serverless: In order to get human-readable output, please implement "toString()" method of your "ApiGatewayResponse" object.
java.lang.reflect.InvocationTargetException

    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at com.serverless.InvokeBridge.invoke(InvokeBridge.java:95)
    at com.serverless.InvokeBridge.<init>(InvokeBridge.java:39)
    at com.serverless.InvokeBridge.main(InvokeBridge.java:150)
Caused by: java.lang.NoSuchMethodError: com.amazonaws.services.lambda.runtime.LambdaLogger.log([B)V
    at com.amazonaws.services.lambda.runtime.log4j2.LambdaAppender.append(LambdaAppender.java:74)
    at org.apache.logging.log4j.core.config.AppenderControl.tryCallAppender(AppenderControl.java:156)
    at org.apache.logging.log4j.core.config.AppenderControl.callAppender0(AppenderControl.java:129)

    at org.apache.logging.log4j.core.config.AppenderControl.callAppenderPreventRecursion(AppenderControl.java:120)
    at org.apache.logging.log4j.core.config.AppenderControl.callAppender(AppenderControl.java:84)
    at org.apache.logging.log4j.core.config.LoggerConfig.callAppenders(LoggerConfig.java:448)
    at org.apache.logging.log4j.core.config.LoggerConfig.processLogEvent(LoggerConfig.java:433)
    at org.apache.logging.log4j.core.config.LoggerConfig.log(LoggerConfig.java:417)
    at org.apache.logging.log4j.core.config.LoggerConfig.log(LoggerConfig.java:403)

    at org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.log(AwaitCompletionReliabilityStrategy.java:63)
    at org.apache.logging.log4j.core.Logger.logMessage(Logger.java:146)
    at org.apache.logging.log4j.spi.AbstractLogger.logMessageSafely(AbstractLogger.java:2091)
    at org.apache.logging.log4j.spi.AbstractLogger.logMessage(AbstractLogger.java:2005)

    at org.apache.logging.log4j.spi.AbstractLogger.logIfEnabled(AbstractLogger.java:1876)
    at org.apache.logging.log4j.spi.AbstractLogger.info(AbstractLogger.java:1421)
    at com.serverless.Handler.handleRequest(Handler.java:18)

    ... 7 more

Adding both log4j and log4j2 with version 1.0.0 (decreased from 1.1.0) helped ...在版本 1.0.0(从 1.1.0 降低)中添加 log4j 和 log4j2 有助于...

<dependency>
  <groupId>com.amazonaws</groupId>
  <artifactId>aws-lambda-java-log4j</artifactId>
  <version>1.0.0</version>
</dependency>
<dependency>
  <groupId>com.amazonaws</groupId>
  <artifactId>aws-lambda-java-log4j2</artifactId>
  <version>1.0.0</version>
</dependency>

It seems you are missing some runtime logger dependencies.您似乎缺少一些运行时记录器依赖项。 Try adding these to your pom file尝试将这些添加到您的 pom 文件中

<dependency>
  <groupId>com.amazonaws</groupId>
  <artifactId>aws-lambda-java-log4j2</artifactId>
  <version>1.1.0</version>
</dependency>

Also, you need to make sure that you are using the compatible version of Java AWS SDK, which is generally the same version number.Something like this此外,您需要确保您使用的是 Java AWS SDK 的兼容版本,该版本通常是相同的版本号。类似这样的事情

<dependency>
  <groupId>com.amazonaws</groupId>
  <artifactId>aws-lambda-java-log4j</artifactId>
  <version>1.0.0</version>
</dependency>

This also work for me....这也适用于我......

 <dependency>
    <groupId>com.amazonaws</groupId>
    <artifactId>aws-lambda-java-log4j2</artifactId>
     <version>1.1.0</version>
 </dependency>

In java file add below lines.在java文件中添加以下行。

LambdaLogger logger = context.getLogger();

logger.log("received: " +input.toString());

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 无法使用Serverless在本地调用AWS Lambda - Not able to invoke locally AWS Lambda using Serverless 如何在 ZD52387880E1EA223817A 中的另一个 aws lambda 调用 aws lambda function - How to invoke an aws lambda function from another aws lambda in Java? 如何在Java中创建/调用AWS Lambda函数? - How to create/invoke AWS Lambda functions in Java? 如何在 Java 中本地触发现有的 AWS lambda? - How can I trigger an existing AWS lambda locally in Java? 如何从Java代码调用AWS lambda函数/处理程序 - How to invoke the AWS lambda function / handler from Java code 在Android上调用AWS Lambda函数 - Invoke AWS Lambda function on Android AWS-Lambda Scheduler调用多个Lambda实例 - AWS - Lambda Scheduler to invoke multiple lambda instances 在Java AWS无服务器框架设置下,如何确定Lambda是在本地运行还是在AWS下运行 - How to determine whether Lambda is running locally or under AWS under Java AWS serverless framework setup 如何在本地为AWS运行Java Lambda函数并使用无服务器(SLS)检查日志 - how to run java lambda function for aws locally and check logs using serverless (sls) 带有Java的AWS Lambda抛出由ClassNotFoundException引起的NoClassDefFoundError,该异常未在本地抛出 - AWS Lambda with java throwing NoClassDefFoundError caused by ClassNotFoundException which isn't thrown locally
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM