> ### 十一例 Zookeeper操作
~~~
package main
import (
"github.com/samuel/go-zookeeper/zk"
"time"
"fmt"
)
var conn *zk.Conn
func callback(event zk.Event) {
//fmt.Println("*******************")
//fmt.Println("path:", event.Path)
//fmt.Println("type:", event.Type.String())
//fmt.Println("state:", event.State.String())
//fmt.Println("-------------------")
}
func init() {
servers := []string{"192.168.1.170:2181", "192.168.1.171:2181", "192.168.1.172:2181"}
option := zk.WithEventCallback(callback)
var err error
if conn, _, err = zk.Connect(servers, time.Second*5, option); err != nil {
fmt.Println(err)
return
}
}
/**
path 節點
data 節點數據
flags有4種取值:
0:永久,除非手動刪除
zk.FlagEphemeral = 1:短暫,session斷開則改節點也被刪除
zk.FlagSequence = 2:會自動在節點后面添加序號
3:Ephemeral和Sequence,即,短暫且自動添加序號
*/
func zkCreate(path string, data []byte, flags int32, ) {
p, err := conn.Create(path, data, flags, zk.WorldACL(zk.PermAll))
if err != nil {
fmt.Println(err)
}
fmt.Println(p)
}
func zkGet(path string) {
b, stat, err := conn.Get(path)
if err != nil {
fmt.Println(err)
}
fmt.Println("節點數據:", string(b))
fmt.Println("節點信息", stat.Czxid, stat.Version)
}
func zkGetChildren(path string) {
b, stat, err := conn.Children(path)
if err != nil {
fmt.Println(err)
}
fmt.Println("節點數據:", b)
fmt.Println("節點信息", stat.Czxid, stat.Version)
}
func zkSet(path string, data []byte) {
_, stat, err := conn.Get(path)
if err != nil {
fmt.Println(err)
}
stat, err = conn.Set(path, data, stat.Version)
if err != nil {
fmt.Println(err)
}
fmt.Println(stat)
}
func zkDelete(path string, version int32) {
if version == -1 {
_, stat, err := conn.Get(path)
if err != nil {
fmt.Println(err)
}
version = stat.Version
}
if err := conn.Delete(path, version); err != nil {
fmt.Println(path, err)
} else {
fmt.Println("Delete OK")
}
}
func zkListenOne(path string) {
//調用conn.ExistsW(path) 或GetW(path)為對應節點設置監聽,該監聽只生效一次
_, _, _, err := conn.ExistsW(path)
if err != nil {
fmt.Println(err)
return
}
}
func zkListenOneChannel(path string) {
_, _, ch, err := conn.ExistsW(path)
if err != nil {
fmt.Println(err)
return
}
go func() {
event := <-ch
fmt.Println("*******************")
fmt.Println("path:", event.Path)
fmt.Println("type:", event.Type.String())
fmt.Println("state:", event.State.String())
fmt.Println("-------------------")
}()
}
func main() {
//TODO : 監聽事件(只生效一次)
//zkListenOne("/data")
//TODO : 創建節點
zkCreate("/data", []byte("123"), 0)
zkCreate("/data/u1", []byte("123"), 2)
zkCreate("/data/u1", []byte("123"), 2)
zkCreate("/data/u1", []byte("123"), 2)
zkCreate("/data/u1", []byte("123"), 2)
time.Sleep(time.Second * 100)
//time.Sleep(time.Second * 60)
//TODO : 往節點添加數據
//zkSet("/data/4", []byte("b3"))
//TODO : 開啟一個協程處理chanel中傳來的event事件
//zkListenOneChannel("/data")
//TODO : 刪除節點
//zkDelete("/data", -1)
//TODO : 獲取節點數據
//zkGet("/data")
//TODO : 獲取子節點
//zkGetChildren("/data")
//zkDeleteAll("/")
}
func zkDeleteAll(path string) {
b, _, _, err := conn.ChildrenW(path)
if err != nil {
return
}
for _, v := range b {
zkDeleteAll2(path + v)
zkDelete(path+v, -1)
}
}
func zkDeleteAll2(path string) {
b, _, _, err := conn.ChildrenW(path)
if err != nil {
return
}
for _, v := range b {
zkDeleteAll2(path + "/" + v)
zkDelete(path+"/"+v, -1)
}
}
~~~
- 第一例 留言板
- 第二例 gRPC使用例子
- 第三例 基于go-micro做服務注冊和服務發現
- 第四例 聊天室
- 第五例 工具庫 第五例 并發安全字典
- dao
- common
- common.go
- config
- config.go
- gorm
- grom.go
- sqlx
- sqlx.go
- kafka
- kafka.go
- log
- log.go
- log2.go
- redis
- redis.go
- zookeeper
- zookeeper.go
- init
- main.go
- 第六例 原生sql操作
- 第七例 sqlx操作
- 第八例 Redis數據庫(gomodule/redigo)
- 第九例 Redis消息隊列
- 第十例 Redis集群連接
- 第十一例 Zookeeper操作
- 第十二例 Kafka操作
- 第十三例 NSQ操作
- 第十四例 二分查找
- 第十五例 交換排序 - 冒泡排序
- 第十六例 插入排序 - 直接插入排序
- 第十七例 插入排序 - 希爾排序
- 第十八例 交換排序 - 快速排序
- 第十九例 算法求解應用
- 第二十例 pprof性能分析
- 第二一例 CPU信息采集
- 第二二例 Heap信息采集
- 第二三例 Http信息采集
- 第二四例 單元測試(功能測試)
- 第二五例 基準測試(壓力測試/性能測試)
- 第二六例 gdb調試
- 第二七例 json序列化和反序列化
- 第二八例 protobuf序列化和反序列化
- 第二九例 包管理工具 go vendor
- 第三十例 包管理工具 go mod
- 第三一例 zip壓縮
- 第三二例 交叉編譯
- 第三三例 線上環境部署
- 第三四例 業務:實現固定周期維護
- 第三五例 聊天室(精簡版)
- 第三六例 并發安全字典
- 第三七例 導出Excel表格
- 第三八例 導出CSV表格
- 第三九例 聊天室(高并發)
- 第四十例 JWT (Json Web Token)
- 第四一例 雪花算法生成 Id
- 第四二例 對稱加密 AES
- 第四三例 非對稱加密 RSA
- 第四四例 簽名算法 SHA1
- 第四五例 數據庫操作 gorm
- 第四六例 數據庫操作 gorm 集合
- 數據庫連接和創建表
- 查詢 - 分頁
- 查詢所有數據
- 查詢單條數據
- 插入一條或多條數據
- 更新一條或多條數據
- 更新一條或多條數據(有零值)
- 第四七例 RSA(MD5WithRSA 算法)簽名和驗簽方式
- 第四八例 線上部署腳本
- 第四九例 Elasticsearch
- 第五十例 對象池
- 第五十一例 相關閱讀