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
Обратите внимание, что из приведенного выше кода обработчик будет 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 дает более подробную информацию об ошибке.
Вывод и соответствующий вывод журнала приведенного выше кода будут такими, как показано на следующих снимках экрана, приведенных ниже -