【ETCD】【实操篇(六)】使用多种方式从ETCD集群中读取数据【Get keys by prefix】

本文将演示从 etcd 集群中获取以特定前缀(如 /config/db)开头的所有键值对。
ETCD技术架构图

在分布式系统中,etcd 是一个高可用的键值存储,用于存储和共享配置信息、服务发现、协调等。从 etcd 读取数据可以通过多种方式进行,常见的方式是使用 etcd 提供的 HTTP API 或者通过客户端库来进行操作。

一、使用EtcdCtl工具来读取数据

1.1、设置环境变量(可选)
export ETCDCTL_API=3
export ETCDCTL_ENDPOINTS=http://localhost:2379
1.2、使用etcdctl Get keys by prefix
etcdctl get <key> <value>  --prefix
etcdctl get /config/db  --prefix
1.2’、格式化获取的结果
D:\data>etcdctl get /config/db-w json --prefix
{"header":{"cluster_id":1090313446326588887,"member_id":2759271418354571410,"revision":4,"raft_term":2},"kvs":[{"key":"L2NvbmZpZy9kYi9ob3N0","create_revision":4,"mod_revision":4,"version":1,"value":"MTkyLjE2OC4xLjEwMA=="}],"count":1}

上面的示例我们把获取到结果以json形式进行输出

1.3、通过etcdctl get -h来查看相关帮助信息
D:\data>etcdctl get -h
NAME:
        get - Gets the key or a range of keys

USAGE:
        etcdctl get [options] <key> [range_end] [flags]

OPTIONS:
      --consistency="l"                 Linearizable(l) or Serializable(s)
      --count-only[=false]              Get only the count
      --from-key[=false]                Get keys that are greater than or equal to the given key using byte compare
  -h, --help[=false]                    help for get
      --keys-only[=false]               Get only the keys
      --limit=0                         Maximum number of results
      --order=""                        Order of results; ASCEND or DESCEND (ASCEND by default)
      --prefix[=false]                  Get keys with matching prefix
      --print-value-only[=false]        Only write values when using the "simple" output format
      --rev=0                           Specify the kv revision
      --sort-by=""                      Sort target; CREATE, KEY, MODIFY, VALUE, or VERSION

二、使用go 客户端读取数据

