本文整理汇总了Golang中github.com/flynn/flynn/controller/utils.HostClient类的典型用法代码示例。如果您正苦于以下问题:Golang HostClient类的具体用法?Golang HostClient怎么用?Golang HostClient使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了HostClient类的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: addHost
func (c *FakeCluster) addHost(h utils.HostClient) {
c.hosts[h.ID()] = h
for ch := range c.hostChannels {
ch <- createDiscoverdEvent(h.ID(), discoverd.EventKindUp)
}
}
示例2: NewHost
func NewHost(h utils.HostClient) *Host {
return &Host{
ID: h.ID(),
client: h,
healthy: true,
stop: make(chan struct{}),
done: make(chan struct{}),
}
}
示例3: NewHost
func NewHost(h utils.HostClient, l log15.Logger) *Host {
return &Host{
ID: h.ID(),
Tags: h.Tags(),
client: h,
healthy: true,
stop: make(chan struct{}),
done: make(chan struct{}),
logger: l,
}
}
示例4: followHost
func (s *Scheduler) followHost(h utils.HostClient) error {
if _, ok := s.hosts[h.ID()]; ok {
return nil
}
host := NewHost(h)
jobs, err := host.StreamEventsTo(s.jobEvents)
if err != nil {
return err
}
s.hosts[host.ID] = host
for _, job := range jobs {
s.handleActiveJob(&job)
}
s.triggerSyncFormations()
return nil
}
示例5: followHost
func (s *Scheduler) followHost(h utils.HostClient) {
if _, ok := s.hostStreams[h.ID()]; ok {
return
}
log := logger.New("fn", "followHost", "host.id", h.ID())
log.Info("streaming job events")
events := make(chan *host.Event)
stream, err := h.StreamEvents("all", events)
if err != nil {
log.Error("error streaming job events", "err", err)
return
}
s.hostStreams[h.ID()] = stream
log.Info("getting active jobs")
jobs, err := h.ListJobs()
if err != nil {
log.Error("error getting active jobs", "err", err)
return
}
log.Info(fmt.Sprintf("got %d active job(s) for host %s", len(jobs), h.ID()))
for _, job := range jobs {
s.handleActiveJob(&job)
}
s.triggerSyncFormations()
go func() {
for e := range events {
s.jobEvents <- e
}
// TODO: reconnect this stream unless unfollowHost was called gh#1921
log.Error("job event stream closed unexpectedly")
}()
}