DynamoDB-스캔

스캔 작업은 모든 테이블 항목 또는 보조 인덱스를 읽습니다. 기본 함수는 인덱스 또는 테이블에있는 모든 항목의 모든 데이터 속성을 반환합니다. 고용ProjectionExpression 필터링 속성의 매개 변수.

모든 스캔은 일치하는 항목이없는 경우에도 결과 집합을 반환하므로 빈 집합이 생성됩니다. 스캔은 데이터 필터링 옵션과 함께 1MB 이하를 검색합니다.

Note − 매개 변수 및 스캔 필터링은 쿼리에도 적용됩니다.

스캔 작업 유형

Filtering− 스캔 작업은 스캔 또는 쿼리 후 데이터를 수정하는 필터 표현식을 통해 미세 필터링을 제공합니다. 결과를 반환하기 전에. 표현식은 비교 연산자를 사용합니다. 구문은 필터 표현식이 허용하지 않는 키 속성을 제외하고 조건 표현식과 유사합니다. 필터 표현식에서 파티션 또는 정렬 키를 사용할 수 없습니다.

Note − 필터링을 적용하기 전에 1MB 제한이 적용됩니다.

Throughput Specifications− 스캔은 처리량을 소비하지만 소비는 반환 된 데이터가 아닌 항목 크기에 중점을 둡니다. 모든 속성을 요청하든 몇 개만 요청하든 소비는 동일하게 유지되며 필터 표현식을 사용하거나 사용하지 않아도 소비에 영향을 미치지 않습니다.

Pagination− DynamoDB는 결과에 페이지를 매겨 결과를 특정 페이지로 나눕니다. 1MB 제한은 반환 된 결과에 적용되며이를 초과하면 나머지 데이터를 수집하기 위해 또 다른 스캔이 필요합니다. 그만큼LastEvaluatedKey값을 사용하면이 후속 스캔을 수행 할 수 있습니다. 값을ExclusiveStartkey. 때LastEvaluatedKey값이 null이되면 작업이 모든 데이터 페이지를 완료했습니다. 그러나 널이 아닌 값이 자동으로 더 많은 데이터가 남아 있음을 의미하지는 않습니다. null 값만 상태를 나타냅니다.

The Limit Parameter− limit 매개 변수는 결과 크기를 관리합니다. DynamoDB는이를 사용하여 데이터를 반환하기 전에 처리 할 항목 수를 설정하며 범위 밖에서는 작동하지 않습니다. x 값을 설정하면 DynamoDB는 일치하는 처음 x 개 항목을 반환합니다.

LastEvaluatedKey 값은 부분 결과를 생성하는 제한 매개 변수의 경우에도 적용됩니다. 스캔을 완료하는 데 사용하십시오.

Result Count − 질의 및 스캔에 대한 응답에는 다음과 관련된 정보도 포함됩니다. ScannedCount및 Count는 스캔 / 쿼리 된 항목을 수량화하고 반환 된 항목을 수량화합니다. 필터링하지 않으면 해당 값이 동일합니다. 1MB를 초과하면 개수는 처리 된 부분 만 나타냅니다.

Consistency− 쿼리 결과 및 스캔 결과는 최종적으로 일관된 읽기이지만 강력하게 일관된 읽기도 설정할 수 있습니다. 사용ConsistentRead 이 설정을 변경하는 매개 변수.

Note − 일관된 읽기 설정은 강력하게 일관되게 설정된 경우 용량 단위를 두 배로 사용하여 소비에 영향을줍니다.

Performance− 쿼리는 전체 테이블 또는 보조 인덱스를 크롤링하는 스캔으로 인해 스캔보다 더 나은 성능을 제공하여 응답이 느려지고 처리량이 많이 소모됩니다. 스캔은 적은 수의 필터를 사용하는 작은 테이블 및 검색에 가장 적합하지만 갑작스럽고 가속화 된 읽기 활동을 방지하고 병렬 스캔을 활용하는 것과 같은 몇 가지 모범 사례를 준수하여 린 스캔을 설계 할 수 있습니다.

쿼리는 주어진 조건을 충족하는 특정 범위의 키를 찾습니다. 성능은 키의 양이 아니라 검색하는 데이터의 양에 따라 결정됩니다. 작업 매개 변수와 일치 항목 수는 특히 성능에 영향을줍니다.

병렬 스캔

스캔 작업은 기본적으로 순차적으로 처리를 수행합니다. 그런 다음 데이터를 1MB 부분으로 반환하여 응용 프로그램이 다음 부분을 가져 오도록합니다. 이로 인해 큰 테이블 및 인덱스에 대한 긴 스캔이 발생합니다.

이 특성은 또한 스캔이 항상 사용 가능한 처리량을 완전히 활용하지 못할 수 있음을 의미합니다. DynamoDB는 여러 파티션에 테이블 데이터를 배포합니다. 스캔 처리량은 단일 파티션 작업으로 인해 단일 파티션으로 제한됩니다.

이 문제에 대한 해결책은 테이블이나 인덱스를 세그먼트로 논리적으로 나누는 것입니다. 그런 다음 "작업자"는 병렬 (동시) 세그먼트를 스캔합니다. 세그먼트의 매개 변수를 사용하고TotalSegments 특정 작업자가 스캔 한 세그먼트를 지정하고 처리 된 세그먼트의 총 수량을 지정합니다.

작업자 번호

최상의 애플리케이션 성능을 얻으려면 작업자 값 (세그먼트 매개 변수)을 실험해야합니다.

Note− 대규모 작업자 집합이있는 병렬 스캔은 모든 처리량을 소비하여 처리량에 영향을줍니다. 단일 작업자가 모든 처리량을 사용하지 못하도록하는 데 사용할 수있는 Limit 매개 변수로이 문제를 관리합니다.

다음은 정밀 스캔의 예입니다.

Note− 다음 프로그램은 이전에 생성 된 데이터 소스를 가정 할 수 있습니다. 실행을 시도하기 전에 지원 라이브러리를 확보하고 필요한 데이터 소스 (필수 특성이있는 테이블 또는 기타 참조 소스)를 작성하십시오.

이 예제는 또한 Eclipse IDE, AWS 자격 증명 파일 및 Eclipse AWS Java 프로젝트 내에서 AWS Toolkit을 사용합니다.

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.ItemCollection;
import com.amazonaws.services.dynamodbv2.document.ScanOutcome;
import com.amazonaws.services.dynamodbv2.document.Table;

public class ScanOpSample {  
   static DynamoDB dynamoDB = new DynamoDB(
      new AmazonDynamoDBClient(new ProfileCredentialsProvider())); 
   static String tableName = "ProductList";  
   
   public static void main(String[] args) throws Exception { 
      findProductsUnderOneHun();                       //finds products under 100 dollars
   }  
   private static void findProductsUnderOneHun() { 
      Table table = dynamoDB.getTable(tableName);
      Map<String, Object> expressionAttributeValues = new HashMap<String, Object>(); 
      expressionAttributeValues.put(":pr", 100); 
         
      ItemCollection<ScanOutcome> items = table.scan ( 
         "Price < :pr",                                  //FilterExpression 
         "ID, Nomenclature, ProductCategory, Price",     //ProjectionExpression 
         null,                                           //No ExpressionAttributeNames  
         expressionAttributeValues);
         
      System.out.println("Scanned " + tableName + " to find items under $100."); 
      Iterator<Item> iterator = items.iterator(); 
         
      while (iterator.hasNext()) { 
         System.out.println(iterator.next().toJSONPretty()); 
      }     
   } 
}