本文整理汇总了Golang中github.com/bketelsen/skynet.Query.FindInstances方法的典型用法代码示例。如果您正苦于以下问题:Golang Query.FindInstances方法的具体用法?Golang Query.FindInstances怎么用?Golang Query.FindInstances使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/bketelsen/skynet.Query
的用法示例。
在下文中一共展示了Query.FindInstances方法的9个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: ListInstances
func ListInstances(q *skynet.Query) {
var regFlag *bool
if *RegisteredFlag == "true" {
b := true
regFlag = &b
} else if *RegisteredFlag == "false" {
b := false
regFlag = &b
}
q.Registered = regFlag
results := q.FindInstances()
for _, instance := range results {
registered := ""
if instance.Registered {
registered = " [Registered]"
}
fmt.Println(instance.Config.ServiceAddr.IPAddress + ":" + strconv.Itoa(instance.Config.ServiceAddr.Port) + " - " + instance.Config.Name + " " + instance.Config.Version + registered)
}
}
示例2: removeFromDoozer
func (ss *SubService) removeFromDoozer() {
q := skynet.Query{
UUID: ss.UUID,
DoozerConn: ss.doozer,
}
instances := q.FindInstances()
for _, instance := range instances {
ss.doozer.Del(instance.GetConfigPath(), ss.doozer.GetCurrentRevision())
}
}
示例3: PrintTopology
func PrintTopology(q *skynet.Query) {
topology := make(map[string]map[string]map[string]map[string][]*skynet.ServiceInfo)
results := q.FindInstances()
// Build topology hash first
for _, instance := range results {
if topology[instance.Config.Region] == nil {
topology[instance.Config.Region] = make(map[string]map[string]map[string][]*skynet.ServiceInfo)
}
if topology[instance.Config.Region][instance.Config.ServiceAddr.IPAddress] == nil {
topology[instance.Config.Region][instance.Config.ServiceAddr.IPAddress] = make(map[string]map[string][]*skynet.ServiceInfo)
}
if topology[instance.Config.Region][instance.Config.ServiceAddr.IPAddress][instance.Config.Name] == nil {
topology[instance.Config.Region][instance.Config.ServiceAddr.IPAddress][instance.Config.Name] = make(map[string][]*skynet.ServiceInfo)
}
if topology[instance.Config.Region][instance.Config.ServiceAddr.IPAddress][instance.Config.Name][instance.Config.Version] == nil {
topology[instance.Config.Region][instance.Config.ServiceAddr.IPAddress][instance.Config.Name][instance.Config.Version] = make([]*skynet.ServiceInfo, 0)
}
topology[instance.Config.Region][instance.Config.ServiceAddr.IPAddress][instance.Config.Name][instance.Config.Version] = append(topology[instance.Config.Region][instance.Config.ServiceAddr.IPAddress][instance.Config.Name][instance.Config.Version], instance)
}
// Now we can print the correct heirarchy
for regionName, region := range topology {
fmt.Println("Region: " + regionName)
for hostName, host := range region {
fmt.Println("\tHost: " + hostName)
for serviceName, service := range host {
fmt.Println("\t\tService: " + serviceName)
for versionName, version := range service {
fmt.Println("\t\t\tVersion: " + versionName)
for _, instance := range version {
registered := ""
if instance.Registered {
registered = " [Registered]"
}
fmt.Println("\t\t\t\t" + instance.Config.ServiceAddr.IPAddress + ":" + strconv.Itoa(instance.Config.ServiceAddr.Port) + registered)
}
}
}
}
}
}
示例4: Unregister
func Unregister(q *skynet.Query) {
instances := filterDaemon(q.FindInstances())
for _, instance := range instances {
cladmin := client.Admin{
Instance: instance,
}
_, err := cladmin.Unregister(skynet.UnregisterRequest{})
if err != nil {
config.Log.Error(err.Error())
}
}
}
示例5: AdminStop
func AdminStop(q *skynet.Query) {
instances := q.FindInstances()
for _, instance := range instances {
cladmin := client.Admin{
Instance: instance,
}
_, err := cladmin.Stop(skynet.StopRequest{
WaitForClients: true,
})
if err != nil {
config.Log.Error(err.Error())
}
}
}
示例6: sendRPCStop
func (ss *SubService) sendRPCStop() {
q := skynet.Query{
UUID: ss.UUID,
DoozerConn: ss.doozer,
}
instances := q.FindInstances()
for _, instance := range instances {
cladmin := client.Admin{
Instance: instance,
}
cladmin.Stop(skynet.StopRequest{
WaitForClients: true,
})
}
}
示例7: cleanupDoozerEntriesForAddr
func (s *Service) cleanupDoozerEntriesForAddr(addr *skynet.BindAddr) {
if addr == nil {
return
}
q := skynet.Query{
Host: addr.IPAddress,
Port: strconv.Itoa(addr.Port),
DoozerConn: s.doozer(),
}
instances := q.FindInstances()
for _, i := range instances {
s.Log.Item("Cleaning up old doozer entry with conflicting addr " + addr.String() + "(" + i.GetConfigPath() + ")")
s.doozer().Del(i.GetConfigPath(), s.doozer().GetCurrentRevision())
}
}
示例8: Stop
func Stop(q *skynet.Query) {
cl := client.NewClient(&config)
for _, instance := range filterDaemon(q.FindInstances()) {
cdaemon := daemon.GetDaemonForService(cl, instance)
in := daemon.StopSubServiceRequest{UUID: instance.Config.UUID}
out, err := cdaemon.StopSubService(in)
if err != nil {
if strings.HasPrefix(err.Error(), "No such service UUID") {
// no daemon on the service's machine, shut it down directly
AdminStop(q)
} else {
fmt.Println(err)
}
} else {
stopTemplate.Execute(os.Stdout, out)
}
}
}
示例9: Restart
func Restart(q *skynet.Query) {
cl := client.NewClient(&config)
for _, instance := range filterDaemon(q.FindInstances()) {
cdaemon := daemon.GetDaemonForService(cl, instance)
in := daemon.RestartSubServiceRequest{UUID: instance.Config.UUID}
out, err := cdaemon.RestartSubService(in)
if err != nil {
if strings.HasPrefix(err.Error(), "No such service UUID") {
// Commented out for now, we need to determine if we want to try to restart an unmanaged instance, and support it
// no daemon on the service's machine, shut it down directly
//AdminStop(q)
} else {
fmt.Println(err)
}
} else {
restartTemplate.Execute(os.Stdout, out)
}
}
}