首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用AWSSDK更新AmazonKinesisClient的关键技术

使用AWSSDK更新AmazonKinesisClient的关键技术
EN

Stack Overflow用户
提问于 2018-09-21 14:15:18
回答 1查看 177关注 0票数 0

我在.Net中创建了一个使用动态流的on应用程序。如何编写一个方法来更新我的KinesisClient的关键要素(它们仅有效1小时),而不需要重新创建客户机本身。这有可能吗?还是我这么做的方式不对?

这是我用来生产客户端的工厂类。

代码语言:javascript
复制
public static AmazonKinesisClient CreateKinesisClient(BasicAWSCredentials credentials, string roleArn, string roleSessionName, RegionEndpoint region, LogWriter logWriter)
    {
        try
        {
            var stsClient = new AmazonSecurityTokenServiceClient(credentials);
            var ownerRoleReq = new AssumeRoleRequest
            {
                RoleArn = roleArn,
                RoleSessionName = roleSessionName
            };
            var ownerRoleResp = stsClient.AssumeRoleAsync(ownerRoleReq).Result;

            logWriter.LogInfo<AmazonKinesisClient>("Role taken:" + ownerRoleResp.AssumedRoleUser);
            return new AmazonKinesisClient(ownerRoleResp.Credentials, region);
        }
        catch (Exception e)
        {
           logWriter.LogError<AmazonClientFactory>(e.Message,e);
           throw;
        }
    }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-02 11:02:19

最后,我将最新的记录id保存在并发字典中,并在重新创建客户机时注入包含KinesisStream中每个碎片的最新id的字典。

代码语言:javascript
复制
 private string CreateShardIteratorRequestWithSequenceNumber(Shard shard, string sequenceNumber)
    {
        var iteratorRequest = new GetShardIteratorRequest()
        {
            ShardId = shard.ShardId,
            StreamName = _streamName,
            ShardIteratorType = ShardIteratorType.AFTER_SEQUENCE_NUMBER,
            StartingSequenceNumber = sequenceNumber
        };
        return GetShardIterator(iteratorRequest);
    }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52445638

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档