Ai
1 Star 0 Fork 0

SasukeBo/go-micro

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
watcher.go 1.38 KB
一键复制 编辑 原始数据 按行查看 历史
汪波 提交于 2023-02-23 10:27 +08:00 . fix: 替换包名
package multi
import (
"sync"
"gitee.com/sasukebo/go-micro/v4/registry"
)
type multiWatcher struct {
wo registry.WatchOptions
w []registry.Watcher
next chan *registry.Result
stop chan bool
}
func newMultiWatcher(r []registry.Registry, opts ...registry.WatchOption) (registry.Watcher, error) {
var wo registry.WatchOptions
for _, o := range opts {
o(&wo)
}
mw := &multiWatcher{
wo: wo,
next: make(chan *registry.Result),
stop: make(chan bool),
}
for _, wr := range r {
w, err := wr.Watch(opts...)
if err != nil {
return nil, err
}
mw.w = append(mw.w, w)
}
return mw, nil
}
func (mw *multiWatcher) Next() (*registry.Result, error) {
cerr := make(chan error)
for _, wt := range mw.w {
go func(w registry.Watcher) {
r, err := w.Next()
if err != nil && err != registry.ErrNotFound {
cerr <- err
}
mw.next <- r
}(wt)
}
for {
select {
case err := <-cerr:
return nil, err
case r, ok := <-mw.next:
if !ok {
return nil, registry.ErrWatcherStopped
}
nr := &registry.Result{}
*nr = *r
return nr, nil
case <-mw.stop:
return nil, registry.ErrWatcherStopped
}
}
}
func (mw *multiWatcher) Stop() {
var wg sync.WaitGroup
wg.Add(len(mw.w))
for _, w := range mw.w {
go func(w registry.Watcher) {
w.Stop()
wg.Done()
}(w)
}
wg.Wait()
select {
case <-mw.stop:
return
default:
close(mw.stop)
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/sasukebo/go-micro.git
git@gitee.com:sasukebo/go-micro.git
sasukebo
go-micro
go-micro
6e18eb58b836

搜索帮助