DynamoDB-모범 사례

특정 사례는 다양한 소스 및 요소로 작업 할 때 코드를 최적화하고 오류를 방지하며 처리량 비용을 최소화합니다.

다음은 DynamoDB에서 가장 중요하고 일반적으로 사용되는 모범 사례 중 일부입니다.

테이블

테이블 분포는 모든 테이블 항목에 읽기 / 쓰기 활동을 균등하게 분산하는 최상의 접근 방식을 의미합니다.

테이블 항목에 대한 균일 한 데이터 액세스를 목표로합니다. 최적의 처리량 사용량은 기본 키 선택 및 항목 워크로드 패턴에 달려 있습니다. 워크로드를 파티션 키 값에 균등하게 분산하십시오. 소량의 많이 사용되는 파티션 키 값과 같은 것은 피하십시오. 대량의 개별 파티션 키 값과 같은 더 나은 선택을 선택하십시오.

파티션 동작을 이해합니다. DynamoDB에서 자동으로 할당 된 파티션을 예측합니다.

DynamoDB는 전력 "버스트"에 대해 사용되지 않은 처리량을 예약하는 버스트 처리량 사용량을 제공합니다. 버스트는 많은 양의 처리량을 빠르게 소비하므로이 옵션을 많이 사용하지 마십시오. 또한 신뢰할 수있는 자원이 아닙니다.

업로드시 더 나은 성능을 얻기 위해 데이터를 배포합니다. 할당 된 모든 서버에 동시에 업로드하여이를 구현하십시오.

자주 사용되는 항목을 캐시하여 읽기 활동을 데이터베이스가 아닌 캐시로 오프로드합니다.

아이템

제한, 성능, 크기 및 액세스 비용은 항목의 가장 큰 문제로 남아 있습니다. 일대 다 테이블을 선택하십시오. 액세스 패턴과 일치하도록 속성을 제거하고 테이블을 나눕니다. 이 간단한 접근 방식을 통해 효율성을 크게 향상시킬 수 있습니다.

큰 값을 저장하기 전에 압축하십시오. 표준 압축 도구를 활용합니다. S3와 같은 큰 속성 값에는 대체 스토리지를 사용하십시오. 객체를 S3에 저장하고 식별자를 항목에 저장할 수 있습니다.

가상 아이템 조각을 통해 여러 아이템에 큰 속성을 분배하십시오. 이것은 항목 크기 제한에 대한 해결 방법을 제공합니다.

쿼리 및 스캔

쿼리 및 스캔은 주로 처리량 소비 문제로 어려움을 겪습니다. 일반적으로 강력한 일관된 읽기로 전환하는 것과 같은 결과로 발생하는 버스트를 피하십시오. 리소스가 적은 방식으로 병렬 스캔을 사용합니다 (예 : 조절이없는 백그라운드 기능). 또한 큰 테이블과 함께 사용하고 처리량을 완전히 활용하지 않거나 스캔 작업을 수행하면 성능이 저하됩니다.

지역 보조 지수

인덱스는 처리량 및 저장 비용, 쿼리 효율성 영역에서 문제를 나타냅니다. 속성을 자주 쿼리하지 않는 한 인덱싱을 피하십시오. 프로젝션에서는 인덱스가 부풀어 오르기 때문에 현명하게 선택하십시오. 많이 사용되는 것만 선택하십시오.

모든 테이블 항목에 정렬 키가 나타나지 않는 인덱스를 의미하는 희소 인덱스를 활용합니다. 대부분의 테이블 항목에없는 속성에 대한 쿼리에 유용합니다.

항목 컬렉션 (모든 테이블 항목 및 해당 인덱스) 확장에주의하십시오. 추가 / 업데이트 작업으로 인해 테이블과 인덱스가 모두 증가하고 10GB는 컬렉션 제한으로 남아 있습니다.

글로벌 보조 지수

인덱스는 처리량 및 저장 비용, 쿼리 효율성 영역에서 문제를 나타냅니다. 테이블의 읽기 / 쓰기 확산과 같이 워크로드 균일 성을 제공하는 주요 속성 확산을 선택합니다. 데이터를 균등하게 분산하는 속성을 선택하십시오. 또한 희소 인덱스를 활용하십시오.

적당한 양의 데이터를 요청하는 쿼리에서 빠른 검색을 위해 글로벌 보조 인덱스를 활용합니다.