当前位置: 首页 > news >正文

ETCD的简介和使用

1.简介

etcd是一个Go言编写的分布式、高可用的一致性键值存储系统,用于提供可靠的分布式键值存储、配置共享和服务发现等功能。

2.特点

  • 易使用:基于HTTP+JSON的API让你用curl就可以轻松使用;

  • 易部署:使用Go语言编写,跨平台,部署和维护简单;

  • 强一致:使用Raft算法充分保证了分布式系统数据的强一致性;

  • 高可用:具有容错能力,假设集群有n个节点,当有(n-1)/2节点发送故障,依然能提供服务;

  • 持久化:数据更新后,会通过WAL格式数据持久化到磁盘,支持Snapshot快照;

  • 快速:每个实例每秒支持一千次写操作,极限写性能可达10K QPS;

  • 安全:可选SSL客户认证机制;

  • ETCD 3.0:除了上述功能,还支持gRPC通信、watch机制。

3.简单架构

etcd主要分为四个部分:

  • HTTP Server:用于处理用户发送的API请求以及其它etcd节点的同步与心跳信息请求。

  • Store:用于处理etcd支持的各类功能的事务,包括数据索引、节点状态变更、监控与反馈、事件处理与执行等等,是etcd对用户提供的大多数API功能的具体实现。

  • Raft:Raft强一致性算法的具体实现,是etcd的核心。

  • WAL:Write Ahead Log(预写式日志),是etcd的数据存储方式。除了在内存中存有所有数据的状态以及节点的索引以外,etcd就通过WAL进行持久化存储。WAL中,所有的数据提交前都会事先记录日志。Snapshot是为了防止数据过多而进行的状态快照;Entry表示存储的具体日志内容。

通常,一个用户的请求发送过来,会经由HTTP Server转发给Store进行具体的事务处理,如果涉及到节点的修改,则交给Raft模块进行状态的变更、日志的记录,然后再同步给别的etcd节点以确认数据提交,最后进行数据的提交,再次同步。

4.安装测试

4.1.安装

etcd版本:3.5.11

https://github.com/etcd-io/etcd/releases/,下载对应系统的包

window:

-- 输出日志到控制台
etcd.exe --log-level debug --listen-client-urls http://192.168.184.1:2379 --advertise-client-urls http://192.168.184.1:2379
​
-- 输出日志到文件
etcd.exe  --log-outputs file21 --log-level debug --listen-client-urls http://192.168.184.1:2379 --advertise-client-urls http://192.168.184.1:2379

linux:

-- 输出日志到控制台./etcd  --log-level 'debug' --listen-client-urls 'http://0.0.0.0:2379' --advertise-client-urls 'http://0.0.0.0:2379'
​
-- 输出日志到文件
./etcd --log-outputs '/root/xxx/etcd-v3.5.11-linux-amd64/logs'    --log-level 'debug' --listen-client-urls 'http://0.0.0.0:2379' --advertise-client-urls 'http://0.0.0.0:2379'

4.2.测试

-- linux 进入安装目录
./etcdctl put greeting "Hello, etcd"
OK
​
./etcdctl get greeting
greeting
Hello, etcd

4.3.使用UI客户端连接

etcd-manager:v1.2.0

配置连接:

查看和操作key

http://www.dtcms.com/a/327798.html

相关文章:

  • 42.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--扩展功能--集成网关--网关集成认证(一)
  • 1513-map 的三种声明定义方式 使用方式
  • BN层:深度学习中的“数据稳定器”,如何解决训练难题?
  • 基于C#的二手服装交易网站的设计与实现/基于asp.net的二手交易系统的设计与实现/基于.net的闲置物品交易系统的设计与实现
  • 嵌入式Linux学习 -- 软件编程3
  • UNet改进(32):结合CNN局部建模与Transformer全局感知
  • Docker 101:面向初学者的综合教程
  • 【C#】从 Queue 到 ConcurrentQueue:一次对象池改造的实战心得
  • 激活函数篇(2):SwiGLU | GLU | Swish | ReLU | Sigmoid
  • 如何查看当前Redis的密码、如何修改密码、如何快速启动以及重启Redis (Windows)
  • 鹧鸪云:光伏施工流程管理的智能“导航仪”
  • 云平台监控-云原生环境Prometheus企业级监控实战
  • 【Redis与缓存预热:如何通过预加载减少数据库压力】
  • RoboNeo美图AI助手
  • 如何单独修改 npm 版本(不改变 Node.js 版本)
  • npm、pnpm、yarn区别
  • 深度解析Mysql的开窗函数(易懂版)
  • docker-compose安装ElasticSearch,ik分词器插件,kibana【超详细】
  • 夜莺开源监控,模板函数一览
  • 集合,完整扩展
  • 任务调度系统设计与实现:Quartz、XXL-JOB 和 Apache Airflow 对比与实践
  • 【项目设计】高并发内存池
  • windows系统端口异常占用删除教程
  • Go面试题及详细答案120题(0-20)
  • [TryHackMe]Internal(hydra爆破+WordPress主题修改getshell+Chisel内网穿透)
  • 《Q————Mysql连接》
  • Linux软件编程:IO(二进制文件)、文件IO
  • 【25-cv-08993】T Miss Toys 启动章鱼宠物玩具版权维权,15 项动物玩偶版权均需警惕
  • 如何使用gpt进行模式微调(2)?
  • 使用Spring Boot对接欧州OCPP1.6充电桩:解决WebSocket连接自动断开问题