Go etcd初探
1.etcd集群的配置
SET IP1_2380=http://127.0.0.1:2380
SET IP1_2379=http://127.0.0.1:2379 SET IP2_2380=http://127.0.0.1:3380
SET IP2_2379=http://127.0.0.1:3379 SET IP3_2380=http://127.0.0.1:4380
SET IP3_2379=http://127.0.0.1:4379 SET SELF_2380=%IP1_2380%
SET SELF_2379=%IP1_2379% etcd -name niub1 -debug -initial-advertise-peer-urls %SELF_2380% -listen-peer-urls %SELF_2380% -listen-client-urls %SELF_2379% -advertise-client-urls %SELF_2379% -initial-cluster niub1=%IP1_2380%,niub2=%IP2_2380%,niub3=%IP3_2380%
创建3个这个脚本,分别改
SET SELF_2380=%IP1_2380%
SET SELF_2379=%IP1_2379%
2、Go测试程序代码
package main import (
"context"
"flag"
"log"
"strings"
"time" "github.com/coreos/etcd/mvcc/mvccpb" "github.com/coreos/etcd/clientv3"
) var (
addr = flag.String("addr", "127.0.0.1:2380", "etcd addr")
) func main() {
flag.Parse() addrs := strings.Split(*addr, ",") cli, err := clientv3.New(clientv3.Config{
Endpoints: addrs,
}) if nil != err {
panic(err)
} defer cli.Close() if _, err := cli.Put(context.TODO(), "haha", "{1,1,3}"); nil != err {
log.Fatal(err)
} {
resp, err := cli.Get(context.TODO(), "haha")
if nil != err {
log.Fatal(err)
}
log.Println("resp=", resp)
} go func() { timer := time.NewTimer(time.Second * )
ticker := time.NewTicker(time.Second * ) for {
select {
case <-ticker.C:
resp, _ := cli.Grant(context.TODO(), )
ctx, _ := context.WithTimeout(context.Background(), *time.Second)
cli.Put(ctx, "node1", `{"addr":"192.168.1.1:9999"}`, clientv3.WithLease(resp.ID))
case <-timer.C:
return
}
}
}() { //watch
rch := cli.Watch(context.Background(), "", clientv3.WithPrefix())
for wresp := range rch {
for _, ev := range wresp.Events {
log.Println(ev)
if ev.IsCreate() {
log.Println("IsCreate")
} else if ev.IsModify() {
log.Println("IsModify")
} else if ev.Type == mvccpb.DELETE {
log.Println("DELETE")
} else if ev.Type == mvccpb.PUT {
log.Println("PUT")
} }
}
} }
3、启动测试
启动时传入参数
Go etcd初探的更多相关文章
- etcd 分布式数据库概念初探
		
Lease(租约): 其实就是一个定时器.首先申请一个TTL=N的lease(定时器),然后创建key的时候传入该lease,那么就实现了一个定时的key. 在程序中可以定时为该lease续约,也就是 ...
 - 初探云原生应用管理(二): 为什么你必须尽快转向 Helm v3
		
系列介绍:这个系列是介绍如何用云原生技术来构建.测试.部署.和管理应用的内容专辑.做这个系列的初衷是为了推广云原生应用管理的最佳实践,以及传播开源标准和知识.在这个系列文章的开篇初探云原生应用管理(一 ...
 - 初探领域驱动设计(2)Repository在DDD中的应用
		
概述 上一篇我们算是粗略的介绍了一下DDD,我们提到了实体.值类型和领域服务,也稍微讲到了DDD中的分层结构.但这只能算是一个很简单的介绍,并且我们在上篇的末尾还留下了一些问题,其中大家讨论比较多的, ...
 - CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探
		
CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码 ...
 - 从273二手车的M站点初探js模块化编程
		
前言 这几天在看273M站点时被他们的页面交互方式所吸引,他们的首页是采用三次加载+分页的方式.也就说分为大分页和小分页两种交互.大分页就是通过分页按钮来操作,小分页是通过下拉(向下滑动)时异步加载数 ...
 - JavaScript学习(一) ——  环境搭建与JavaScript初探
		
1.开发环境搭建 本系列教程的开发工具,我们采用HBuilder. 可以去网上下载最新的版本,然后解压一下就能直接用了.学习JavaScript,环境搭建是非常简单的,或者说,只要你有一个浏览器,一个 ...
 - .NET文件并发与RabbitMQ(初探RabbitMQ)
		
本文版权归博客园和作者吴双本人共同所有.欢迎转载,转载和爬虫请注明原文地址:http://www.cnblogs.com/tdws/p/5860668.html 想必MQ这两个字母对于各位前辈们和老司 ...
 - React Native初探
		
前言 很久之前就想研究React Native了,但是一直没有落地的机会,我一直认为一个技术要有落地的场景才有研究的意义,刚好最近迎来了新的APP,在可控的范围内,我们可以在上面做任何想做的事情. P ...
 - 一次基于etcd的分布式锁自动延时失败问题的排查
		
今天在测试基于etcd的分布式锁过程中,在测试获取锁后,释放之前超出TTL时长的情况下自动延长TTL这部分功能,在延长指定key的TTL时总是返回404错误信息,在对目标KEY更新TTL时目标KEY已 ...
 
随机推荐
- HTTP协议2
			
一.响应协议 格式: (1)响应首行:HTTP协议版本,不可默认 (2)响应头信息:可以默认 响应内容是由服务器发送给浏览器的内容,浏览器会根据响应内容来显示 (3)空行: (4)响应体: 响应内容是 ...
 - leetcode笔记--水箱问题
			
类型的引用:Solution *s=new Solution(); 1.Container With Most Water Given n non-negative integers a1, a2, ...
 - JAVA自学笔记08
			
JAVA自学笔记08 1.构造方法私有,外界就不能再创建对象 2.说明书的制作过程 1)写一个工具类,在同一文件夹下,测试类需要用到工具类,系统将自动编译工具类:工具类的成员方法一般是静态的,因此在测 ...
 - 我所知道的JS调试
			
前言 任何一门语言都有对应的调试方法,也有对应的调试工具,JavaScript当然也不例外.最常用的莫过于浏览器这个调试工具了.而今天我们要讲的对于这个基础调试就不细说,我会将目前所有调试javasc ...
 - Python3 与 NetCore 基础语法对比(List、Tuple、Dict、Set专栏)
			
Jupyter最新版:https://www.cnblogs.com/dotnetcrazy/p/9155310.html 在线演示:http://nbviewer.jupyter.org/githu ...
 - python读取excel(xlrd)
			
一.安装xlrd模块: 1.mac下打开终端输入命令: pip install xlrd 2.验证安装是否成功: 在mac终端输入 python 进入python环境 然后输入 import xl ...
 - tmunx error:invalid option: status-utf8  invalid option: utf8
			
修改为:set-window-option -gq mouse off set-window-option -gq mode-mouse off set-option -gq status-utf8 ...
 - php获取客户端IP地址的方法
			
参考:https://www.cnblogs.com/rendd/p/6183094.html <?php function getip() { //strcasecmp 比较两个字符,不区分大 ...
 - Intel Fortran 调用Delphi编制的DLL
			
module link_cont interface subroutine I_FileOpenCont (ncase,ndata,lpool,xfiles) integer(kind=) :: nc ...
 - Tomcat服务器安装、配置、测试
			
Tomcat服务器安装.配置.测试(win7_64bit) 目录 1.概述 2.本文用到的工具 3.Tomcat服务器安装配置 4.Tomcat服务器简单测试 5.注意事项 >>看不清的图 ...