本文整理匯總了Golang中github.com/pulcy/gluon/service.ServiceFlags.GetClusterMembers方法的典型用法代碼示例。如果您正苦於以下問題:Golang ServiceFlags.GetClusterMembers方法的具體用法?Golang ServiceFlags.GetClusterMembers怎麽用?Golang ServiceFlags.GetClusterMembers使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/pulcy/gluon/service.ServiceFlags
的用法示例。
在下文中一共展示了ServiceFlags.GetClusterMembers方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: createFleetConf
func createFleetConf(deps service.ServiceDependencies, flags *service.ServiceFlags) (bool, error) {
proxy, err := isEtcdProxy(deps, flags)
if err != nil {
return false, maskAny(err)
}
members, err := flags.GetClusterMembers(deps.Logger)
if err != nil {
deps.Logger.Warning("GetClusterMembers failed: %v", err)
}
etcdServers := []string{}
for _, cm := range members {
if !cm.EtcdProxy {
etcdServers = append(etcdServers, fmt.Sprintf("http://%s:2379", cm.ClusterIP))
}
}
lines := []string{
"[Service]",
fmt.Sprintf("Environment=FLEET_METADATA=%s", flags.Fleet.Metadata),
fmt.Sprintf("Environment=FLEET_ETCD_SERVERS=%s", strings.Join(etcdServers, ",")),
fmt.Sprintf("Environment=FLEET_PUBLIC_IP=%s", flags.Network.ClusterIP),
fmt.Sprintf("Environment=FLEET_AGENT_TTL=%v", flags.Fleet.AgentTTL),
fmt.Sprintf("Environment=FLEET_DISABLE_ENGINE=%v", proxy || flags.Fleet.DisableEngine),
fmt.Sprintf("Environment=FLEET_DISABLE_WATCHES=%v", flags.Fleet.DisableWatches),
fmt.Sprintf("Environment=FLEET_ENGINE_RECONCILE_INTERVAL=%d", flags.Fleet.EngineReconcileInterval),
fmt.Sprintf("Environment=FLEET_TOKEN_LIMIT=%d", flags.Fleet.TokenLimit),
}
changed, err := util.UpdateFile(confPath, []byte(strings.Join(lines, "\n")), configFileMode)
return changed, maskAny(err)
}
示例2: createService
func createService(deps service.ServiceDependencies, flags *service.ServiceFlags) (bool, error) {
deps.Logger.Info("creating %s", weaveServicePath)
members, err := flags.GetClusterMembers(deps.Logger)
if err != nil {
return false, maskAny(err)
}
var peers []string
for _, m := range members {
peers = append(peers, m.PrivateHostIP)
}
name, err := getPeerName(deps, flags)
if err != nil {
return false, maskAny(err)
}
opts := struct {
Seed string
Peers string
Name string
Hostname string
}{
Seed: flags.Weave.Seed,
Peers: strings.Join(peers, " "),
Name: name,
Hostname: flags.Weave.Hostname,
}
changed, err := templates.Render(weaveServiceTmpl, weaveServicePath, opts, serviceFileMode)
return changed, maskAny(err)
}
示例3: createService
func createService(deps service.ServiceDependencies, flags *service.ServiceFlags) (bool, error) {
deps.Logger.Info("creating %s", consulServicePath)
members, err := flags.GetClusterMembers(deps.Logger)
if err != nil {
return false, maskAny(err)
}
var join []string
bootstrapExpect := 0
for _, m := range members {
if !m.EtcdProxy {
bootstrapExpect++
if m.ClusterIP != flags.Network.ClusterIP {
join = append(join, fmt.Sprintf("-retry-join %s", m.ClusterIP))
}
}
}
srv, err := isServer(members, flags)
if err != nil {
return false, maskAny(err)
}
args := fmt.Sprintf("-advertise=%s %s -client=0.0.0.0 -data-dir=/opt/consul/data", flags.Network.ClusterIP, strings.Join(join, " "))
if srv {
args = fmt.Sprintf("-server -bootstrap-expect=%d %s", bootstrapExpect, args)
}
opts := struct {
Flags string
}{
Flags: args,
}
changed, err := templates.Render(consulServiceTmpl, consulServicePath, opts, serviceFileMode)
return changed, maskAny(err)
}
示例4: createEtcdConfig
func createEtcdConfig(deps service.ServiceDependencies, flags *service.ServiceFlags) (etcdConfig, error) {
if flags.Network.ClusterIP == "" {
return etcdConfig{}, maskAny(fmt.Errorf("ClusterIP empty"))
}
members, err := flags.GetClusterMembers(deps.Logger)
if err != nil {
deps.Logger.Warning("GetClusterMembers failed: %v", err)
}
result := etcdConfig{
ClusterIP: flags.Network.ClusterIP,
}
initialCluster := []string{}
endpoints := []string{}
hosts := []string{}
clientPort := 2379
result.ClusterState = flags.Etcd.ClusterState
if result.ClusterState == "" {
result.ClusterState = "new"
}
memberIndex := 0
for index, cm := range members {
if !cm.EtcdProxy {
initialCluster = append(initialCluster, fmt.Sprintf("%s=http://%s:2380", cm.MachineID, cm.ClusterIP))
endpoints = append(endpoints, fmt.Sprintf("http://%s:%d", cm.ClusterIP, clientPort))
hosts = append(hosts, cm.ClusterIP)
}
if cm.ClusterIP == flags.Network.ClusterIP {
result.Name = cm.MachineID
result.IsProxy = cm.EtcdProxy
result.PrivateHostIP = cm.PrivateHostIP
if cm.EtcdProxy {
memberIndex = index
} else {
memberIndex = len(hosts) - 1
}
}
}
result.ListenPeerURLs = fmt.Sprintf("https://%s:2381,http://%s:2380", result.PrivateHostIP, flags.Network.ClusterIP)
result.AdvertisePeerURLs = fmt.Sprintf("https://%s:2381,http://%s:2380", result.PrivateHostIP, flags.Network.ClusterIP)
result.ListenClientURLs = fmt.Sprintf("http://0.0.0.0:%d,http://0.0.0.0:4001", clientPort)
result.AdvertiseClientURLs = fmt.Sprintf("http://%s:%d,http://%s:4001", flags.Network.ClusterIP, clientPort, flags.Network.ClusterIP)
result.InitialCluster = strings.Join(initialCluster, ",")
result.Endpoints = strings.Join(endpoints, ",")
result.Host = hosts[memberIndex%len(hosts)]
result.Port = strconv.Itoa(clientPort)
return result, nil
}
示例5: isEtcdProxy
func isEtcdProxy(deps service.ServiceDependencies, flags *service.ServiceFlags) (bool, error) {
members, err := flags.GetClusterMembers(deps.Logger)
if err != nil {
return false, maskAny(err)
}
for _, member := range members {
if member.ClusterIP == flags.Network.ClusterIP {
return member.EtcdProxy, nil
}
}
return false, nil
}
示例6: createConfig
func createConfig(deps service.ServiceDependencies, flags *service.ServiceFlags) (bool, error) {
deps.Logger.Info("creating %s", nomadConfigPath)
members, err := flags.GetClusterMembers(deps.Logger)
if err != nil {
return false, maskAny(err)
}
srv, err := isServer(members, flags)
if err != nil {
return false, maskAny(err)
}
vaultEnv, err := readVaultEnv()
if err != nil {
return false, maskAny(err)
}
vaultAddress := vaultEnv["VAULT_ADDR"]
vaultCAFile := vaultEnv["VAULT_CACERT"]
bootstrapExpect := 0
for _, m := range members {
if !m.EtcdProxy {
bootstrapExpect++
}
}
opts := struct {
AdvertiseIP string
ConsulAddress string
MetaLines []string
IsServer bool
BootstrapExpect int
HasVault bool
VaultAddress string
VaultCAFile string
}{
AdvertiseIP: flags.Network.ClusterIP,
ConsulAddress: fmt.Sprintf("%s:8500", flags.Network.ClusterIP),
IsServer: srv,
BootstrapExpect: bootstrapExpect,
HasVault: false && vaultAddress != "" && vaultCAFile != "", // Vault token is also needed before we can enable
VaultAddress: vaultAddress,
VaultCAFile: vaultCAFile,
}
metaParts := strings.Split(flags.Fleet.Metadata, ",")
for _, meta := range metaParts {
kv := strings.SplitN(meta, "=", 2)
if len(kv) == 2 {
opts.MetaLines = append(opts.MetaLines, fmt.Sprintf("\"%s\" = \"%s\"", kv[0], kv[1]))
}
}
changed, err := templates.Render(nomadConfigTmpl, nomadConfigPath, opts, configFileMode)
return changed, maskAny(err)
}
示例7: createNoProxy
// createNoProxy creates the value for the no_proxy environment variable.
func createNoProxy(deps service.ServiceDependencies, flags *service.ServiceFlags) (string, error) {
members, err := flags.GetClusterMembers(deps.Logger)
if err != nil {
return "", maskAny(err)
}
list := []string{".local", ".private"}
for _, cm := range members {
list = append(list, cm.ClusterIP)
if cm.ClusterIP != cm.PrivateHostIP {
list = append(list, cm.PrivateHostIP)
}
}
return strings.Join(list, ","), nil
}
示例8: getPeerName
func getPeerName(deps service.ServiceDependencies, flags *service.ServiceFlags) (string, error) {
members, err := flags.GetClusterMembers(deps.Logger)
if err != nil {
return "", maskAny(err)
}
for _, member := range members {
if member.ClusterIP == flags.Network.ClusterIP {
name, err := util.WeaveNameFromMachineID(member.MachineID)
if err != nil {
return "", maskAny(err)
}
return name, nil
}
}
return "", nil
}