本文整理汇总了Golang中github.com/skynetservices/skynet.Query类的典型用法代码示例。如果您正苦于以下问题:Golang Query类的具体用法?Golang Query怎么用?Golang Query使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了Query类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: ListServices
func ListServices(q *skynet.Query) {
results := q.FindServices()
for _, service := range results {
fmt.Println(service)
}
}
示例2: ListRegions
func ListRegions(q *skynet.Query) {
results := q.FindRegions()
for _, region := range results {
fmt.Println(region)
}
}
示例3: ListHosts
func ListHosts(q *skynet.Query) {
results := q.FindHosts()
for _, host := range results {
fmt.Println(host)
}
}
示例4: 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)
}
}
示例5: getQueryListMux
func (im *InstanceMonitor) getQueryListMux(q *skynet.Query) (r []skynet.ServiceInfo) {
for _, s := range im.instances {
if q.ServiceMatches(s) {
r = append(r, s)
}
}
return
}
示例6: 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 {
// Prevent runtime nil pointer dereference
if instance.Config == nil {
continue
}
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)
}
}
}
}
}
}
示例7: 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())
}
}
示例8: 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())
}
}
}
示例9: ListServiceVersions
func ListServiceVersions(q *skynet.Query) {
if q.Service == "" {
fmt.Println("Service name is required")
return
}
results := q.FindServiceVersions()
for _, version := range results {
fmt.Println(version)
}
}
示例10: 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())
}
}
}
示例11: 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,
})
}
}
示例12: 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.Trace("Cleaning up old doozer entry with conflicting addr " +
addr.String() + "(" + i.GetConfigPath() + ")")
s.doozer().Del(i.GetConfigPath(), s.doozer().GetCurrentRevision())
s.doozer().Del(i.GetStatsPath(), s.doozer().GetCurrentRevision())
}
}
示例13: 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)
}
}
}
示例14: Deploy
// TODO: this should be smarter about which hosts it deploys to
func Deploy(q *skynet.Query, path string, args ...string) {
cl := client.NewClient(config)
fmt.Println("deploying " + path + " " + strings.Join(args, ""))
for _, host := range q.FindHosts() {
cdaemon := daemon.GetDaemonForHost(cl, host)
in := daemon.DeployRequest{
ServicePath: path,
Args: shellquote.Join(args...),
}
out, err := cdaemon.Deploy(in)
if err != nil {
fmt.Println(err)
return
}
deployTemplate.Execute(os.Stdout, out)
}
}
示例15: 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)
}
}
}