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

etcd启动和测试

趁着失业看点没看过的东西,先在本机上启动etcd的环境再跟着文档看看一些具体的实现。首先可以再docker上pull一个最新的镜像并启动,用docker启动一个容器会比较方便的得到一个干净隔离的环境,需要删除的时候也更彻底一些。

官方文档: https://etcd.io/docs/v3.5/tutorials/

本地环境的配置

// 拉取镜像
docker pull bitnami/etcd// 根据镜像启动一个新的容器
docker run -d --name myetcd \--publish 2379:2379 \--publish 2380:2380 \--env ALLOW_NONE_AUTHENTICATION=yes \--env ETCD_ADVERTISE_CLIENT_URLS=http://0.0.0.0:2379 \bitnami/etcd:latest// 进入容器使用etcdctl命令验证功能
docker exec -it myetcd /bin/sh//执行一些基础命令看看效果
$ etcdctl put name yugu
OK
$ etcdctl get name
name
yugu
$ etcdctl del name
1
$ etcdctl get name
$

http请求遇到的base64编码问题

之前在启动容器的时候指定了etcd暴露的服务端地址,可以尝试一下使用http请求操作etcd。因为使用了grpc通信,在代码中找到对应的proto文件查看服务路径。

api/etcdserverpb/rpc.protorpc Put(PutRequest) returns (PutResponse) {option (google.api.http) = {post: "/v3/kv/put"body: "*"};}

curl接口的时候却返回错误,通过返回的信息推断是和payload的内容不是base64编码格式有关。通过代码可以看到Key和Value的类型是[]byte而不string,因此为了请求的字符串能够表示完整的二进制内容, 需要对二进制内容进行base64编码后作为字符串传递。而这部分工作是grpc-gateway自动完成的。

curl -L http://localhost:2379/v3/kv/put \-X POST \-d '{"key": "name", "value": "czl"}'{"error":"illegal base64 data at input byte 4","code":3,"message":"illegal base64 data at input byte 4"}%

grpc-gateway 通过 protoc 编译器插件生成用于将 gRPC 服务映射到 RESTful API 的代码。生成的代码会处理 HTTP 请求和响应的转换,包括将 gRPC 消息序列化为 JSON 格式或将 JSON 格式反序列化为 gRPC 消息。在这个转换过程中,bytes 类型的字段会被自动编码或解码为 Base64。

在对请求内容进行base64编码后重试成功能够拿到返回结果, 再获取key的值发现已经被成功更新了。从返回结果的各个字段可以看到etcd集群和节点的ID以及当前字段修改的次数,当我再次更新同一个key的值并获取的话,可以看到revision字段也被更新了(累加1),最后raft_term应该是与raft选举的任期有关,如果我重启容器的话,这个值应该也会改变。具体raft的实现后面在看…

curl -L http://localhost:2379/v3/kv/put \-X POST \-d '{"key": "bmFtZQ==", "value": "Y3ps"}'{"header":{"cluster_id":"14841639068965178418","member_id":"10276657743932975437","revision":"5","raft_term":"4"}}%$ etcdctl get name
name
czl

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • PyTorch 基础学习(13)- 混合精度训练
  • C++ 设计模式——建造者模式
  • Redis—持久化机制
  • StarRocks 存算分离数据回收原理
  • jpg怎么转换成pdf?6个简单方法,实现jpg转换成pdf
  • 设计模式(一):单例模式
  • 数字IC/FPGA中有符号数的处理探究
  • Python|OpenCV-基于OpenCV进行图像的复制与克隆(19)
  • 第五章 设置和其他常见活动 - 创建 IRIS 凭证集
  • 【hot100篇-python刷题记录】【买卖股票的最佳时机】
  • django之自定义序列化器用法
  • 【Java学习】反射和枚举详解
  • 微服务网关
  • 基于python的自适应svm电影评价倾向性分析设计与实现
  • 全光谱日照模拟系统汽车整车光老化测试 太阳光照射模拟器
  • canvas绘制圆角头像
  • codis proxy处理流程
  • golang中接口赋值与方法集
  • input的行数自动增减
  • JAVA 学习IO流
  • Java精华积累:初学者都应该搞懂的问题
  • jdbc就是这么简单
  • Joomla 2.x, 3.x useful code cheatsheet
  • JS笔记四:作用域、变量(函数)提升
  • JS基础篇--通过JS生成由字母与数字组合的随机字符串
  • macOS 中 shell 创建文件夹及文件并 VS Code 打开
  • Netty源码解析1-Buffer
  • Python socket服务器端、客户端传送信息
  • React 快速上手 - 07 前端路由 react-router
  • REST架构的思考
  • SAP云平台运行环境Cloud Foundry和Neo的区别
  • 对话 CTO〡听神策数据 CTO 曹犟描绘数据分析行业的无限可能
  • 基于阿里云移动推送的移动应用推送模式最佳实践
  • 计算机在识别图像时“看到”了什么?
  • 算法之不定期更新(一)(2018-04-12)
  • 学习Vue.js的五个小例子
  • 新年再起“裁员潮”,“钢铁侠”马斯克要一举裁掉SpaceX 600余名员工 ...
  • !!java web学习笔记(一到五)
  • !$boo在php中什么意思,php前戏
  • #vue3 实现前端下载excel文件模板功能
  • (02)Hive SQL编译成MapReduce任务的过程
  • (3)nginx 配置(nginx.conf)
  • (C语言)深入理解指针2之野指针与传值与传址与assert断言
  • (delphi11最新学习资料) Object Pascal 学习笔记---第13章第1节 (全局数据、栈和堆)
  • (MonoGame从入门到放弃-1) MonoGame环境搭建
  • (备忘)Java Map 遍历
  • (分布式缓存)Redis持久化
  • (九)c52学习之旅-定时器
  • (六)激光线扫描-三维重建
  • (面试必看!)锁策略
  • (七)MySQL是如何将LRU链表的使用性能优化到极致的?
  • (转贴)用VML开发工作流设计器 UCML.NET工作流管理系统
  • (转载)在C#用WM_COPYDATA消息来实现两个进程之间传递数据
  • *p++,*(p++),*++p,(*p)++区别?
  • *算法训练(leetcode)第四十五天 | 101. 孤岛的总面积、102. 沉没孤岛、103. 水流问题、104. 建造最大岛屿