PublishLayerVersion - AWS Lambda

PublishLayerVersion

ZIP 아카이브에서 AWS Lambda 계층을 생성합니다. 동일한 계층 이름으로 PublishLayerVersion을(를) 호출할 때마다 새 버전이 생성됩니다.

CreateFunction 또는 UpdateFunctionConfiguration(으)로 함수에 계층을 추가합니다.

요청 구문

POST /2018-10-31/layers/LayerName/versions HTTP/1.1 Content-type: application/json { "CompatibleArchitectures": [ "string" ], "CompatibleRuntimes": [ "string" ], "Content": { "S3Bucket": "string", "S3Key": "string", "S3ObjectVersion": "string", "ZipFile": blob }, "Description": "string", "LicenseInfo": "string" }

URI 요청 파라미터

요청은 다음 URI 파라미터를 사용합니다.

LayerName

계층의 이름 또는 Amazon 리소스 이름(ARN)입니다.

길이 제약: 최소 길이는 1입니다. 최대 길이는 140입니다.

Pattern: (arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+)|[a-zA-Z0-9-_]+

필수 항목 여부: 예

요청 본문

요청은 JSON 형식으로 다음 데이터를 받습니다.

CompatibleArchitectures

호환되는 명령 세트 아키텍처의 목록입니다.

유형: 문자열 어레이

배열 멤버: 최대 항목 수는 2개입니다.

유효 값: x86_64 | arm64

필수 항목 여부: 아니요

CompatibleRuntimes

호환 함수 런타임의 목록. ListLayersListLayerVersions을(를) 사용한 필터링에 사용됩니다.

다음 목록에는 더 이상 사용되지 않는 런타임이 포함되어 있습니다. 자세한 내용은 런타임 사용 중단 정책을 참조하세요.

유형: 문자열 어레이

배열 멤버: 최대 항목 수 15개.

유효 값: nodejs | nodejs4.3 | nodejs6.10 | nodejs8.10 | nodejs10.x | nodejs12.x | nodejs14.x | nodejs16.x | java8 | java8.al2 | java11 | python2.7 | python3.6 | python3.7 | python3.8 | python3.9 | dotnetcore1.0 | dotnetcore2.0 | dotnetcore2.1 | dotnetcore3.1 | dotnet6 | nodejs4.3-edge | go1.x | ruby2.5 | ruby2.7 | provided | provided.al2 | nodejs18.x | python3.10 | java17 | ruby3.2 | python3.11 | nodejs20.x | provided.al2023 | python3.12 | java21

필수 항목 여부: 아니요

Content

함수 계층 아카이브.

유형: LayerVersionContentInput 객체

필수 항목 여부: 예

Description

버전에 대한 설명입니다.

유형: String

길이 제약: 최소 길이는 0. 최대 길이 256.

필수 항목 여부: 아니요

LicenseInfo

계층의 소프트웨어 라이선스. 이것은 다음 중 하나가 될 수 있습니다.

  • SPDX 라이선스 식별자. 예: MIT.

  • 인터넷에 호스팅된 라이선스의 URL입니다. 예: https://opensource.org/licenses/MIT.

  • 라이선스의 전체 텍스트.

유형: 문자열

길이 제약: 최대 길이는 512입니다.

Required: No

응답 구문

HTTP/1.1 201 Content-type: application/json { "CompatibleArchitectures": [ "string" ], "CompatibleRuntimes": [ "string" ], "Content": { "CodeSha256": "string", "CodeSize": number, "Location": "string", "SigningJobArn": "string", "SigningProfileVersionArn": "string" }, "CreatedDate": "string", "Description": "string", "LayerArn": "string", "LayerVersionArn": "string", "LicenseInfo": "string", "Version": number }

응답 요소

작업이 성공하면 서비스가 HTTP 201 응답을 다시 전송합니다.

다음 데이터는 서비스에 의해 JSON 형식으로 반환됩니다.

CompatibleArchitectures

호환되는 명령 세트 아키텍처의 목록입니다.

유형: 문자열 어레이

배열 멤버: 최대 항목 수는 2개입니다.

유효한 값: x86_64 | arm64

CompatibleRuntimes

계층의 호환 가능한 실행 시간입니다.

다음 목록에는 더 이상 사용되지 않는 런타임이 포함되어 있습니다. 자세한 내용은 런타임 사용 중단 정책을 참조하세요.

유형: 문자열 어레이

배열 멤버: 최대 항목 수 15개.

유효한 값: nodejs | nodejs4.3 | nodejs6.10 | nodejs8.10 | nodejs10.x | nodejs12.x | nodejs14.x | nodejs16.x | java8 | java8.al2 | java11 | python2.7 | python3.6 | python3.7 | python3.8 | python3.9 | dotnetcore1.0 | dotnetcore2.0 | dotnetcore2.1 | dotnetcore3.1 | dotnet6 | nodejs4.3-edge | go1.x | ruby2.5 | ruby2.7 | provided | provided.al2 | nodejs18.x | python3.10 | java17 | ruby3.2 | python3.11 | nodejs20.x | provided.al2023 | python3.12 | java21

Content

계층 버전에 대한 세부 정보입니다.

유형: LayerVersionContentOutput 객체

CreatedDate

계층 버전이 생성된 날짜입니다(ISO-8601 형식)(YYYY-MM-DDThh:mm:ss.sTZD).

유형: 문자열

Description

버전에 대한 설명입니다.

유형: String

길이 제약: 최소 길이는 0. 최대 길이는 256입니다.

LayerArn

계층의 ARN입니다.

유형: 문자열

길이 제약: 최소 길이는 1. 최대 길이는 140입니다.

패턴: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+

LayerVersionArn

계층 버전의 ARN입니다.

유형: String

길이 제약: 최소 길이는 1. 최대 길이는 140입니다.

패턴: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+:[0-9]+

LicenseInfo

계층의 소프트웨어 라이선스.

유형: 문자열

길이 제약: 최대 길이는 512입니다.

Version

버전 번호입니다.

Type: Long

Errors

모든 작업에서 발생하는 일반적인 오류에 대한 자세한 내용은 일반적인 오류 섹션을 참조하세요.

CodeStorageExceededException

AWS 계정이 최대 총 코드 크기를 초과했습니다. 자세한 내용은 Lambda 할당량을 참조하세요.

HTTP 상태 코드: 400

InvalidParameterValueException

요청의 파라미터 중 하나가 유효하지 않습니다.

HTTP 상태 코드: 400

ResourceNotFoundException

요청에 지정된 리소스가 없습니다.

HTTP 상태 코드: 404

ServiceException

AWS Lambda 서비스에 내부 오류가 발생했습니다.

HTTP 상태 코드: 500

TooManyRequestsException

요청 처리량 제한을 초과했습니다. 자세한 내용은 Lambda 할당량을 참조하세요.

HTTP Status Code: 429

참고

이 API를 언어별 AWS SDK 중 하나로 사용하는 방법에 대한 자세한 설명은 다음을 참조하세요.