描述:
java8应用程序在执行sam build; sam local invoke...后在本地运行,但在使用sam package; sam deploy部署时出现ClassNotFound异常时失败
复制问题的步骤:
sam init -r java8 -d gradle && cd sam-appsam build:sam build --use-containersam local invoke HelloWorldFunction --no-eventsam package --template-file template.yaml --output-template-file packaged.yaml --s3-bucket <some bucket name>
sam deploy --template-file packaged.yaml --stack-name java8-gradle-test --capabilities CAPABILITY_IAM --region eu-west-2 --no-fail-on-empty-changesetjava8-gradle-test-HelloWorldFunction-...,添加任意测试事件,然后单击test观察结果:
执行结果:失败
日志:
START RequestId: a5e25d74-4a0d-4763-b7a7-383aeede5c82 Version: $LATEST
Class not found: helloworld.App: java.lang.ClassNotFoundException
java.lang.ClassNotFoundException: helloworld.App
at java.net.URLClassLoader.findClass(URLClassLoader.java:382)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:348)
END RequestId: a5e25d74-4a0d-4763-b7a7-383aeede5c82
REPORT RequestId: a5e25d74-4a0d-4763-b7a7-383aeede5c82 Duration: 58.33 ms Billed Duration: 100 ms Memory Size: 128 MB Max Memory Used: 69 MB 预期结果:
与运行此函数的sam local invoke时相同的成功响应。
在sam local invoke和sam package之间似乎有一些意想不到的区别,后者没有从sam build中提取工件。
发布于 2019-06-20 17:55:02
解决了!这是通过使用sam package --output-template-file packaged.yaml --s3-bucket <some bucket name>来修正的(不指定模板文件)。很明显,sam local invoke是在挑选构建好的,但我不允许sam package这样做。参见对https://github.com/awslabs/aws-sam-cli/issues/978的解释
https://stackoverflow.com/questions/56690353
复制相似问题