mirror of https://github.com/hashicorp/consul
consul/state: add function for returning all nodes
parent
8671c5f80b
commit
66b3250e55
|
@ -99,6 +99,26 @@ func (s *StateStore) GetNode(id string) (*structs.Node, error) {
|
||||||
return nil, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Nodes is used to return all of the known nodes.
|
||||||
|
func (s *StateStore) Nodes() (structs.Nodes, error) {
|
||||||
|
tx := s.db.Txn(false)
|
||||||
|
defer tx.Abort()
|
||||||
|
|
||||||
|
// Retrieve all of the nodes
|
||||||
|
nodes, err := tx.Get("nodes", "id")
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("failed nodes lookup: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create and return the nodes list.
|
||||||
|
// TODO: Optimize by returning an iterator.
|
||||||
|
var results structs.Nodes
|
||||||
|
for node := nodes.Next(); node != nil; node = nodes.Next() {
|
||||||
|
results = append(results, node.(*structs.Node))
|
||||||
|
}
|
||||||
|
return results, nil
|
||||||
|
}
|
||||||
|
|
||||||
// EnsureService is called to upsert creation of a given NodeService.
|
// EnsureService is called to upsert creation of a given NodeService.
|
||||||
func (s *StateStore) EnsureService(idx uint64, node string, svc *structs.NodeService) error {
|
func (s *StateStore) EnsureService(idx uint64, node string, svc *structs.NodeService) error {
|
||||||
tx := s.db.Txn(true)
|
tx := s.db.Txn(true)
|
||||||
|
@ -174,7 +194,7 @@ func (s *StateStore) NodeServices(nodeID string) (*structs.NodeServices, error)
|
||||||
|
|
||||||
// Initialize the node services struct
|
// Initialize the node services struct
|
||||||
ns := &structs.NodeServices{
|
ns := &structs.NodeServices{
|
||||||
Node: *node,
|
Node: node,
|
||||||
Services: make(map[string]*structs.NodeService),
|
Services: make(map[string]*structs.NodeService),
|
||||||
}
|
}
|
||||||
ns.CreateIndex = node.CreateIndex
|
ns.CreateIndex = node.CreateIndex
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package state
|
package state
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"reflect"
|
"reflect"
|
||||||
"testing"
|
"testing"
|
||||||
|
@ -84,6 +85,45 @@ func TestStateStore_EnsureNode_GetNode(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestStateStore_GetNodes(t *testing.T) {
|
||||||
|
s := testStateStore(t)
|
||||||
|
|
||||||
|
// Create some nodes in the state store
|
||||||
|
nodes := []*structs.Node{
|
||||||
|
&structs.Node{Node: "node0", Address: "1.1.1.0"},
|
||||||
|
&structs.Node{Node: "node1", Address: "1.1.1.1"},
|
||||||
|
&structs.Node{Node: "node2", Address: "1.1.1.2"},
|
||||||
|
}
|
||||||
|
for i, node := range nodes {
|
||||||
|
if err := s.EnsureNode(uint64(i), node); err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Retrieve the nodes
|
||||||
|
out, err := s.Nodes()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// All nodes were returned
|
||||||
|
if n := len(out); n != 3 {
|
||||||
|
t.Fatalf("bad node count: %d", n)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Make sure the nodes match
|
||||||
|
for i, node := range nodes {
|
||||||
|
if node.CreateIndex != uint64(i) || node.ModifyIndex != uint64(i) {
|
||||||
|
t.Fatalf("bad node index: %d, %d", node.CreateIndex, node.ModifyIndex)
|
||||||
|
}
|
||||||
|
name := fmt.Sprintf("node%d", i)
|
||||||
|
addr := fmt.Sprintf("1.1.1.%d", i)
|
||||||
|
if node.Node != name || node.Address != addr {
|
||||||
|
t.Fatalf("bad: %#v", node)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestStateStore_EnsureService_NodeServices(t *testing.T) {
|
func TestStateStore_EnsureService_NodeServices(t *testing.T) {
|
||||||
s := testStateStore(t)
|
s := testStateStore(t)
|
||||||
|
|
||||||
|
|
|
@ -17,9 +17,9 @@ var (
|
||||||
|
|
||||||
type MessageType uint8
|
type MessageType uint8
|
||||||
|
|
||||||
// Index is used to track the index used while creating
|
// RaftIndex is used to track the index used while creating
|
||||||
// or modifying a given struct type.
|
// or modifying a given struct type.
|
||||||
type Index struct {
|
type RaftIndex struct {
|
||||||
CreateIndex uint64
|
CreateIndex uint64
|
||||||
ModifyIndex uint64
|
ModifyIndex uint64
|
||||||
}
|
}
|
||||||
|
@ -232,9 +232,9 @@ type Node struct {
|
||||||
Node string
|
Node string
|
||||||
Address string
|
Address string
|
||||||
|
|
||||||
Index
|
RaftIndex
|
||||||
}
|
}
|
||||||
type Nodes []Node
|
type Nodes []*Node
|
||||||
|
|
||||||
// Used to return information about a provided services.
|
// Used to return information about a provided services.
|
||||||
// Maps service name to available tags
|
// Maps service name to available tags
|
||||||
|
@ -250,9 +250,9 @@ type ServiceNode struct {
|
||||||
ServiceAddress string
|
ServiceAddress string
|
||||||
ServicePort int
|
ServicePort int
|
||||||
|
|
||||||
Index
|
RaftIndex
|
||||||
}
|
}
|
||||||
type ServiceNodes []ServiceNode
|
type ServiceNodes []*ServiceNode
|
||||||
|
|
||||||
// NodeService is a service provided by a node
|
// NodeService is a service provided by a node
|
||||||
type NodeService struct {
|
type NodeService struct {
|
||||||
|
@ -267,10 +267,10 @@ type NodeService struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
type NodeServices struct {
|
type NodeServices struct {
|
||||||
Node Node
|
Node *Node
|
||||||
Services map[string]*NodeService
|
Services map[string]*NodeService
|
||||||
|
|
||||||
Index
|
RaftIndex
|
||||||
}
|
}
|
||||||
|
|
||||||
// HealthCheck represents a single check on a given node
|
// HealthCheck represents a single check on a given node
|
||||||
|
|
Loading…
Reference in New Issue