You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kratos/pkg/naming/naming.go

57 lines
1.3 KiB

6 years ago
package naming
import (
"context"
)
// metadata common key
const (
MetaZone = "zone"
6 years ago
MetaCluster = "cluster"
MetaWeight = "weight"
MetaColor = "color"
6 years ago
)
// Instance represents a server the client connects to.
type Instance struct {
// Zone is IDC.
Zone string `json:"zone"`
6 years ago
// Env prod/pre/uat/fat1
6 years ago
Env string `json:"env"`
// AppID is mapping servicetree appid.
AppID string `json:"appid"`
// Hostname is hostname from docker.
Hostname string `json:"hostname"`
// Addrs is the adress of app instance
// format: scheme://host
Addrs []string `json:"addrs"`
// Version is publishing version.
Version string `json:"version"`
// LastTs is instance latest updated timestamp
LastTs int64 `json:"latest_timestamp"`
// Metadata is the information associated with Addr, which may be used
// to make load balancing decision.
Metadata map[string]string `json:"metadata"`
6 years ago
// Status status
Status int64
}
6 years ago
// Resolver resolve naming service
type Resolver interface {
6 years ago
Fetch(context.Context) (map[string][]*Instance, bool)
6 years ago
Watch() <-chan struct{}
Close() error
}
// Registry Register an instance and renew automatically
type Registry interface {
Register(context.Context, *Instance) (context.CancelFunc, error)
Close() error
}
// Builder resolver builder.
type Builder interface {
Build(id string) Resolver
Scheme() string
}