2.1、安装 Go 客户端库
2.2、示例代码
func init() {
   
   
	// 初始化etcd客户端
	var err error
	cli, err = clientv3.New(clientv3.Config{
   
   
<think> 我们正在回答用户关于FastAdmin使用Redis缓存和文件缓存存储数据的方法的问题。之前已经详细介绍了Redis缓存的使用,现在需要补充文件缓存的使用,并将两者进行对比说明。 文件缓存是FastAdmin(基于ThinkPHP)默认的缓存方式使用本地文件系统存储缓存数据。以下是两种缓存方式的具体使用方法: ### 一、Redis缓存配置与使用(复习补充) #### 1. 配置Redis驱动 修改`application/config.php`中的缓存配置: ```php 'cache' => [ 'type' => 'redis', 'host' => '127.0.0.1', 'port' => 6379, 'password' => '', // 如果有设置密码 'select' => 0, // 选择Redis数据库索引 'timeout' => 3600, // 默认缓存过期时间(秒) 'prefix' => 'fa_', // 缓存前缀 'persistent' => false, // 是否使用长连接 ], ``` #### 2. 缓存操作示例 ```php use think\facade\Cache; // 设置缓存(带过期时间10分钟) Cache::set('user_data', $data, 600); // 获取缓存 $data = Cache::get('user_data'); // 删除缓存 Cache::delete('user_data'); // 使用标签管理(可批量清除) Cache::tag('user')->set('user_info', $userInfo); Cache::tag('user')->set('user_profile', $profile); ``` ### 二、文件缓存配置与使用 #### 1. 配置文件缓存 文件缓存是默认的缓存驱动,通常无需额外配置。但可以自定义缓存路径和前缀: ```php 'cache' => [ 'type' => 'file', // 驱动类型 'path' => '../runtime/cache/', // 缓存保存目录 'prefix' => 'fa_', // 缓存前缀 'expire' => 3600, // 默认缓存过期时间(秒) ], ``` #### 2. 文件缓存操作 操作方式与Redis缓存完全一致(得益于ThinkPHP的统一缓存接口): ```php use think\facade\Cache; // 写入缓存(有效时间10分钟) Cache::set('config_data', $configArray, 600); // 读取缓存 $config = Cache::get('config_data'); // 删除指定缓存 Cache::delete('config_data'); // 使用标签(标签数据存储在独立的hash表中) Cache::tag('config')->set('site_config', $siteConfig); ``` ### 三、两种缓存方式对比 | **特性** | **Redis缓存** | **文件缓存** | |--------------------|----------------------------------------|--------------------------------------| | 存储位置 | 内存 | 硬盘文件 | | 读写速度 | 极快(微秒级) | 较慢(毫秒级) | | 数据持久化 | 支持RDB/AOF | 始终持久化 | | 分布式支持 | 天然支持 | 不支持(需借助NFS等共享存储) | | 数据类型支持 | 丰富(字符串/哈希/列表/集合等) | 仅字符串(序列化存储) | | 适用场景 | 高并发读写、频繁访问的热数据 | 低频访问数据、小型项目 | ### 四、缓存选择建议 1. **优先Redis**:生产环境推荐使用Redis,尤其需要处理高并发时 2. **开发调试选文件**:本地开发环境可使用文件缓存简化部署 3. **混合使用策略**: ```php // 在config/cache.php中配置多个缓存通道 'channels' => [ 'file' => [ 'type' => 'file', 'path' => '../runtime/file_cache/', ], 'redis' => [ 'type' => 'redis', 'host' => '127.0.0.1', ], ], // 代码中按需切换 Cache::store('redis')->set('hot_data', $value); // 热数据存Redis Cache::store('file')->set('cold_data', $value); // 冷数据存文件 ``` ### 五、注意事项 1. **文件缓存清理**:定期清理`runtime/cache`目录防止空间耗尽 2. **Redis内存管理**:通过`maxmemory-policy`配置淘汰策略(如volatile-lru) 3. **缓存失效策略**:重要数据建议采用主动更新(写数据库时同步删缓存)[^2] 4. **标签实现差异**:文件缓存的标签实际存储为独立索引文件,大量标签时效率较低 > 关键提示:使用缓存标签清除时,Redis可通过`KEYS`命令直接删除关联数据,而文件缓存需要遍历索引文件,数据量大时可能造成短暂延迟。 --- ### 相关问题 1. 如何监控FastAdmin中Redis缓存的命中率? 2. 文件缓存数据存储的物理结构是怎样的? 3. 如何实现FastAdmin缓存数据的批量导出导入? 4. 高并发场景下如何防止Redis缓存穿透? 5. 在FastAdmin中如何动态切换缓存驱动? [^1]: Windows10系统安装Redis以及在fastadmin使用Redis。解压文件并运行redis-server.exe文件且不要关闭以及打开redis-cli.exe文件,在redis-cli.exe文件中输入ping观察,一般会返回pong,输入shutdown关闭redis-server.exe窗口。 [^2]: Redis实现信息缓存的方法。提供了缓存查询和写入的标准流程,包括缓存查询、数据库回源和写入缓存。 </think> ### FastAdmin中使用Redis缓存与文件缓存的方法 在FastAdmin中,缓存系统基于ThinkPHP框架实现,支持多种缓存驱动。以下是Redis缓存和文件缓存的具体配置与使用方法: --- ### 一、Redis缓存配置与使用 #### 1. 配置Redis驱动 **修改`application/config.php`**: ```php 'cache' => [ 'type' => 'redis', // 驱动类型 'host' => '127.0.0.1', // Redis服务器地址 'port' => 6379, // 端口 'password' => '', // 密码(无密码留空) 'select' => 0, // 数据库索引(0-15) 'prefix' => 'fa_', // 键名前缀 'timeout' => 3600, // 默认过期时间() 'persistent' => false, // 是否使用长连接 ] ``` #### 2. 基本操作示例 ```php use think\facade\Cache; // 写入缓存(带10分钟过期时间) Cache::set('user:1001', ['name' => '张三', 'role' => 'admin'], 600); // 读取缓存 $user = Cache::get('user:1001'); // 删除缓存 Cache::delete('user:1001'); // 检查缓存存在性 if (Cache::has('config:site')) { // ... } ``` #### 3. 高级用法:缓存数据库查询 ```php public function getShopInfo($id) { $key = "shop:{$id}"; // 尝试从Redis获取 if ($data = Cache::get($key)) { return json_decode($data, true); } // 数据库查询(无缓存时) $shop = Db::name('shop')->find($id); if ($shop) { // 写入Redis(缓存1小时) Cache::set($key, json_encode($shop), 3600); return $shop; } return null; } ``` > 注意:更新数据后需手动删除相关缓存保证一致性[^2] --- ### 二、文件缓存配置与使用 #### 1. 配置文件缓存 **修改`application/config.php`**: ```php 'cache' => [ 'type' => 'file', // 驱动类型 'path' => '../runtime/cache/', // 缓存存储目录 'prefix' => 'fa_', // 缓存前缀 'expire' => 3600, // 默认过期时间() ] ``` #### 2. 文件缓存操作(与Redis接口一致) ```php // 写入文件缓存 Cache::set('sysconfig', $configArray); // 读取文件缓存 $config = Cache::get('sysconfig'); // 缓存标签管理(批量清除相关缓存) Cache::tag('config')->set('site_title', '我的网站'); Cache::tag('config')->set('site_icp', '京ICP备XXXX号'); ``` #### 3. 文件缓存特性 - **存储路径**:`runtime/cache/` 目录下生成 `.php` 缓存文件 - **文件结构**:每个缓存项单独文件,文件名格式:`前缀_键名.php` - **内容格式**: ```php <?php return ['expire' => 1690000000, 'data' => '缓存内容']; ``` --- ### 三、两种缓存方式对比 | **特性** | **Redis缓存** | **文件缓存** | |------------------|----------------------------------------|--------------------------------------| | 存储位置 | 内存 | 硬盘文件 | | 读写速度 | 微秒级(超快) | 毫秒级(较慢) | | 数据持久化 | 需配置RDB/AOF | 始终持久化 | | 分布式支持 | 天然支持 | 不支持 | | 适用场景 | 高并发、频繁读写数据 | 低频访问的配置数据 | | 安装要求 | 需单独安装Redis服务 | 无需额外服务 | --- ### 四、最佳实践建议 1. **混合使用策略**: ```php // 热数据用Redis Cache::store('redis')->set('hot:data', $value); // 冷数据用文件缓存 Cache::store('file')->set('config:base', $config); ``` 2. **缓存清理方法**: - Redis:`redis-cli KEYS fa_* | xargs redis-cli DEL` - 文件缓存:删除`runtime/cache/`目录 3. **性能优化**: - Redis连接池:配置`'persistent' => true`减少连接开销 - 文件缓存:使用SSD硬盘提升IO速度 > 重要提示:Windows开发环境需保持`redis-server.exe`运行[^1],Linux生产环境建议配置Redis密码和持久化 --- ### 相关问题 1. 如何监控FastAdmin中Redis缓存的内存使用情况? 2. 文件缓存与Redis缓存的并发性能差异有多大? 3. 如何实现FastAdmin缓存数据的自动预热? 4. Redis集群模式下FastAdmin如何配置缓存? 5. 文件缓存目录结构是否可以自定义优化? [^1]: Windows10系统安装Redis以及在fastadmin使用Redis。解压文件并运行redis-server.exe文件且不要关闭 [^2]: Redis实现信息缓存的方法。提供了缓存查询和写入的标准流程,包括缓存查询、数据库回源和写入缓存。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值