forked from Terry-Mao/gopush-cluster
-
Notifications
You must be signed in to change notification settings - Fork 0
/
zk.go
49 lines (42 loc) · 1.66 KB
/
zk.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
// Copyright © 2014 Terry Mao, LiuDing All rights reserved.
// This file is part of gopush-cluster.
// gopush-cluster is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
// gopush-cluster is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
// You should have received a copy of the GNU General Public License
// along with gopush-cluster. If not, see <http://www.gnu.org/licenses/>.
// github.com/samuel/go-zookeeper
// Copyright (c) 2013, Samuel Stauffer <samuel@descolada.com>
// All rights reserved.
package main
import (
myzk "github.com/Terry-Mao/gopush-cluster/zk"
"github.com/golang/glog"
"github.com/samuel/go-zookeeper/zk"
"strings"
)
// InitZK create zookeeper root path, and register a temp node.
func InitZK() (*zk.Conn, error) {
conn, err := myzk.Connect(Conf.ZookeeperAddr, Conf.ZookeeperTimeout)
if err != nil {
glog.Errorf("zk.Connect() error(%v)", err)
return nil, err
}
if err = myzk.Create(conn, Conf.ZookeeperPath); err != nil {
glog.Errorf("zk.Create() error(%v)", err)
return conn, err
}
data := strings.Join(Conf.Addr, ",")
glog.V(1).Infof("zk data: \"%s\"", data)
// tcp, websocket and rpc bind address store in the zk
if err = myzk.RegisterTemp(conn, Conf.ZookeeperPath, data); err != nil {
glog.Errorf("zk.RegisterTemp() error(%v)", err)
return conn, err
}
return conn, nil
}