网站:https://github.com/coreos/etcd

一些观点:https://yq.aliyun.com/articles/11035

1.etcd是键值存储仓库,配置共享和服务发现
2.2379用于客户端通信,2380用于节点通信。
3.etcd可以集群使用,也可以单机。不支持密码认证,但可选ssl认证,最好不要走公网。
4.数据持久化

5.开机启动

/usr/local/bin/etcd --name=test123 --data-dir=/home/wyt/bin/etcd-v3.0.15-linux-amd64/data

--listen-client-urls=http://0.0.0.0:2379 --listen-peer-urls=http://0.0.0.0:2380

--advertise-client-urls=http://0.0.0.0:2379 --initial-advertise-peer-urls=http://0.0.0.0:2380

说明:

--listen-client-urls                 list of URLs to listen on for client traffic(用户客户端数据通信端口)

--listen-peer-urls                  list of URLs to listen on for peer traffic(各个etcd节点的数据通信端口,交互,选举,数据同步等)

--advertise-client-urls           list of this member's client URLs to advertise to the public(集群参数:etcd服务器之间通讯的端口)

--initial-advertise-peer-urls    list of this member's peer URLs to advertise to the rest of the cluster(集群参数)

上面是我的理解,下面摘抄自其它地方(http://www.cnblogs.com/breg/p/5728237.html):
    —data-dir 指定节点的数据存储目录,这些数据包括节点ID,集群ID,集群初始化配置,Snapshot文件,若未指定—wal-dir,还会存储WAL文件;
    —wal-dir 指定节点的was文件的存储目录,若指定了该参数,wal文件会和其他数据文件分开存储。
    —name 节点名称
    —initial-advertise-peer-urls 告知集群其他节点url.
    — listen-peer-urls 监听URL,用于与其他节点通讯
    — advertise-client-urls 告知客户端url, 也就是服务的url
    — initial-cluster-token 集群的ID
    — initial-cluster 集群中所有节点

端口映射:

iptables -t nat -A PREROUTING  -p tcp --dport 65079 -j REDIRECT --to-port 2379

iptables -t nat -A PREROUTING  -p tcp --dport 65080 -j REDIRECT --to-port 2380

6.设置键值

etcdctl set mykey "abcdefg"

etcdctl get mykey

etcdctl rm  mykey

curl -L http://192.168.8.163:2379/version

curl -L http://192.168.8.163:65079/version

7.测试命令(来自:http://debugo.com/using-etcd/?utm_source=tuicool&utm_medium=referral)

#设置一个键的值
etcdctl set /foo/bar "hello world"
hello world
#设置一个带time to live的键
etcdctl set /foo/bar "hello world" --ttl 60
hello world
#当值为"hello world"时,替换为"Goodbye world"。
etcdctl set /foo/bar "Goodbye world" --swap-with-value "hello world"
etcdctl set /foo/bar "Goodbye world" --swap-with-value "hello world"
Goodbye world
etcdctl set /foo/bar "Goodbye world" --swap-with-value "hello world"
Error: 101: Compare failed ([hello world != Goodbye world]) [7]
#仅当不存在时创建
etcdctl mk /foo/new_bar "Hello world"
Hello world
etcdctl mk /foo/new_bar "Hello world"
Error: 105: Key already exists (/foo/new_bar) [8]
#仅当存在时更新建
etcdctl update /foo/bar "hello etcd"
hello etcd
#创建一个directory node
etcdctl mkdir /foo/dir
#创建一个directory node,或者将一个file node设置成directory node
etcdctl setDir /foo/dir
#删除file node
etcdctl rm /foo/bar
#删除directory node
etcdctl rmdir /foo/dir
etcdctl rm /foo/dir --dir
#递归删除
etcdctl rm /foo/dir --recursive
#当值为"Hello world"时删除
etcdctl rm /foo/bar --with-value "Hello world"
#获得某个键的值
etcdctl get /foo/bar
hello, etcd
#获得某个键在集群内的一致性值
etcdctl get /foo/bar --consistent
hello, etcd
#获得一些扩展的元信息
etcdctl -o extended get /foo/bar
Key: /foo/bar
Created-Index: 14
Modified-Index: 14
TTL: 0
Etcd-Index: 14
Raft-Index: 5013
Raft-Term: 0 hello, etcd
#其中,索引是一个对于etcd上任何改变中唯一、单调递增的整数。这个特殊的索引反映了etcd在某个key被创建后的时间点的etcd状态机。比如此时新建一个/foo/bar1,那么该节点的created-index和modified-index为15,代表了当前etcd的最新改变。
#列出目录的内容,-p则对directory node以/结尾
etcdctl ls
/foo
etcdctl ls /foo
/foo/bar
/foo/new_bar
/foo/dir
etcdctl ls / --recursive
/foo
/foo/bar
/foo/new_bar
/foo/dir #设置监视(watch),此时该命令会一直等待并输出下一次变化。
etcdctl watch /foo/bar
hello, etcd!
#while another terminal
etcdctl update /foo/bar "hello, etcd!"
hello, etcd!
#持续监视更新
etcdctl watch /foo/bar --forever
......
#使用Ctrl+c结束
#当反生变化时执行一个应用
etcdctl exec-watch /foo/bar -- sh -c "echo hi"
hi
hi
......
#监视目录下所有节点的改变
etcdctl exec-watch --recursive /foo -- sh -c "echo hi"

8.web界面

下载工程:https://github.com/henszey/etcd-browser

修改server.js

var etcdHost = process.env.ETCD_HOST || '127.0.0.1';
var etcdPort = process.env.ETCD_PORT || 2379;
var serverPort = process.env.SERVER_PORT || 8000;

前面2个是etcd地址和数据端口,8000是提供的web端口,在浏览器上输入:http://192.168.8.xx:8000/

etcd第一集的更多相关文章

  1. NanUI for Winform 使用示例【第一集】——山寨个代码编辑器

    NanUI for Winform从昨天写博客发布到现在获得了和多朋友的关注,首先感谢大家的关注和支持!请看昨天本人的博文<NanUI for Winform发布,让Winform界面设计拥有无 ...

  2. Windows Phone开发(43):推送通知第一集——Toast推送

    原文:Windows Phone开发(43):推送通知第一集--Toast推送 好像有好几天没更新了,抱歉抱歉,最近"光荣"地失业,先是忙于寻找新去处,唉,暂时没有下文.而后又有一 ...

  3. FJUT第四周寒假作业之第一集,临时特工?(深度优先搜索)

    原网址:http://210.34.193.66:8080/vj/Contest.jsp?cid=163#P2 第一集,临时特工? TimeLimit:1000MS  MemoryLimit:128M ...

  4. k8s部署etcd数据库集群

    ⒈下载 https://github.com/etcd-io/etcd/releases ⒉解压 tar -zxvf etcd-v3.3.12-linux-amd64.tar.gz ⒊移动可执行文件及 ...

  5. etcd-v2第一集

    网站:https://github.com/coreos/etcd 一些观点:https://yq.aliyun.com/articles/11035 1.etcd是键值存储仓库,配置共享和服务发现2 ...

  6. Unity 图文重现官方教程视频 2droguelike 第一集

    初衷: 本人初学Unity,四处收集了一些视频和教材,学习和摸索了一段时间, 我发现官网教程简单易上手,只不过他是英文讲解不方便,我就想把他翻译翻译吧, 然后我又发现看视频学习要暂停回放好多遍,麻烦, ...

  7. 创芯Xilinx Microblaze 学习系列第一集

    创芯Xilinx Microblaze 学习系列第一集 Xilinx ISE Design Suite 13.2 The MicroBlaze™ embedded processor soft cor ...

  8. k8s集群部署之环境介绍与etcd数据库集群部署

    角色 IP 组件 配置 master-1 192.168.10.11 kube-apiserver kube-controller-manager kube-scheduler etcd 2c 2g ...

  9. SpringBoot第一集:入门(2020最新最易懂)

    2020最新SpringBoot第一集:入门(2020最新最易懂) 学习思路: 是什么?为什么要学,有什么用?有什么特点?简单明了的总结一句话! SpringBoot推荐开发工具: Spring To ...

随机推荐

  1. 破解Outlook数据文件密码/PST访问密码

    不少人会经常用outlook,邮件多的时候可能不定期导出一个PST文件,为安全起见,给PST文件设置访问密码,可是时间长了,难免忘记,怎么办呢?不用担心,你自己就可以解决,无论是Outlook97.O ...

  2. spring实现一对多表单的保存

    现在我已经从ios转行为java了呦吼吼吼~~~ 1.先来一张界面,项目的字段太多了,为了研究知识点我做了个潘长江版的

  3. python的断言

    assert的语法格式: assert expression 它的等价语句为: if not expression: raise AssertionError 这段代码用来检测数据类型的断言,因为 a ...

  4. WordPress使用记录

    主要记录WordPress4.7使用过程中遇到的一些问题及解决办法. 1.无法显示主题列表 问题:新的版本主题管理页面是只显示当前主题的,无法进行管理. 解决:修改php.ini文件,参考这里.

  5. Spring之实现任务调度

    现实生活中,我们经常会制定一些"任务"在什么时间完成什么事情.同样在各种的企业中也会遇到这种任务调度的需求,比如商家或者网站的月报表 之类的要在每个月的最后一天统计各种数据,备份每 ...

  6. [抓紧小长假的尾巴] 分析一个KeyFileMe

    系统 : Windows xp 程序 : keyfileme 程序下载地址 :http://pan.baidu.com/s/1qYVfvu0 要求 : 编写KeyFile 使用工具 : OD 可在看雪 ...

  7. XML代码生成器——XMLFACTORY 简介(一)

    XML代码生成器——XMLFACTORY 简介(一) 软件开发中经常要和第三方应用交互数据,特别是在银行.电信行业,这种需求更是必不可少,往往一个系统要和三五个其它系统交互数据,而数据交换的报文经常采 ...

  8. linux 查找文件与进程常用命令

    Linux的五个查找命令 1. find find是最常见和最强大的查找命令,你可以用它找到任何你想找的文件. find的使用格式如下: $ find <指定目录> <指定条件> ...

  9. css3背景图水平垂直顺时针逆时针翻转旋转

    .bgPlay{ background:url(../images/bg.jpg) no-repeat; /* background-size:auto auto || cover 代表以宽或高填满元 ...

  10. debain 8安装为知笔记(how to install wiznote in debain 8)

    刚装了debain8后想安装为知笔记,百度之后发现为知笔记原来是开源软件.代码托管在github上:https://github.com/WizTeam/WizQTClient 但是上面只有Ubunt ...