etcd简介
etcd是一个开源的分布式键值存储系统,它主要用于配置管理、服务发现、分布式锁和协调分布式系统。etcd使用Raft算法来实现共识机制,确保数据的一致性和可靠性。它最初由CoreOS团队开发,现在由Cloud Native Computing Foundation (CNCF)维护。
功能特点
- 高可用性:etcd通过多节点部署提供高可用性,即使部分节点失效,系统仍然可以正常工作。
- 一致性:使用Raft算法实现强一致性,确保所有节点的数据一致。
- 轻量级:etcd设计轻量,易于部署和扩展。
- 安全性:支持TLS/SSL加密通信,保障数据传输安全。
- 动态配置:可以动态更改配置,无需停机。
- 观察者模式:支持观察特定键的变化,实现实时数据同步。
应用场景
- 服务发现:在微服务架构中,服务实例可以注册到etcd,并由服务发现客户端查询。
- 配置管理:集中管理配置数据,动态更新配置,无需重启服务。
- 分布式锁:在分布式系统中,多个进程或服务可能需要对共享资源进行同步访问,etcd可以用来实现分布式锁。
- 集群管理:用于管理Kubernetes集群中的节点信息和状态。
基本操作
etcd提供了一套API,允许用户进行基本的键值操作,如:
- 设置键值:
etcdctl set /path value
- 获取键值:
etcdctl get /path
- 删除键:
etcdctl del /path
- 观察变化:
etcdctl watch /path
安装和部署
从GitHub Release获取etcd安装包
- 访问etcd GitHub页面:
打开浏览器,访问etcd的GitHub官方页面:https://github.com/etcd-io/etcd。 - 导航到Releases页面:
在GitHub页面上找到并点击“Releases”标签,这将展示所有可用的etcd版本。 - 选择合适版本:
根据系统环境(如操作系统和架构)选择合适的版本。通常,最新版本会位于列表的顶部,但也可以根据需要选择其他稳定版本。 - 下载安装包:
在选定的版本下,会看到为不同操作系统和架构准备的预编译二进制文件。找到适合系统的文件,并点击下载链接(通常是.tar.gz
或.zip
格式)。 - 解压安装包:
下载完成后,使用适当的工具解压安装包到希望安装etcd的目录。 验证安装:
解压后,进入解压的目录,会看到etcd
和etcdctl
两个可执行文件。可以通过运行./etcd --version
和./etcdctl version
来验证这两个工具是否已正确安装。部署
windows:
双击etcd.exe
默认开启端口2379
cmd输入:
etcdctl.exe --endpoints=http://127.0.0.1:2379 put key value
来设置值
输入
etcdctl.exe --endpoints=http://127.0.0.1:2379 get key
来获取值