docker 部署单节点的etcd以及 常用使用命令

docker部署etcd

复制代码
$ docker run -d --name etcd-server -p 2379:2379 -p 2380:2380 quay.io/coreos/etcd:v3.5.0 /usr/local/bin/etcd -name my-etcd-1 -advertise-client-urls http://0.0.0.0:2379 -listen-client-urls http://0.0.0.0:2379 -initial-advertise-peer-urls http://0.0.0.0:2380 -listen-peer-urls http://0.0.0.0:2380 -initial-cluster my-etcd-1=http://0.0.0.0:2380
Unable to find image 'quay.io/coreos/etcd:v3.5.0' locally
v3.5.0: Pulling from coreos/etcd
6022c6b01d76: Pull complete
1d97b1ec77fc: Pull complete
99ef4b690837: Pull complete
435b7bf0967c: Pull complete
17e4a5f7c1b5: Pull complete
5b0292999756: Pull complete
Digest: sha256:28759af54acd6924b2191dc1a1d096e2fa2e219717a21b9d8edf89717db3631b
Status: Downloaded newer image for quay.io/coreos/etcd:v3.5.0
ddcbe3db8e832a366d37a75f15ed35618e82928e79d31fe9e33f39627e97c114

验证 etcd 服务

可以使用 etcdctl 命令行工具验证 etcd 服务是否正常工作。

在主机上安装 etcdctl,安装方式如下:

macos:

复制代码
$ brew install etcd

其他系统:

  1. 访问etcd的GitHub发布页面(https://github.com/etcd-io/etcd/releases)来找到你想要的版本。

  2. 下载对应版本的etcdctl二进制文件。

  3. 将下载的文件移动到你的PATH中的一个目录,例如/usr/local/bin

    下载etcdctl,替换<version>为实际版本号

    $ curl -L https://github.com/etcd-io/etcd/releases/download/v{version}/etcd-v{version}-darwin-amd64.tar.gz -o etcd-v{version}-darwin-amd64.tar.gz

    解压缩

    $ tar xzvf etcd-v{version}-darwin-amd64.tar.gz

    将etcdctl移动到/usr/local/bin目录

    $ sudo mv etcd-v{version}-darwin-amd64/etcdctl /usr/local/bin/
    替换<version>为你想要安装的etcdctl版本。

验证:

复制代码
$ etcdctl --endpoints=http://localhost:2379 endpoint health --write-out="json"

如果返回 {"endpoint":"http://localhost:2379","health":"true"},表示 etcd 服务运行正常。

常用使用命令

  1. 存储键值对

    复制代码
    etcdctl --endpoints=http://localhost:2379 put mykey "myvalue"
  2. 读取键值对

    复制代码
    etcdctl --endpoints=http://localhost:2379 get mykey
  3. 列出所有键值对

    复制代码
    etcdctl --endpoints=http://localhost:2379 get --prefix ""
  4. 删除键值对

    复制代码
    etcdctl --endpoints=http://localhost:2379 del mykey
  5. 查看 etcd 集群状态

    复制代码
    etcdctl --endpoints=http://localhost:2379 endpoint status
  6. 备份 etcd 数据

    复制代码
    etcdctl --endpoints=http://localhost:2379 snapshot save backup.db
  7. 恢复 etcd 数据

    复制代码
    etcdctl snapshot restore backup.db --data-dir /path/to/etcd/data-dir
相关推荐
时迁2479 分钟前
【k8s】k8s是怎么实现自动扩缩的
云原生·容器·kubernetes·k8s
诡异森林。3 小时前
Docker--Docker网络原理
网络·docker·容器
ALex_zry4 小时前
Docker Macvlan网络配置实战:解决“network already exists“错误
网络·docker·php
IT小辉同学4 小时前
Docker如何更换镜像源提高拉取速度
spring cloud·docker·eureka
matrixlzp5 小时前
K8S Service 原理、案例
云原生·容器·kubernetes
GnixAij6 小时前
Docker SSH端口转发
docker·ssh
angushine6 小时前
让Docker端口映射受Firewall管理而非iptables
运维·docker·容器
玄明Hanko7 小时前
生产环境到底能用Docker部署MySQL吗?
后端·mysql·docker
玄明Hanko7 小时前
Quarkus+Docker最全面完整教程:手把手搞定Java云原生
后端·docker·云原生
SimonLiu0098 小时前
清理HiNas(海纳斯) Docker日志并限制日志大小
java·docker·容器