Documentation ¶
Index ¶
- Constants
- Variables
- func ErrResponse(w http.ResponseWriter, err error)
- func Warn(clusterID, msg string)
- func WarnBySpecialKey(key, msg string)
- type AdminTaskManager
- type AuthorizedVols
- type Cluster
- type ClusterService
- type DataNode
- type DataPartition
- type DataPartitionMap
- type DataReplica
- type FileCrc
- type FileInCore
- type FileMetadata
- type GetCarryNodes
- type GetMaxTotal
- type IDAllocator
- type InvalidNodeView
- type LeaderInfo
- type MasterInfo
- type MetaNode
- type MetaPartition
- type MetaReplica
- type MetadataFsm
- func (mf *MetadataFsm) Apply(command []byte, index uint64) (resp interface{}, err error)
- func (mf *MetadataFsm) ApplyMemberChange(confChange *proto.ConfChange, index uint64) (interface{}, error)
- func (mf *MetadataFsm) ApplySnapshot(peers []proto.Peer, iterator proto.SnapIterator) (err error)
- func (mf *MetadataFsm) HandleFatalEvent(err *raft.FatalError)
- func (mf *MetadataFsm) HandleLeaderChange(leader uint64)
- func (mf *MetadataFsm) Snapshot() (proto.Snapshot, error)
- type MetadataSnapshot
- type Node
- type NodeSetView
- type NodeView
- type RaftCmd
- type Server
- type SortedWeightedNodes
- type TopologyView
- type User
- type UserPermission
- type UserService
- type UserStatistical
- type UserUseSpace
- type Vol
- type VolVarargs
- type VolumeService
- type WarnMessage
- type Zone
- type ZoneView
Constants ¶
const ( // the maximum number of tasks that can be handled each time MaxTaskNum = 30 TaskWorkerInterval = time.Second * time.Duration(2) )
const
const ( TypeMetaPartion uint32 = 0x01 TypeDataPartion uint32 = 0x02 )
const ( LRUCacheSize = 3 << 30 WriteBufferSize = 4 * util.MB )
const ( EmptyCrcValue uint32 = 4045511210 DefaultZoneName = proto.DefaultZoneName )
const ( StatPeriod = time.Minute * time.Duration(1) MetricDataNodesUsedGB = "dataNodes_used_GB" MetricDataNodesTotalGB = "dataNodes_total_GB" MetricDataNodesIncreasedGB = "dataNodes_increased_GB" MetricMetaNodesUsedGB = "metaNodes_used_GB" MetricMetaNodesTotalGB = "metaNodes_total_GB" MetricMetaNodesIncreasedGB = "metaNodes_increased_GB" MetricDataNodesCount = "dataNodes_count" MetricMetaNodesCount = "metaNodes_count" MetricVolCount = "vol_count" MetricVolTotalGB = "vol_total_GB" MetricVolUsedGB = "vol_used_GB" MetricVolUsageGB = "vol_usage_ratio" MetricVolMetaCount = "vol_meta_count" MetricDiskError = "disk_error" MetricDataNodesInactive = "dataNodes_inactive" MetricMetaNodesInactive = "metaNodes_inactive" )
metrics
const ( ClusterName = "clusterName" ID = "id" IP = "ip" Port = "port" LogLevel = "logLevel" WalDir = "walDir" StoreDir = "storeDir" GroupID = 1 ModuleName = "master" CfgRetainLogs = "retainLogs" DefaultRetainLogs = 20000 SecretKey = "masterServiceKey" )
configuration keys
const ( RootUserID = "root" DefaultRootPasswd = "ChubaoFSRoot" DefaultUserPassword = "ChubaoFSUser" )
const ADMIN permissionMode = permissionMode(1)
const (
NumberOfDataPartitionsToLoad = "numberOfDataPartitionsToLoad"
)
config key
const USER permissionMode = permissionMode(2)
Variables ¶
var AddrDatabase = make(map[uint64]string)
AddrDatabase is a map that stores the address of a given host (e.g., the leader)
Functions ¶
func ErrResponse ¶
func ErrResponse(w http.ResponseWriter, err error)
func WarnBySpecialKey ¶
func WarnBySpecialKey(key, msg string)
WarnBySpecialKey provides warnings when exits
Types ¶
type AdminTaskManager ¶
type AdminTaskManager struct { TaskMap map[string]*proto.AdminTask sync.RWMutex // contains filtered or unexported fields }
AdminTaskManager sends administration commands to the metaNode or dataNode.
func (*AdminTaskManager) AddTask ¶
func (sender *AdminTaskManager) AddTask(t *proto.AdminTask)
AddTask adds a new task to the task map.
func (*AdminTaskManager) DelTask ¶
func (sender *AdminTaskManager) DelTask(t *proto.AdminTask)
DelTask deletes the to-be-deleted tasks.
type AuthorizedVols ¶
type Cluster ¶
type Cluster struct { Name string BadDataPartitionIds *sync.Map BadMetaPartitionIds *sync.Map DisableAutoAllocate bool MasterSecretKey []byte // contains filtered or unexported fields }
Cluster stores all the cluster-level information.
type ClusterService ¶
type ClusterService struct {
// contains filtered or unexported fields
}
func (*ClusterService) Schema ¶
func (s *ClusterService) Schema() *graphql.Schema
type DataNode ¶
type DataNode struct { Total uint64 `json:"TotalWeight"` Used uint64 `json:"UsedWeight"` AvailableSpace uint64 ID uint64 ZoneName string `json:"Zone"` Addr string ReportTime time.Time sync.RWMutex `graphql:"-"` UsageRatio float64 // used / total space SelectedTimes uint64 // number times that this datanode has been selected as the location for a data partition. Carry float64 // carry is a factor used in cacluate the node's weight TaskManager *AdminTaskManager `graphql:"-"` DataPartitionReports []*proto.PartitionReport DataPartitionCount uint32 NodeSetID uint64 PersistenceDataPartitions []uint64 BadDisks []string ToBeOffline bool RdOnly bool MigrateLock sync.RWMutex // contains filtered or unexported fields }
DataNode stores all the information about a data node
func (*DataNode) SelectNodeForWrite ¶
func (dataNode *DataNode) SelectNodeForWrite()
SelectNodeForWrite implements "SelectNodeForWrite" in the Node interface
type DataPartition ¶
type DataPartition struct { PartitionID uint64 LastLoadedTime int64 ReplicaNum uint8 Status int8 Replicas []*DataReplica Hosts []string // host addresses Peers []proto.Peer sync.RWMutex MissingNodes map[string]int64 // key: address of the missing node, value: when the node is missing VolName string VolID uint64 OfflinePeerID uint64 FileInCoreMap map[string]*FileInCore FilesWithMissingReplica map[string]int64 // key: file name, value: last time when a missing replica is found // contains filtered or unexported fields }
DataPartition represents the structure of storing the file contents.
func (*DataPartition) ToProto ¶ added in v1.5.0
func (partition *DataPartition) ToProto(c *Cluster) *proto.DataPartitionInfo
type DataPartitionMap ¶
DataPartitionMap stores all the data partitionMap
type DataReplica ¶
type DataReplica struct { proto.DataReplica // contains filtered or unexported fields }
DataReplica represents the replica of a data partition
type FileCrc ¶
type FileCrc struct {
// contains filtered or unexported fields
}
FileCrc defines the crc of a file
type FileInCore ¶
type FileInCore struct { proto.FileInCore MetadataArray []*FileMetadata }
FileInCore define file in data partition
func (FileInCore) ToProto ¶ added in v1.5.0
func (fc FileInCore) ToProto() proto.FileInCore
type FileMetadata ¶
type FileMetadata struct { proto.FileMetadata // contains filtered or unexported fields }
FileMetadata defines the file metadata on a dataNode
func (*FileMetadata) String ¶
func (fm *FileMetadata) String() (msg string)
type GetCarryNodes ¶
type GetMaxTotal ¶
type IDAllocator ¶
type IDAllocator struct {
// contains filtered or unexported fields
}
IDAllocator generates and allocates ids
type InvalidNodeView ¶
NodeView provides the view of the data or meta node.
type LeaderInfo ¶
type LeaderInfo struct {
// contains filtered or unexported fields
}
LeaderInfo represents the leader's information
type MasterInfo ¶
type MetaNode ¶
type MetaNode struct { ID uint64 Addr string IsActive bool Sender *AdminTaskManager `graphql:"-"` ZoneName string `json:"Zone"` MaxMemAvailWeight uint64 `json:"MaxMemAvailWeight"` Total uint64 `json:"TotalWeight"` Used uint64 `json:"UsedWeight"` Ratio float64 SelectCount uint64 Carry float64 Threshold float32 ReportTime time.Time MetaPartitionCount int NodeSetID uint64 sync.RWMutex `graphql:"-"` ToBeOffline bool PersistenceMetaPartitions []uint64 RdOnly bool MigrateLock sync.RWMutex // contains filtered or unexported fields }
MetaNode defines the structure of a meta node
func (*MetaNode) SelectNodeForWrite ¶
func (metaNode *MetaNode) SelectNodeForWrite()
SelectNodeForWrite implements the Node interface
type MetaPartition ¶
type MetaPartition struct { PartitionID uint64 Start uint64 End uint64 MaxInodeID uint64 InodeCount uint64 DentryCount uint64 Replicas []*MetaReplica ReplicaNum uint8 Status int8 IsRecover bool Hosts []string Peers []proto.Peer OfflinePeerID uint64 MissNodes map[string]int64 LoadResponse []*proto.MetaPartitionLoadResponse sync.RWMutex // contains filtered or unexported fields }
MetaPartition defines the structure of a meta partition
type MetaReplica ¶
type MetaReplica struct { Addr string MaxInodeID uint64 InodeCount uint64 DentryCount uint64 ReportTime int64 Status int8 // unavailable, readOnly, readWrite IsLeader bool // contains filtered or unexported fields }
MetaReplica defines the replica of a meta partition
type MetadataFsm ¶
type MetadataFsm struct {
// contains filtered or unexported fields
}
MetadataFsm represents the finite state machine of a metadata partition
func (*MetadataFsm) Apply ¶
func (mf *MetadataFsm) Apply(command []byte, index uint64) (resp interface{}, err error)
Apply implements the interface of raft.StateMachine
func (*MetadataFsm) ApplyMemberChange ¶
func (mf *MetadataFsm) ApplyMemberChange(confChange *proto.ConfChange, index uint64) (interface{}, error)
ApplyMemberChange implements the interface of raft.StateMachine
func (*MetadataFsm) ApplySnapshot ¶
func (mf *MetadataFsm) ApplySnapshot(peers []proto.Peer, iterator proto.SnapIterator) (err error)
ApplySnapshot implements the interface of raft.StateMachine
func (*MetadataFsm) HandleFatalEvent ¶
func (mf *MetadataFsm) HandleFatalEvent(err *raft.FatalError)
HandleFatalEvent implements the interface of raft.StateMachine
func (*MetadataFsm) HandleLeaderChange ¶
func (mf *MetadataFsm) HandleLeaderChange(leader uint64)
HandleLeaderChange implements the interface of raft.StateMachine
type MetadataSnapshot ¶
type MetadataSnapshot struct {
// contains filtered or unexported fields
}
MetadataSnapshot represents the snapshot of a meta partition
func (*MetadataSnapshot) ApplyIndex ¶
func (ms *MetadataSnapshot) ApplyIndex() uint64
ApplyIndex implements the Snapshot interface
func (*MetadataSnapshot) Close ¶
func (ms *MetadataSnapshot) Close()
Close implements the Snapshot interface
func (*MetadataSnapshot) Next ¶
func (ms *MetadataSnapshot) Next() (data []byte, err error)
Next implements the Snapshot interface
type Node ¶
type Node interface { SetCarry(carry float64) SelectNodeForWrite() GetID() uint64 GetAddr() string }
Node defines an interface that needs to be implemented by weightedNode
type NodeSetView ¶
type RaftCmd ¶
RaftCmd defines the Raft commands.
type Server ¶
type Server struct {
// contains filtered or unexported fields
}
Server represents the server in a cluster
type SortedWeightedNodes ¶
type SortedWeightedNodes []*weightedNode
SortedWeightedNodes defines an array sorted by carry
func (SortedWeightedNodes) Len ¶
func (nodes SortedWeightedNodes) Len() int
func (SortedWeightedNodes) Less ¶
func (nodes SortedWeightedNodes) Less(i, j int) bool
func (SortedWeightedNodes) Swap ¶
func (nodes SortedWeightedNodes) Swap(i, j int)
type TopologyView ¶
type TopologyView struct {
Zones []*ZoneView
}
TopologyView provides the view of the topology view of the cluster
type UserPermission ¶
type UserService ¶
type UserService struct {
// contains filtered or unexported fields
}
func (*UserService) Schema ¶
func (s *UserService) Schema() *graphql.Schema
type UserStatistical ¶
type UserUseSpace ¶
type Vol ¶
type Vol struct { ID uint64 Name string Owner string OSSAccessKey string OSSSecretKey string Status uint8 Capacity uint64 // GB NeedToLowerReplica bool FollowerRead bool MetaPartitions map[uint64]*MetaPartition `graphql:"-"` // contains filtered or unexported fields }
Vol represents a set of meta partitionMap and data partitionMap
type VolVarargs ¶
type VolVarargs struct {
// contains filtered or unexported fields
}
type VolumeService ¶
type VolumeService struct {
// contains filtered or unexported fields
}
func (*VolumeService) Schema ¶
func (s *VolumeService) Schema() *graphql.Schema
type WarnMessage ¶
Source Files ¶
- admin_task_manager.go
- api_service.go
- api_service_user.go
- cluster.go
- cluster_stat.go
- cluster_task.go
- config.go
- const.go
- data_node.go
- data_partition.go
- data_partition_check.go
- data_partition_map.go
- data_replica.go
- disk_manager.go
- filecheck.go
- filecrc.go
- filemeta.go
- gapi_cluster.go
- gapi_user.go
- gapi_volume.go
- http_server.go
- id_allocator.go
- master_manager.go
- meta_node.go
- meta_partition.go
- meta_partition_manager.go
- metadata_fsm.go
- metadata_fsm_op.go
- metadata_snapshot.go
- monitor_metrics.go
- node_selector.go
- operate_util.go
- server.go
- topology.go
- user.go
- userdata_fsm_op.go
- vol.go