AWS Toolkit for EclipseからLambda関数を直接作成できずにMavenでパッケージ化して作成
2021/08/23
目次
AWS Toolkit for EclipseからLambda関数を直接作成
チュートリアル の作成、アップロード、呼び出し方法 AWS Lambda 機能の手順にそって進めました。
右クリック-[New]-[Other]を選択しました。
[AWS]-[AWS Lambda Java Project]を選択しました。
手順にそって進めます。
プロジェクト作成が完了すると、Readme.htmlにチュートリアルの手順が記載されています。
ここで手順ではコードを書き換えるのですが、handleRequestのパラメータは String input だとエラーになるので、Object inputのままにしました。
|
1 2 3 4 5 6 7 |
@Override public String handleRequest(Object input, Context context) { context.getLogger().log("Input: " + input); String output = "Hello, " + input + "!"; return output; } |
/src/test/java – com.example.lambda.demo のHelloTest.javaの21行目のinputを以下に変更しました。
|
1 2 |
input = "from Lambda"; |
41行目には , を足します。
|
1 2 |
Assert.assertEquals("Hello, from Lambda!", output); |
右クリック – [Debug As] – [JUnit Test]を実行して、Failure Traceに何も表示されなければテストが正常完了です。
右クリック – [AWS Lambda]-[Upload function to AWS Lambda]を選択しました。
手順に沿って進めました。
IAMロールなどLambda関数に必要な設定をEclipseでできるのですね。
そして、Finishを押下したところでエラーです。
エラーと対応(Java8にする)
エラーメッセージは以下です。
|
1 2 3 4 5 6 7 8 9 10 |
Failed to upload project to Lambda com.amazonaws.eclipse.core.exceptions.AwsActionException: Cannot invoke "java.io.File.length()" because "jarFile" is null at com.amazonaws.eclipse.lambda.upload.wizard.UploadFunctionWizard.doFinish(UploadFunctionWizard.java:115) at com.amazonaws.eclipse.core.plugin.AbstractAwsJobWizard$1.run(AbstractAwsJobWizard.java:35) at org.eclipse.core.internal.jobs.Worker.run(Worker.java:63) Caused by: java.lang.NullPointerException: Cannot invoke "java.io.File.length()" because "jarFile" is null at com.amazonaws.eclipse.lambda.upload.wizard.util.UploadFunctionUtil.performFunctionUpload(UploadFunctionUtil.java:82) at com.amazonaws.eclipse.lambda.upload.wizard.UploadFunctionWizard.doFinish(UploadFunctionWizard.java:111) ... 2 more |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
Unable to export project [HelloLambda] to jar file java.lang.reflect.InvocationTargetException: JAR creation failed. See details for additional information. at org.eclipse.jdt.internal.ui.jarpackager.JarFileExportOperation.singleRun(JarFileExportOperation.java:1006) at org.eclipse.jdt.internal.ui.jarpackager.JarFileExportOperation.execute(JarFileExportOperation.java:996) at org.eclipse.ui.actions.WorkspaceModifyOperation.lambda$0(WorkspaceModifyOperation.java:110) at org.eclipse.core.internal.resources.Workspace.run(Workspace.java:2292) at org.eclipse.core.internal.resources.Workspace.run(Workspace.java:2317) at org.eclipse.ui.actions.WorkspaceModifyOperation.run(WorkspaceModifyOperation.java:131) at com.amazonaws.eclipse.lambda.upload.wizard.util.FunctionJarExportHelper.exportProjectToJarFile(FunctionJarExportHelper.java:78) at com.amazonaws.eclipse.lambda.upload.wizard.util.UploadFunctionUtil.performFunctionUpload(UploadFunctionUtil.java:68) at com.amazonaws.eclipse.lambda.upload.wizard.UploadFunctionWizard.doFinish(UploadFunctionWizard.java:111) at com.amazonaws.eclipse.core.plugin.AbstractAwsJobWizard$1.run(AbstractAwsJobWizard.java:35) at org.eclipse.core.internal.jobs.Worker.run(Worker.java:63) |
Webで検索すると、JDKのバージョンを8にしよう。
とあったので、まず以下2つのファイルを削除しました。
/Library/Internet Plug-Ins/JavaAppletPlugin.plugin
/Library/PreferencePane/JavaControlPanel.prefPane
そして、Java SE Development Kit 8 DownloadsからmacOS x64向けのパッケージをダウンロードしてインストールしました。
でも同じエラーが発生しました。
もう少し調べると、[Upload function to AWS Lambda]を使わずにMavenでパッケージ化してデプロイしたらいいじゃないかという結果があったので、Toolkitを使うのは諦めて従うことにしました。
Mavenでパッケージ化してアップロード
プロジェクトを選択して右クリック-[Run As]-[Maven install]を選択しました。
Targetにdemo-1.0.0.jarができたので、マネジメントコンソールで手動で作ったランタイムがJava8のLambda関数にアップロードしました。
テストのパラメータは、テストコードと同じく、”from Lambda”にしました。
テストが成功しました。
現在のLambdaのデフォルトJavaバージョンは11
よくよく考えたら、今のLambdaのデフォルトJavaバージョンは11なんだからローカルのJDKを8じゃなくて11にしないといけないんじゃないかと思いまして。
ローカルのJDKを11をインストールしてやり直しました。
Java SE Development Kit 11 Downloads
|
1 2 3 4 5 6 7 |
% java -version java version "11.0.10" 2021-01-19 LTS Java(TM) SE Runtime Environment 18.9 (build 11.0.10+8-LTS-162) Java HotSpot(TM) 64-Bit Server VM 18.9 (build 11.0.10+8-LTS-162, mixed mode) % javac -version javac 11.0.10 |
これで、念のためプロジェクト作成からやってみます。
結果、同じでした。
そういう問題ではなかったようです。
Eclipseで開発してデプロイするという目的は達成できたのでよしとします。
最後までお読みいただきましてありがとうございました!
「AWS認定資格試験テキスト&問題集 AWS認定ソリューションアーキテクト - プロフェッショナル 改訂第2版」という本を書きました。
「AWS認定資格試験テキスト AWS認定クラウドプラクティショナー 改訂第3版」という本を書きました。
「ポケットスタディ AWS認定 デベロッパーアソシエイト [DVA-C02対応] 」という本を書きました。
「要点整理から攻略するAWS認定ソリューションアーキテクト-アソシエイト」という本を書きました。
「AWSではじめるLinux入門ガイド」という本を書きました。
開発ベンダー5年、ユーザ企業システム部門通算9年、ITインストラクター5年目でプロトタイプビルダーもやりだしたSoftware Engineerです。
質問はコメントかSNSなどからお気軽にどうぞ。
出来る限りなるべく答えます。
このブログの内容/発言の一切は個人の見解であり、所属する組織とは関係ありません。
このブログは経験したことなどの共有を目的としており、手順や結果などを保証するものではありません。
ご参考にされる際は、読者様自身のご判断にてご対応をお願いいたします。
また、勉強会やイベントのレポートは自分が気になったことをメモしたり、聞いて思ったことを書いていますので、登壇者の意見や発表内容ではありません。
ad
ad
関連記事
-
-
AWS認定試験の自宅受験で壁のポスターを注意されちゃいました
AWS認定オンライン受験をしてみましたに書きましたとおり、自宅受験デビューしまし …
-
-
DynamoDB IAMポリシーで特定項目だけを許可する
検証記録です。 対象テーブル 書籍のサンプルで作ったこちらです。 所属バンドの楽 …
-
-
Amazon EC2のスクリーンショットとは
ドキュメント見てたらAmazon EC2でスクリーンショットって機能があったので …
-
-
Amazon Auroraのスナップショットの暗号化とリージョン間コピーを改めて試しました
Amazon Auroraデータベースを暗号化して、スナップショットを作成、クロ …
-
-
Amazon SES(Simple Email Service)でメール受信時のアクションでLambdaを実行して渡されるデータを見てみる
Amazon SESで受信したメールをS3に保存して、S3のトリガーでLambd …
-
-
API Gateway Lambdaプロキシ統合で渡されるリクエストを確認しました
API Gatewayの統合リクエストでLambdaを指定するときにプロキシ統合 …
-
-
AWS Organizationsで組織全体のAWS CloudTrailを有効にしました
Organizationsのサービスメニューから、CloudTrailを選択して …
-
-
「X-Tech JAWS 【第2回】~9割のX-Techと1割の優しさで切り拓く未来~」に行ってきました
「X-Tech JAWS 【第2回】~9割のX-Techと1割の優しさで切り拓く …
-
-
AWS DeepLens開封の儀
去年(2019年)7月にamazon.co.jpでDeepLens買えますやんっ …
-
-
slackのbotをAWS Lambda(Python)+API Gatewayで構築
slackで投稿した内容に応じて返信したり調べ物したりしてくれるbotですが、こ …










