AWS Lambda - функция в Java

В этой главе давайте подробно разберемся, как создать простую функцию AWS Lambda на Java.

Создание файла JAR в Eclipse

Прежде чем приступить к созданию лямбда-функции в AWS, нам потребуется поддержка набора инструментов AWS для Eclipse. Для получения инструкций по установке того же самого, вы можете обратиться кEnvironment Setup главу в этом руководстве.

После того, как вы закончите установку, следуйте инструкциям, приведенным здесь -

Шаг 1

Откройте Eclipse IDE и создайте новый проект с AWS Lambda Java Project. Обратите внимание на снимок экрана, приведенный ниже, для лучшего понимания -

Шаг 2

Как только вы выберете Next, он перенаправит вас на экран, показанный ниже -

Шаг 3

Теперь для Типа ввода создается код по умолчанию. Custom. Как только вы нажметеFinish кнопка создается проект, как показано ниже -

Шаг 4

Теперь щелкните свой проект правой кнопкой мыши и экспортируйте его. ВыбратьJava / JAR файл из Export мастер и щелкните Next.

Шаг 5

Теперь, если вы нажмете Next, вам будет предложено сохранить файл в папке назначения, которая будет предложена, когда вы нажмете «Далее».

После сохранения файла вернитесь в Консоль AWS и создайте функцию AWS Lambda для Java.

Шаг 6

Теперь загрузите .jar файл, который мы создали с помощью Upload кнопку, как показано на скриншоте ниже -

Подробности обработчика для Java

Handler является package name и class name. Посмотрите на следующий пример, чтобы подробно понять обработчик -

пример

package com.amazonaws.lambda.demo;

import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;
public class LambdaFunctionHandler implements RequestHandler
      
        { @Override public String handleRequest(Object input, Context context) { context.getLogger().log("Input: " + input); // TODO: implement your handler return "Hello from Lambda!"; } } 
      

Обратите внимание, что из приведенного выше кода обработчик будет com.amazonaws.lambda.demo.LambdaFunctionHandler

Теперь давайте протестируем изменения и посмотрим на результат -

Объект контекста в Java

Взаимодействие с выполнением AWS Lambda осуществляется с помощью контекста. Он предоставляет следующие методы для использования внутри Java:

Старший Нет Методы контекста и описание
1

getMemoryLimitInMB()

это даст ограничение памяти, которое вы указали при создании лямбда-функции.

2

getFunctionName()

это даст имя лямбда-функции.

3

getFunctionVersion()

это даст версию запущенной лямбда-функции.

4

getInvokedFunctionArn()

это даст ARN, используемый для вызова функции.

5

getAwsRequestId()

это даст идентификатор запроса aws. Этот идентификатор создается для лямбда-функции, и он уникален. Идентификатор можно использовать с поддержкой AWS в случае возникновения каких-либо проблем.

6

getLogGroupName()

это даст название группы aws cloudwatch, связанной с созданной лямбда-функцией aws. Это будет null, если у пользователя iam нет разрешения на ведение журнала Cloudwatch.

7

getClientContext()

это даст подробную информацию о приложении и устройстве при использовании с aws mobile sdk. Он предоставит подробную информацию, такую ​​как имя и код версии, идентификатор клиента, заголовок, имя пакета приложения. Может быть нулевым.

8

getIdentity()

это даст подробную информацию об идентичности amazon cognito при использовании с aws mobile sdk. Может быть нулевым.

9

getRemainingTimeInMillis()

это даст оставшееся время выполнения в миллисекундах, когда функция завершится после указанного тайм-аута.

10

getLogger()

это даст логгер лямбда, связанный с объектом контекста.

Теперь давайте обновим приведенный выше код и посмотрим на результат для некоторых из перечисленных выше методов. Обратите внимание на приведенный ниже пример кода для лучшего понимания -

package com.amazonaws.lambda.demo;
import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;
public class LambdaFunctionHandler implements RequestHandler<Object, String> {
   @Override
   public String handleRequest(Object input, Context context) {
      context.getLogger().log("Input: " + input);
      System.out.println("AWS Lambda function name: " + context.getFunctionName());
      System.out.println("Memory Allocated: " + context.getMemoryLimitInMB());
      System.out.println("Time remaining in milliseconds: " + context.getRemainingTimeInMillis());
      System.out.println("Cloudwatch group name " + context.getLogGroupName());
      System.out.println("AWS Lambda Request Id " + context.getAwsRequestId());
      
      // TODO: implement your handler
      return "Hello from Lambda!";
   }
}

После того, как вы запустите приведенный выше код, вы можете найти вывод, как показано ниже -

Журналы для контекста

Вы можете наблюдать следующий вывод, когда просматриваете вывод журнала -

Память, выделенная для лямбда-функции, составляет 512 МБ. Отведенное время - 25 секунд. Оставшееся время, как показано выше, составляет 24961 в миллисекундах. Итак, 25000 - 24961, что равно 39 миллисекундам, используется для выполнения лямбда-функции. Обратите внимание, что имя группы Cloudwatch и идентификатор запроса также отображаются, как показано выше.

Обратите внимание, что мы использовали следующую команду для печати журналов на Java -

System.out.println (“log message”)

То же самое доступно в CloudWatch. Для этого заходим в сервисы AWS, выбираемCloudWatchservices и нажмите Logs.

Теперь, если вы выберете функцию Lambda, она отобразит дату журналов, как показано ниже -

Вход в Java

Вы также можете использовать Lambdalogger в Java для регистрации данных. Обратите внимание на следующий пример, который показывает то же самое -

пример

package com.amazonaws.lambda.demo;
import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.amazonaws.services.lambda.runtime.LambdaLogger;
public class LambdaFunctionHandler implements RequestHandler<Object, String> {
   @Override
   public String handleRequest(Object input, Context context) {
      LambdaLogger logger = context.getLogger();
      logger.log("Input: " + input);
      logger.log("AWS Lambda function name: " + context.getFunctionName()+"\n");
      logger.log("Memory Allocated: " + context.getMemoryLimitInMB()+"\n");
      logger.log("Time remaining in milliseconds: " + context.getRemainingTimeInMillis()+"\n");
      logger.log("Cloudwatch group name " + context.getLogGroupName()+"\n");
      logger.log("AWS Lambda Request Id " + context.getAwsRequestId()+"\n");
      
      // TODO: implement your handler
      return "Hello from Lambda!";
   }
}

Код, показанный выше, даст вам следующий результат -

Результат в CloudWatch будет таким, как показано ниже -

Обработка ошибок в Java для лямбда-функции

В этом разделе объясняется, как обрабатывать ошибки в Java для функции Lambda. Обратите внимание на следующий код, который показывает то же самое -

package com.amazonaws.lambda.errorhandling;
import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;
public class LambdaFunctionHandler implements RequestHandler<Object, String> {
   @Override
   public String handleRequest(Object input, Context context) {
      throw new RuntimeException("Error from aws lambda");
   } 
}

Обратите внимание, что сведения об ошибке отображаются в json формат с errorMessage Error from AWS Lambda. Так жеErrorType и stackTrace дает более подробную информацию об ошибке.

Вывод и соответствующий вывод журнала приведенного выше кода будут такими, как показано на следующих снимках экрана, приведенных ниже -