" KinesisClientLibIOException:Shard未关闭"在DynamoDB流上

时间:2017-07-21 18:20:43

标签: amazon-dynamodb amazon-kinesis amazon-dynamodb-streams

我有一个DynamoDB表,我添加了一个Stream。我创建了一个Lambda来处理这个流并测试吞吐量,延迟等。完成我的测试后,我删除了lambda的触发器。

然后我继续用Python MultiLangDaemon client测试同一个表,进行比较,看看它是否可以找到lambda离开的地方。

守护进程开始处理分片并爆炸,但下面有例外。正在搜索它,我只找到this answer,但不适用。我尝试删除用于跟踪worker的DynamoDB表,并让MultiLangDaemon重新创建它。同样的事情发生了。

为什么会发生这种情况,如何在不丢失流中的数据的情况下进行恢复?

SEVERE: Caught exception:
com.amazonaws.services.kinesis.clientlibrary.exceptions.internal.KinesisClientLibIOException: Shard [shardId-00000001500614265247-3b7a2849, shardId-00000001500628985464-c896556e] is not closed. This can happen if we constructed the list of shards  while a reshard operation was in progress.
  at com.amazonaws.services.kinesis.clientlibrary.lib.worker.ShardSyncer.assertClosedShardsAreCoveredOrAbsent(ShardSyncer.java:206)
  at com.amazonaws.services.kinesis.clientlibrary.lib.worker.ShardSyncer.cleanupLeasesOfFinishedShards(ShardSyncer.java:652)
  at com.amazonaws.services.kinesis.clientlibrary.lib.worker.ShardSyncer.syncShardLeases(ShardSyncer.java:141)
  at com.amazonaws.services.kinesis.clientlibrary.lib.worker.ShardSyncer.checkAndCreateLeasesForNewShards(ShardSyncer.java:88)
  at com.amazonaws.services.kinesis.clientlibrary.lib.worker.ShutdownTask.call(ShutdownTask.java:122)
  at com.amazonaws.services.kinesis.clientlibrary.lib.worker.MetricsCollectingTaskDecorator.call(MetricsCollectingTaskDecorator.java:49)
  at com.amazonaws.services.kinesis.clientlibrary.lib.worker.MetricsCollectingTaskDecorator.call(MetricsCollectingTaskDecorator.java:24)
  at java.util.concurrent.FutureTask.run(FutureTask.java:266)
  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
  at java.lang.Thread.run(Thread.java:745)

0 个答案:

没有答案