本文整理汇总了Golang中github.com/coreos/torus.Ring.Version方法的典型用法代码示例。如果您正苦于以下问题:Golang Ring.Version方法的具体用法?Golang Ring.Version怎么用?Golang Ring.Version使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/coreos/torus.Ring
的用法示例。
在下文中一共展示了Ring.Version方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: watchRing
func (e *Etcd) watchRing(r torus.Ring) {
ctx, cancel := context.WithCancel(e.getContext())
defer cancel()
wch := e.Client.Watch(ctx, MkKey("meta", "the-one-ring"))
for resp := range wch {
if err := resp.Err(); err != nil {
clog.Errorf("error watching ring: %s", err)
return
}
for _, ev := range resp.Events {
newRing, err := ring.Unmarshal(ev.Kv.Value)
if err != nil {
clog.Debugf("corrupted ring: %#v", ev.Kv.Value)
clog.Errorf("Failed to unmarshal ring: %s", err)
clog.Error("corrupted ring? Continuing with current ring")
continue
}
clog.Infof("got new ring")
if r.Version() == newRing.Version() {
clog.Warningf("Same ring version: %d", r.Version())
}
e.mut.RLock()
for _, x := range e.ringListeners {
x <- newRing
}
r = newRing
e.mut.RUnlock()
}
}
}
示例2: setRing
func setRing(cfg torus.Config, r torus.Ring) error {
client, err := etcdv3.New(etcdv3.Config{Endpoints: []string{cfg.MetadataAddress}, TLS: cfg.TLS})
if err != nil {
return err
}
defer client.Close()
resp, err := client.Get(context.Background(), MkKey("meta", "the-one-ring"))
if err != nil {
return err
}
if len(resp.Kvs) == 0 {
return torus.ErrNoGlobalMetadata
}
oldr, err := ring.Unmarshal(resp.Kvs[0].Value)
if err != nil {
return err
}
if oldr.Version() != r.Version()-1 {
return torus.ErrNonSequentialRing
}
b, err := r.Marshal()
if err != nil {
return err
}
_, err = client.Put(context.Background(), MkKey("meta", "the-one-ring"), string(b))
return err
}
示例3: SetRing
func (c *etcdCtx) SetRing(ring torus.Ring) error {
oldr, etcdver, err := c.getRing()
if err != nil {
return err
}
if oldr.Version() != ring.Version()-1 {
return torus.ErrNonSequentialRing
}
b, err := ring.Marshal()
if err != nil {
return err
}
key := MkKey("meta", "the-one-ring")
txn := c.etcd.Client.Txn(c.getContext()).If(
etcdv3.Compare(etcdv3.Version(key), "=", etcdver),
).Then(
etcdv3.OpPut(key, string(b)),
)
resp, err := txn.Commit()
if err != nil {
return err
}
if resp.Succeeded {
return nil
}
return torus.ErrAgain
}
示例4: SetRing
func (s *Server) SetRing(ring torus.Ring) error {
s.mut.Lock()
defer s.mut.Unlock()
if ring.Version()-1 != s.ring.Version() {
return torus.ErrNonSequentialRing
}
s.ring = ring
for _, c := range s.ringListeners {
c <- s.ring
}
return nil
}