本文整理匯總了Java中com.amazonaws.services.dynamodbv2.model.DescribeStreamRequest類的典型用法代碼示例。如果您正苦於以下問題:Java DescribeStreamRequest類的具體用法?Java DescribeStreamRequest怎麽用?Java DescribeStreamRequest使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
DescribeStreamRequest類屬於com.amazonaws.services.dynamodbv2.model包,在下文中一共展示了DescribeStreamRequest類的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: getShardIterator
import com.amazonaws.services.dynamodbv2.model.DescribeStreamRequest; //導入依賴的package包/類
String getShardIterator(String resumeFromSequenceNumber) {
ShardIteratorType iteratorType = getEndpoint().getIteratorType();
String sequenceNumber = getEndpoint().getSequenceNumber();
if (resumeFromSequenceNumber != null) {
// Reset things as we're in an error condition.
currentShard = null;
currentShardIterator = null;
iteratorType = ShardIteratorType.AFTER_SEQUENCE_NUMBER;
sequenceNumber = resumeFromSequenceNumber;
}
// either return a cached one or get a new one via a GetShardIterator request.
if (currentShardIterator == null) {
ListStreamsResult streamsListResult = getClient().listStreams(
new ListStreamsRequest().withTableName(getEndpoint().getTableName())
);
final String streamArn = streamsListResult.getStreams().get(0).getStreamArn(); // XXX assumes there is only one stream
DescribeStreamResult streamDescriptionResult = getClient().describeStream(
new DescribeStreamRequest().withStreamArn(streamArn)
);
shardList.addAll(streamDescriptionResult.getStreamDescription().getShards());
LOG.trace("Current shard is: {} (in {})", currentShard, shardList);
if (currentShard == null) {
currentShard = resolveNewShard(iteratorType, resumeFromSequenceNumber);
} else {
currentShard = shardList.nextAfter(currentShard);
}
shardList.removeOlderThan(currentShard);
LOG.trace("Next shard is: {} (in {})", currentShard, shardList);
GetShardIteratorResult result = getClient().getShardIterator(
buildGetShardIteratorRequest(streamArn, iteratorType, sequenceNumber)
);
currentShardIterator = result.getShardIterator();
}
LOG.trace("Shard Iterator is: {}", currentShardIterator);
return currentShardIterator;
}
示例2: setup
import com.amazonaws.services.dynamodbv2.model.DescribeStreamRequest; //導入依賴的package包/類
@Before
public void setup() throws Exception {
endpoint.setAmazonDynamoDbStreamsClient(amazonDynamoDBStreams);
undertest = new ShardIteratorHandler(endpoint);
when(amazonDynamoDBStreams.listStreams(any(ListStreamsRequest.class))).thenReturn(
new ListStreamsResult()
.withStreams(new Stream()
.withStreamArn("arn:aws:dynamodb:region:12345:table/table_name/stream/timestamp")
)
);
when(amazonDynamoDBStreams.describeStream(any(DescribeStreamRequest.class))).thenReturn(
new DescribeStreamResult()
.withStreamDescription(
new StreamDescription()
.withTableName("table_name")
.withShards(
ShardListTest.createShardsWithSequenceNumbers(null,
"a", "1", "5",
"b", "8", "15",
"c", "16", "16",
"d", "20", null
)
)
)
);
when(amazonDynamoDBStreams.getShardIterator(any(GetShardIteratorRequest.class))).thenAnswer(new Answer<GetShardIteratorResult>() {
@Override
public GetShardIteratorResult answer(InvocationOnMock invocation) throws Throwable {
return new GetShardIteratorResult()
.withShardIterator("shard_iterator_"
+ ((GetShardIteratorRequest) invocation.getArguments()[0]).getShardId()
+ "_000");
}
});
}