當前位置: 首頁>>代碼示例>>Golang>>正文


Golang discovery.CreateEntries函數代碼示例

本文整理匯總了Golang中github.com/docker/swarm/discovery.CreateEntries函數的典型用法代碼示例。如果您正苦於以下問題:Golang CreateEntries函數的具體用法?Golang CreateEntries怎麽用?Golang CreateEntries使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了CreateEntries函數的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: watchOnce

// Watch the store until either there's a store error or we receive a stop request.
// Returns false if we shouldn't attempt watching the store anymore (stop request received).
func (s *Discovery) watchOnce(stopCh <-chan struct{}, watchCh <-chan []*store.KVPair, discoveryCh chan discovery.Entries, errCh chan error) bool {
	for {
		select {
		case pairs := <-watchCh:
			if pairs == nil {
				return true
			}

			log.WithField("discovery", s.backend).Debugf("Watch triggered with %d nodes", len(pairs))

			// Convert `KVPair` into `discovery.Entry`.
			addrs := make([]string, len(pairs))
			for _, pair := range pairs {
				addrs = append(addrs, string(pair.Value))
			}

			entries, err := discovery.CreateEntries(addrs)
			if err != nil {
				errCh <- err
			} else {
				discoveryCh <- entries
			}
		case <-stopCh:
			// We were requested to stop watching.
			return false
		}
	}
}
開發者ID:jiangshengwu,項目名稱:swarm,代碼行數:30,代碼來源:kv.go

示例2: fetch

func (s *Discovery) fetch() (discovery.Entries, error) {
	fileContent, err := ioutil.ReadFile(s.path)
	if err != nil {
		return nil, fmt.Errorf("failed to read '%s': %v", s.path, err)
	}
	return discovery.CreateEntries(parseFileContent(fileContent))
}
開發者ID:rkazak,項目名稱:swarm,代碼行數:7,代碼來源:file.go

示例3: Watch

// Watch is exported
func (s *Discovery) Watch(callback discovery.WatchCallback) {
	s.store.WatchRange(s.prefix, "", s.heartbeat, func(kvalues []store.KVEntry) {
		// Traduce byte array entries to discovery.Entry
		entries, _ := discovery.CreateEntries(convertToStringArray(kvalues))
		callback(entries)
	})
}
開發者ID:AlphaStaxLLC,項目名稱:libnetwork,代碼行數:8,代碼來源:kv.go

示例4: Fetch

// Fetch is exported
func (s *Discovery) Fetch() ([]*discovery.Entry, error) {
	fileContent, err := ioutil.ReadFile(s.path)
	if err != nil {
		return nil, err
	}
	return discovery.CreateEntries(parseFileContent(fileContent))
}
開發者ID:postfix,項目名稱:golib-1,代碼行數:8,代碼來源:file.go

示例5: Fetch

// Fetch is exported
func (s *Discovery) Fetch() ([]*discovery.Entry, error) {
	addrs, err := s.store.GetRange(s.prefix)
	if err != nil {
		return nil, err
	}
	return discovery.CreateEntries(convertToStringArray(addrs))
}
開發者ID:AlphaStaxLLC,項目名稱:libnetwork,代碼行數:8,代碼來源:kv.go

示例6: Fetch

func (s *FileDiscoveryService) Fetch() ([]*discovery.Entry, error) {
	data, err := ioutil.ReadFile(s.path)
	if err != nil {
		return nil, err
	}

	return discovery.CreateEntries(strings.Split(string(data), "\n"))
}
開發者ID:josephwinston,項目名稱:libswarm,代碼行數:8,代碼來源:file.go

示例7: Fetch

// Fetch is exported
func (s *Discovery) Fetch() ([]*discovery.Entry, error) {
	addrs, _, err := s.conn.Children(s.fullpath())

	if err != nil {
		return nil, err
	}

	return discovery.CreateEntries(addrs)
}
開發者ID:postfix,項目名稱:golib-1,代碼行數:10,代碼來源:zookeeper.go

示例8: Fetch

func (s *EtcdDiscoveryService) Fetch() ([]*discovery.Entry, error) {
	resp, err := s.client.Get(s.path, true, true)
	if err != nil {
		return nil, err
	}

	addrs := []string{}
	for _, n := range resp.Node.Nodes {
		addrs = append(addrs, n.Value)
	}
	return discovery.CreateEntries(addrs)
}
開發者ID:marsmensch,項目名稱:swarm,代碼行數:12,代碼來源:etcd.go

