当通过调用执行伸缩规则接口在创建或释放 ECS 实例时,如果遇到了请求超时或服务器内部错误时,客户端可能会尝试重发请求,这时客户端可以通过提供可选参数 ClientToken 避免服务器创建或释放出比预期要多的实例,即通过提供 ClientToken 参数保证请求的幂等性。ClientToken 是一个由客户端生成的唯一的、大小写敏感、不超过 64 个 ASCII 字符的字符串。
如果用户使用同一个 ClientToken 值调用创建实例接口,则服务端会返回相同的请求结果,包含相同的 ScalingActivityId。因此用户在遇到错误进行重试的时候,可以通过提供相同的 ClientToken 值,来确保只创建一个伸缩活动,并得到这个伸缩活动的 ScalingActivityId。
如果用户提供了一个已经使用过的 ClientToken,但其他请求参数不同,则弹性伸缩会返回 IdempotentParameterMismatch 的错误代码。需要注意的是,SignatureNonce、Timestamp 和 Signature 参数在重试时是需要变化的,因为弹性伸缩使用 SignatureNonce 来防止重放攻击,使用 Timestamp 来标记每次请求时间,所以再次请求必须提供不同的 SignatureNonce 和 Timestamp 参数值,这同时也会导致 Signature 值的变化。
通常,客户端只需要在 503(ServiceUnavailable)错误、或者无法得到响应结果的情况下进行重试操作。返回结果是 200 时,重试可以得到与上次相同的结果,但不会对服务端状态产生任何影响。而对 4xx 或 500 的返回错误,除非提示信息里明确出现
try it later,否则重试也无法成功。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
在使用阿里云ECS自动伸缩功能调用API创建或释放实例时,确保请求幂等性以避免因重试导致的多余实例生成,可遵循以下实践:
设置ClientToken参数:
ClientToken
值。例如:ClientToken=123e4567-e89b-12d3-a456-426655440000
。ClientToken
时,即使请求超时或遇到服务器内部错误(如500 InternalError或503 ServiceUnavailable),重试时应保持该ClientToken
不变。这样,即使多次尝试,服务端也只会执行一次实际操作。处理重试逻辑:
SignatureNonce
、Timestamp
参数,并重新计算Signature
以防止重放攻击和时间戳过期问题,同时保持ClientToken
不变。幂等性保障:
ClientToken
重试请求,将得到相同的结果及ScalingActivityId
,确保只触发一个伸缩活动。ClientToken
但其他请求参数有变,则会收到IdempotentParameterMismatch
错误,此时需更换ClientToken
后重试。响应处理:
综上所述,通过精心设计重试策略并正确应用ClientToken
,可以有效保证ECS实例在弹性伸缩操作中的幂等性,从而控制实例数量准确无误,提升系统稳定性和资源管理效率。
注:上述回答中,角标引用的知识库资料为[1],代表参考资料【1】如何保证幂等性文档内容。