news 2026/5/1 8:18:02

自动令牌刷新的Etcd客户端实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
自动令牌刷新的Etcd客户端实现

这是一个用于处理 etcd 身份验证令牌自动刷新的自定义客户端类。让我详细解释这个代码:

1. 核心功能概述

这个类继承自标准的etcd3.Etcd3Client,主要目的是在 etcd 认证令牌过期时自动刷新,避免因令牌过期导致的操作失败。

2. 类结构分析

classRefreshTokenClient(etcd3.Etcd3Client):

2.1 关键方法

1.refresh()方法

defrefresh(self):auth_request=etcdrpc.AuthenticateRequest(name=ETCD_USER,password=ETCD_PASSWORD)resp=self.auth_stub.Authenticate(auth_request,self.timeout)self.metadata=(('token',resp.token),)# 更新令牌
  • 向 etcd 重新认证获取新的令牌
  • 更新客户端的认证元数据

2.retry()方法(核心装饰器模式)

defretry(self,fn):def_inner():try:returnfn()# 第一次尝试执行操作exceptgrpc.RpcErrorasexc:# 捕获认证失败错误self.refresh()# 刷新令牌returnfn()# 重试操作return_inner

3. 工作原理示例

假设有一个实际使用场景:

# 假设有以下环境变量ETCD_USER="admin"ETCD_PASSWORD="secret123"ETCD_IP="localhost"ETCD_PORT=2379# 创建带自动刷新的客户端etcd=RefreshTokenClient(host=ETCD_IP,port=ETCD_PORT,user=ETCD_USER,password=ETCD_PASSWORD)# 使用示例try:# 1. 第一次写入(令牌有效)etcd.put('/key1','value1')# 2. 模拟令牌过期后的操作# 内部流程:# a) 调用 put() 方法# b) 触发认证错误 (grpc.RpcError)# c) retry() 捕获异常# d) 调用 refresh() 获取新令牌# e) 重新尝试 put() 操作etcd.put('/key2','value2')# 3. 读取操作同样受保护value,_=etcd.get('/key1')print(f"读取到的值:{value}")exceptExceptionase:print(f"操作失败:{e}")

4. 覆盖的方法分析

代码中覆盖了所有主要的 etcd 操作方法:

方法类型方法名用途
读操作get_response,get_prefix_response获取键值
写操作put,delete增删改数据
批量操作transaction,delete_prefix事务和批量删除
Lease 操作lease,refresh_lease租约管理
集群管理add_member,remove_member集群成员管理
维护操作compact,defragment存储维护
监控list_alarms,create_alarm警报管理

5. 完整工作流程示例

# 场景:长运行程序,令牌会过期importtimedeflong_running_task():# 使用自动刷新客户端client=RefreshTokenClient(host='localhost',port=2379,user='myuser',password='mypass')# 令牌有效期为 1 小时foriinrange(100):# 模拟长时间运行(假设运行超过1小时)time.sleep(100)# 100秒# 第 60 分钟后,令牌过期# 下次操作时会自动刷新try:client.put(f'/task/progress/{i}',f'progress{i}%')print(f"更新进度:{i}%")exceptExceptionase:print(f"操作{i}失败:{e}")# 但实际不会失败,因为 retry() 会处理令牌刷新

6. 特殊处理的方法

members属性(生成器)

@propertydefmembers(self):forminself.retry(lambda:list(super(RefreshTokenClient,self).members))():yieldm
  • 需要特殊处理,因为members是属性而不是方法
  • 将生成器转换为列表以确保正确重试

7. 条件实例化

代码最后根据认证信息选择客户端类型:

ifETCD_USERandETCD_PASSWORD:etcd=RefreshTokenClient(...)# 使用自动刷新客户端else:etcd=etcd3.client(...)# 使用普通客户端

8. 优势总结

  1. 透明性:使用者无需关心令牌管理
  2. 可靠性:自动重试机制提高系统稳定性
  3. 兼容性:完全兼容原始 etcd3 客户端 API
  4. 错误处理:优雅处理认证失效场景

这种设计模式特别适用于:

  • 长时间运行的服务
  • 需要高可用的分布式系统
  • 自动化运维工具
  • 容器化环境中的服务发现
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 7:25:52

Monaco Editor文档注释样式自定义配置完全指南

Monaco Editor文档注释样式自定义配置完全指南 【免费下载链接】monaco-editor A browser based code editor 项目地址: https://gitcode.com/gh_mirrors/mo/monaco-editor 开发者面临的视觉识别困境 在实际开发中,很多开发者在使用Monaco Editor时会遇到文…

作者头像 李华
网站建设 2026/4/23 17:20:57

Wan2.2-T2V-A14B在文旅宣传视频中的快速落地案例

Wan2.2-T2V-A14B在文旅宣传视频中的快速落地案例你有没有遇到过这种情况:一个绝美的景区,故事讲得动人,照片拍得惊艳,可一到做宣传片,立马卡壳?要协调拍摄团队、等天气、抢时间,最后成片还未必能…

作者头像 李华
网站建设 2026/4/30 17:34:03

15、目标枚举与漏洞映射:全面解析安全评估

目标枚举与漏洞映射:全面解析安全评估 在当今数字化的时代,网络安全问题日益严峻。为了保障系统和网络的安全,我们需要对目标进行全面的评估,包括目标枚举和漏洞映射。本文将详细介绍这些方面的知识和相关工具。 1. 目标枚举 目标枚举是安全评估的重要环节,其目的是收集…

作者头像 李华
网站建设 2026/5/1 8:09:21

数字阅读体验终极指南:5个快速提升阅读效率的技巧

数字阅读体验终极指南:5个快速提升阅读效率的技巧 【免费下载链接】readest Readest is a modern, feature-rich ebook reader designed for avid readers offering seamless cross-platform access, powerful tools, and an intuitive interface to elevate your r…

作者头像 李华
网站建设 2026/4/30 14:03:04

Gitleaks环境变量配置:新手必学的3种一键设置方法

Gitleaks环境变量配置:新手必学的3种一键设置方法 【免费下载链接】gitleaks Protect and discover secrets using Gitleaks 🔑 项目地址: https://gitcode.com/GitHub_Trending/gi/gitleaks Gitleaks是一款强大的密钥检测配置工具,专…

作者头像 李华