示例9: Fetch

// Fetch is exported
func (s *Discovery) Fetch() ([]*discovery.Entry, error) {
	kv := s.client.KV()
	pairs, _, err := kv.List(s.prefix, nil)
	if err != nil {
		return nil, err
	}

	addrs := []string{}
	for _, pair := range pairs {
		if pair.Key == s.prefix {
			continue
		}
		addrs = append(addrs, string(pair.Value))
	}

	return discovery.CreateEntries(addrs)
}
開發者ID:postfix,項目名稱:golib-1,代碼行數:18,代碼來源:consul.go

示例10: fetch

// Fetch returns the list of entries for the discovery service at the specified endpoint
func (s *Discovery) fetch() (discovery.Entries, error) {
	resp, err := http.Get(fmt.Sprintf("%s/%s/%s", s.url, "clusters", s.token))
	if err != nil {
		return nil, err
	}

	defer resp.Body.Close()

	var addrs []string
	if resp.StatusCode == http.StatusOK {
		if err := json.NewDecoder(resp.Body).Decode(&addrs); err != nil {
			return nil, fmt.Errorf("Failed to decode response: %v", err)
		}
	} else {
		return nil, fmt.Errorf("Failed to fetch entries, Discovery service returned %d HTTP status code", resp.StatusCode)
	}

	return discovery.CreateEntries(addrs)
}
開發者ID:waterytowers,項目名稱:global-hack-day-3,代碼行數:20,代碼來源:token.go

示例11: TestRegister

func TestRegister(t *testing.T) {
	d := &Discovery{token: "TEST_TOKEN", url: discoveryURL, heartbeat: 1}
	expected := "127.0.0.1:2675"
	expectedEntries, err := discovery.CreateEntries([]string{expected})
	assert.NoError(t, err)

	// Register
	assert.NoError(t, d.Register(expected))

	// Watch
	ch, errCh := d.Watch(nil)
	select {
	case entries := <-ch:
		assert.True(t, entries.Equals(expectedEntries))
	case err := <-errCh:
		t.Fatal(err)
	case <-time.After(5 * time.Second):
		t.Fatal("Timed out")
	}

	assert.NoError(t, d.Register(expected))
}
開發者ID:rkazak,項目名稱:swarm,代碼行數:22,代碼來源:token_test.go

示例12: fetch

// Fetch returns the list of entries for the discovery service at the specified endpoint
func (s *Discovery) fetch() (discovery.Entries, error) {
	// Here, we contact the serf agent and ask for a list of members
	// We have to send back entries, which are basically a host and a port (see discovery.go)
	output, err := exec.Command("./agent_members.sh").Output()

	if err != nil {
		return nil, err
	}

	all_lines := strings.Split(string(output[:]), "\n")
	lines := all_lines[:len(all_lines)-1]
	var addrs []string
	for _, line := range lines {
		fields := strings.Fields(line)
		fmt.Println("FIELDS %d", len(fields))
		if len(fields) != 3 {
			return nil, errors.New("Error while parsing the output of serf members : Wrong number of fields")
		}
		addrs = append(addrs, fields[1])
	}

	return discovery.CreateEntries(addrs)
}
開發者ID:adouang,項目名稱:swarm,代碼行數:24,代碼來源:serf.go

示例13: Watch

// Watch is exported
func (s *Discovery) Watch(callback discovery.WatchCallback) {

	addrs, _, eventChan, err := s.conn.ChildrenW(s.fullpath())
	if err != nil {
		log.WithField("name", "zk").Debug("Discovery watch aborted")
		return
	}
	entries, err := discovery.CreateEntries(addrs)
	if err == nil {
		callback(entries)
	}

	for e := range eventChan {
		if e.Type == zk.EventNodeChildrenChanged {
			log.WithField("name", "zk").Debug("Discovery watch triggered")
			entries, err := s.Fetch()
			if err == nil {
				callback(entries)
			}
		}

	}

}
開發者ID:postfix,項目名稱:golib-1,代碼行數:25,代碼來源:zookeeper.go


注:本文中的github.com/docker/swarm/discovery.CreateEntries函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。