51 lines
911 B
Go
51 lines
911 B
Go
|
|
package zooKeeperMgr
|
|||
|
|
|
|||
|
|
import (
|
|||
|
|
"fmt"
|
|||
|
|
"strings"
|
|||
|
|
|
|||
|
|
"github.com/samuel/go-zookeeper/zk"
|
|||
|
|
)
|
|||
|
|
|
|||
|
|
// 级联创建path节点(如果中间节点不存在,则创建)
|
|||
|
|
func CascadeCreate(conn *zk.Conn, path string) error {
|
|||
|
|
if path == "" {
|
|||
|
|
return nil
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
subPathArr := strings.Split(path, "/")
|
|||
|
|
path = ""
|
|||
|
|
var data = []byte("")
|
|||
|
|
var flags int32 = 0
|
|||
|
|
var acls = zk.WorldACL(zk.PermAll)
|
|||
|
|
|
|||
|
|
for i := 0; i < len(subPathArr); i++ {
|
|||
|
|
// Omit the first one which is /
|
|||
|
|
if subPathArr[i] == "" {
|
|||
|
|
continue
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
path += fmt.Sprintf("/%s",subPathArr[i])
|
|||
|
|
fmt.Printf("Path:%s\n",path)
|
|||
|
|
exists, _, err := conn.Exists(path)
|
|||
|
|
if err != nil {
|
|||
|
|
return err
|
|||
|
|
}
|
|||
|
|
if exists {
|
|||
|
|
continue
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
retPath, err := conn.Create(path, data, flags, acls)
|
|||
|
|
if err != nil {
|
|||
|
|
if err == zk.ErrNodeExists {
|
|||
|
|
fmt.Println(err)
|
|||
|
|
continue
|
|||
|
|
}
|
|||
|
|
return err
|
|||
|
|
}
|
|||
|
|
fmt.Printf("ZooKeeper created:%s\n", retPath)
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
return nil
|
|||
|
|
}
|