我无法检查我写给Kinesis的数据。看起来以下示例应该可以工作,但我得到一个从get_records返回的空列表(在Records字段中)。可能会发生什么想法?
import uuid
import boto3
import time
streamname = 'mytestStream'
session = boto3.session.Session()
kinesis_client = session.client('kinesis', region_name='us-east-1')
##### WRITE TO KINESIS
partitionkey = str(uuid.uuid4())[:8]
put_response = kinesis_client.put_record(StreamName=streamname,Data='mytestdata',PartitionKey=partitionkey)
time.sleep(5)
##### READ FROM KINESIS
shard_id = kinesis_client.describe_stream(StreamName=streamname)['StreamDescription']['Shards'][0]['ShardId']
shard_iterator = kinesis_client.get_shard_iterator(StreamName=streamname, ShardId=shard_id, ShardIteratorType="LATEST")["ShardIterator"]
data_from_kinesis = kinesis_client.get_records(ShardIterator=shard_iterator)
谢谢!
答案 0 :(得分:2)
如果您要使用LATEST checkpoint,则应首先开始阅读流,然后放置记录。在您的示例中,时间轴如下;
要解决此问题,您应该在不同的线程中运行生产者和使用者。正确的流程应该是这样的;