rename Server to DataNode

formatting
This commit is contained in:
Chris Lu 2012-09-08 16:25:44 -07:00
parent 9bde067f16
commit 9f4630736d
10 changed files with 47 additions and 50 deletions

View file

@ -29,7 +29,7 @@ var (
chunkFolder = cmdVolume.Flag.String("dir", "/tmp", "data directory to store files") chunkFolder = cmdVolume.Flag.String("dir", "/tmp", "data directory to store files")
volumes = cmdVolume.Flag.String("volumes", "0,1-3,4", "comma-separated list of volume ids or range of ids") volumes = cmdVolume.Flag.String("volumes", "0,1-3,4", "comma-separated list of volume ids or range of ids")
publicUrl = cmdVolume.Flag.String("publicUrl", "localhost:8080", "public url to serve data read") publicUrl = cmdVolume.Flag.String("publicUrl", "localhost:8080", "public url to serve data read")
metaServer = cmdVolume.Flag.String("mserver", "localhost:9333", "master directory server to store mappings") masterNode = cmdVolume.Flag.String("mserver", "localhost:9333", "master directory server to store mappings")
vpulse = cmdVolume.Flag.Int("pulseSeconds", 5, "number of seconds between heartbeats") vpulse = cmdVolume.Flag.Int("pulseSeconds", 5, "number of seconds between heartbeats")
store *storage.Store store *storage.Store
@ -161,11 +161,11 @@ func runVolume(cmd *Command, args []string) bool {
go func() { go func() {
for { for {
store.Join(*metaServer) store.Join(*masterNode)
time.Sleep(time.Duration(float32(*vpulse*1e3)*(1+rand.Float32())) * time.Millisecond) time.Sleep(time.Duration(float32(*vpulse*1e3)*(1+rand.Float32())) * time.Millisecond)
} }
}() }()
log.Println("store joined at", *metaServer) log.Println("store joined at", *masterNode)
log.Println("Start storage service at http://127.0.0.1:"+strconv.Itoa(*vport), "public url", *publicUrl) log.Println("Start storage service at http://127.0.0.1:"+strconv.Itoa(*vport), "public url", *publicUrl)
e := http.ListenAndServe(":"+strconv.Itoa(*vport), nil) e := http.ListenAndServe(":"+strconv.Itoa(*vport), nil)

View file

@ -11,7 +11,7 @@ import (
) )
type Machine struct { type Machine struct {
Volumes []storage.VolumeInfo C1Volumes []storage.VolumeInfo
Url string //<server name/ip>[:port] Url string //<server name/ip>[:port]
PublicUrl string PublicUrl string
LastSeen int64 // unix time in seconds LastSeen int64 // unix time in seconds
@ -29,7 +29,7 @@ type Mapper struct {
} }
func NewMachine(server, publicUrl string, volumes []storage.VolumeInfo, lastSeen int64) *Machine { func NewMachine(server, publicUrl string, volumes []storage.VolumeInfo, lastSeen int64) *Machine {
return &Machine{Url: server, PublicUrl: publicUrl, Volumes: volumes, LastSeen: lastSeen} return &Machine{Url: server, PublicUrl: publicUrl, C1Volumes: volumes, LastSeen: lastSeen}
} }
func NewMapper(dirname string, filename string, volumeSizeLimit uint64, pulse int) (m *Mapper) { func NewMapper(dirname string, filename string, volumeSizeLimit uint64, pulse int) (m *Mapper) {
@ -72,7 +72,7 @@ func (m *Mapper) Get(vid storage.VolumeId) ([]*Machine, error) {
func (m *Mapper) Add(machine *Machine) { func (m *Mapper) Add(machine *Machine) {
m.Machines[machine.Url] = machine m.Machines[machine.Url] = machine
//add to vid2machine map, and Writers array //add to vid2machine map, and Writers array
for _, v := range machine.Volumes { for _, v := range machine.C1Volumes {
list := m.vid2machines[v.Id] list := m.vid2machines[v.Id]
found := false found := false
for index, entry := range list { for index, entry := range list {
@ -89,7 +89,7 @@ func (m *Mapper) Add(machine *Machine) {
} }
func (m *Mapper) remove(machine *Machine) { func (m *Mapper) remove(machine *Machine) {
delete(m.Machines, machine.Url) delete(m.Machines, machine.Url)
for _, v := range machine.Volumes { for _, v := range machine.C1Volumes {
list := m.vid2machines[v.Id] list := m.vid2machines[v.Id]
foundIndex := -1 foundIndex := -1
for index, entry := range list { for index, entry := range list {
@ -125,13 +125,13 @@ func (m *Mapper) refreshWritableVolumes() {
var writers []storage.VolumeId var writers []storage.VolumeId
for _, machine_entry := range m.Machines { for _, machine_entry := range m.Machines {
if machine_entry.LastSeen > freshThreshHold { if machine_entry.LastSeen > freshThreshHold {
for _, v := range machine_entry.Volumes { for _, v := range machine_entry.C1Volumes {
if uint64(v.Size) < m.volumeSizeLimit { if uint64(v.Size) < m.volumeSizeLimit {
writers = append(writers, v.Id) writers = append(writers, v.Id)
} }
} }
} else { } else {
log.Println("Warning! Server", machine_entry.Url, "last seen is", time.Now().Unix()-machine_entry.LastSeen, "seconds ago!") log.Println("Warning! DataNode", machine_entry.Url, "last seen is", time.Now().Unix()-machine_entry.LastSeen, "seconds ago!")
m.remove(machine_entry) m.remove(machine_entry)
} }
} }

View file

@ -37,7 +37,7 @@ func (vg *VolumeGrowth) GrowVolumeCopy(copyLevel int, topo *topology.Topology) {
picked, ret := nl.RandomlyPickN(2) picked, ret := nl.RandomlyPickN(2)
vid := topo.NextVolumeId() vid := topo.NextVolumeId()
if ret { if ret {
var servers []*topology.Server var servers []*topology.DataNode
for _, n := range picked { for _, n := range picked {
if ok, server := n.ReserveOneVolume(rand.Intn(n.FreeSpace()), vid); ok { if ok, server := n.ReserveOneVolume(rand.Intn(n.FreeSpace()), vid); ok {
servers = append(servers, server) servers = append(servers, server)
@ -54,7 +54,7 @@ func (vg *VolumeGrowth) GrowVolumeCopy(copyLevel int, topo *topology.Topology) {
picked, ret := nl.RandomlyPickN(3) picked, ret := nl.RandomlyPickN(3)
vid := topo.NextVolumeId() vid := topo.NextVolumeId()
if ret { if ret {
var servers []*topology.Server var servers []*topology.DataNode
for _, n := range picked { for _, n := range picked {
if ok, server := n.ReserveOneVolume(rand.Intn(n.FreeSpace()), vid); ok { if ok, server := n.ReserveOneVolume(rand.Intn(n.FreeSpace()), vid); ok {
servers = append(servers, server) servers = append(servers, server)
@ -86,7 +86,7 @@ func (vg *VolumeGrowth) GrowVolumeCopy(copyLevel int, topo *topology.Topology) {
} }
} }
func (vg *VolumeGrowth) Grow(vid storage.VolumeId, servers ...*topology.Server) { func (vg *VolumeGrowth) Grow(vid storage.VolumeId, servers ...*topology.DataNode) {
for _, server := range servers { for _, server := range servers {
vi := &storage.VolumeInfo{Id: vid, Size: 0} vi := &storage.VolumeInfo{Id: vid, Size: 0}
server.AddVolume(vi) server.AddVolume(vi)

View file

@ -91,7 +91,7 @@ func setup(topologyLayout string) *topology.Topology {
rackMap := rackValue.(map[string]interface{}) rackMap := rackValue.(map[string]interface{})
dc.LinkChildNode(rack) dc.LinkChildNode(rack)
for serverKey, serverValue := range rackMap { for serverKey, serverValue := range rackMap {
server := topology.NewServer(serverKey) server := topology.NewDataNode(serverKey)
serverMap := serverValue.(map[string]interface{}) serverMap := serverValue.(map[string]interface{})
rack.LinkChildNode(server) rack.LinkChildNode(server)
for _, v := range serverMap["volumes"].([]interface{}) { for _, v := range serverMap["volumes"].([]interface{}) {

View file

@ -10,7 +10,7 @@ type Node interface {
Id() NodeId Id() NodeId
String() string String() string
FreeSpace() int FreeSpace() int
ReserveOneVolume(r int, vid storage.VolumeId) (bool, *Server) ReserveOneVolume(r int, vid storage.VolumeId) (bool, *DataNode)
UpAdjustMaxVolumeCountDelta(maxVolumeCountDelta int) UpAdjustMaxVolumeCountDelta(maxVolumeCountDelta int)
UpAdjustActiveVolumeCountDelta(activeVolumeCountDelta int) UpAdjustActiveVolumeCountDelta(activeVolumeCountDelta int)
UpAdjustMaxVolumeId(vid storage.VolumeId) UpAdjustMaxVolumeId(vid storage.VolumeId)
@ -21,7 +21,7 @@ type Node interface {
LinkChildNode(node Node) LinkChildNode(node Node)
UnlinkChildNode(nodeId NodeId) UnlinkChildNode(nodeId NodeId)
IsServer() bool IsDataNode() bool
Children() map[NodeId]Node Children() map[NodeId]Node
Parent() Node Parent() Node
} }
@ -37,8 +37,8 @@ type NodeImpl struct {
nodeType string nodeType string
} }
func (n *NodeImpl) IsServer() bool { func (n *NodeImpl) IsDataNode() bool {
return n.nodeType == "Server" return n.nodeType == "DataNode"
} }
func (n *NodeImpl) IsRack() bool { func (n *NodeImpl) IsRack() bool {
return n.nodeType == "Rack" return n.nodeType == "Rack"
@ -67,9 +67,9 @@ func (n *NodeImpl) Children() map[NodeId]Node {
func (n *NodeImpl) Parent() Node { func (n *NodeImpl) Parent() Node {
return n.parent return n.parent
} }
func (n *NodeImpl) ReserveOneVolume(r int, vid storage.VolumeId) (bool, *Server) { func (n *NodeImpl) ReserveOneVolume(r int, vid storage.VolumeId) (bool, *DataNode) {
ret := false ret := false
var assignedNode *Server var assignedNode *DataNode
for _, node := range n.children { for _, node := range n.children {
freeSpace := node.FreeSpace() freeSpace := node.FreeSpace()
//fmt.Println("r =", r, ", node =", node, ", freeSpace =", freeSpace) //fmt.Println("r =", r, ", node =", node, ", freeSpace =", freeSpace)
@ -79,9 +79,9 @@ func (n *NodeImpl) ReserveOneVolume(r int, vid storage.VolumeId) (bool, *Server)
if r >= freeSpace { if r >= freeSpace {
r -= freeSpace r -= freeSpace
} else { } else {
if node.IsServer() && node.FreeSpace() > 0 { if node.IsDataNode() && node.FreeSpace() > 0 {
//fmt.Println("vid =", vid, " assigned to node =", node, ", freeSpace =", node.FreeSpace()) //fmt.Println("vid =", vid, " assigned to node =", node, ", freeSpace =", node.FreeSpace())
return true, node.(*Server) return true, node.(*DataNode)
} }
ret, assignedNode = node.ReserveOneVolume(r, vid) ret, assignedNode = node.ReserveOneVolume(r, vid)
if ret { if ret {

View file

@ -49,15 +49,15 @@ func (nl *NodeList) RandomlyPickN(n int) ([]Node, bool) {
return list[len(list)-n:], true return list[len(list)-n:], true
} }
func (nl *NodeList) ReserveOneVolume(randomVolumeIndex int, vid storage.VolumeId) (bool, *Server) { func (nl *NodeList) ReserveOneVolume(randomVolumeIndex int, vid storage.VolumeId) (bool, *DataNode) {
for _, node := range nl.nodes { for _, node := range nl.nodes {
freeSpace := node.FreeSpace() freeSpace := node.FreeSpace()
if randomVolumeIndex >= freeSpace { if randomVolumeIndex >= freeSpace {
randomVolumeIndex -= freeSpace randomVolumeIndex -= freeSpace
} else { } else {
if node.IsServer() && node.FreeSpace() > 0 { if node.IsDataNode() && node.FreeSpace() > 0 {
fmt.Println("vid =", vid, " assigned to node =", node, ", freeSpace =", node.FreeSpace()) fmt.Println("vid =", vid, " assigned to node =", node, ", freeSpace =", node.FreeSpace())
return true, node.(*Server) return true, node.(*DataNode)
} }
children := node.Children() children := node.Children()
newNodeList := NewNodeList(children, nl.except) newNodeList := NewNodeList(children, nl.except)

View file

@ -5,26 +5,23 @@ import (
"pkg/storage" "pkg/storage"
) )
type Server struct { type DataNode struct {
NodeImpl NodeImpl
volumes map[storage.VolumeId]*storage.VolumeInfo volumes map[storage.VolumeId]*storage.VolumeInfo
Ip NodeId
Port int
PublicUrl string
} }
func NewServer(id string) *Server { func NewDataNode(id string) *DataNode {
s := &Server{} s := &DataNode{}
s.id = NodeId(id) s.id = NodeId(id)
s.nodeType = "Server" s.nodeType = "DataNode"
s.volumes = make(map[storage.VolumeId]*storage.VolumeInfo) s.volumes = make(map[storage.VolumeId]*storage.VolumeInfo)
return s return s
} }
func (s *Server) CreateOneVolume(r int, vid storage.VolumeId) storage.VolumeId { func (s *DataNode) CreateOneVolume(r int, vid storage.VolumeId) storage.VolumeId {
s.AddVolume(&storage.VolumeInfo{Id: vid, Size: 32 * 1024 * 1024 * 1024}) s.AddVolume(&storage.VolumeInfo{Id: vid, Size: 32 * 1024 * 1024 * 1024})
return vid return vid
} }
func (s *Server) AddVolume(v *storage.VolumeInfo) { func (s *DataNode) AddVolume(v *storage.VolumeInfo) {
s.volumes[v.Id] = v s.volumes[v.Id] = v
s.UpAdjustActiveVolumeCountDelta(1) s.UpAdjustActiveVolumeCountDelta(1)
s.UpAdjustMaxVolumeId(v.Id) s.UpAdjustMaxVolumeId(v.Id)

View file

@ -91,7 +91,7 @@ func setup(topologyLayout string) *Topology {
rackMap := rackValue.(map[string]interface{}) rackMap := rackValue.(map[string]interface{})
dc.LinkChildNode(rack) dc.LinkChildNode(rack)
for serverKey, serverValue := range rackMap { for serverKey, serverValue := range rackMap {
server := NewServer(serverKey) server := NewDataNode(serverKey)
serverMap := serverValue.(map[string]interface{}) serverMap := serverValue.(map[string]interface{})
rack.LinkChildNode(server) rack.LinkChildNode(server)
for _, v := range serverMap["volumes"].([]interface{}) { for _, v := range serverMap["volumes"].([]interface{}) {

View file

@ -17,13 +17,13 @@ func NewTopology(id string) *Topology {
t.children = make(map[NodeId]Node) t.children = make(map[NodeId]Node)
return t return t
} }
func (t *Topology) RandomlyReserveOneVolume() (bool, *Server, storage.VolumeId) { func (t *Topology) RandomlyReserveOneVolume() (bool, *DataNode, storage.VolumeId) {
vid := t.NextVolumeId() vid := t.NextVolumeId()
ret, node := t.ReserveOneVolume(rand.Intn(t.FreeSpace()), vid) ret, node := t.ReserveOneVolume(rand.Intn(t.FreeSpace()), vid)
return ret, node, vid return ret, node, vid
} }
func (t *Topology) RandomlyReserveOneVolumeExcept(except []Node) (bool, *Server, storage.VolumeId) { func (t *Topology) RandomlyReserveOneVolumeExcept(except []Node) (bool, *DataNode, storage.VolumeId) {
freeSpace := t.FreeSpace() freeSpace := t.FreeSpace()
for _, node := range except { for _, node := range except {
freeSpace -= node.FreeSpace() freeSpace -= node.FreeSpace()