Documentation ¶
Index ¶
- Constants
- type AsyncTaskErrorFunc
- type MetaConfig
- type MetaConn
- type MetaPartition
- type MetaWrapper
- func (mw *MetaWrapper) AddMultipartPart_ll(path, multipartId string, partId uint16, size uint64, md5 string, inode uint64) (err error)
- func (mw *MetaWrapper) AppendExtentKey(parentInode, inode uint64, ek proto.ExtentKey, discard []proto.ExtentKey) error
- func (mw *MetaWrapper) AppendExtentKeys(inode uint64, eks []proto.ExtentKey) error
- func (mw *MetaWrapper) BatchGetXAttr(inodes []uint64, keys []string) ([]*proto.XAttrInfo, error)
- func (mw *MetaWrapper) BatchInodeGet(inodes []uint64) []*proto.InodeInfo
- func (mw *MetaWrapper) Close() error
- func (mw *MetaWrapper) Cluster() string
- func (mw *MetaWrapper) Create_ll(parentID uint64, name string, mode, uid, gid uint32, target []byte) (*proto.InodeInfo, error)
- func (mw *MetaWrapper) Delete_ll(parentID uint64, name string, isDir bool) (*proto.InodeInfo, error)
- func (mw *MetaWrapper) DentryCreate_ll(parentID uint64, name string, inode uint64, mode uint32) error
- func (mw *MetaWrapper) DentryUpdate_ll(parentID uint64, name string, inode uint64) (oldInode uint64, err error)
- func (mw *MetaWrapper) Evict(inode uint64) error
- func (mw *MetaWrapper) GetExtents(inode uint64) (gen uint64, size uint64, extents []proto.ExtentKey, err error)
- func (mw *MetaWrapper) GetMultipart_ll(path, multipartId string) (info *proto.MultipartInfo, err error)
- func (mw *MetaWrapper) GetRootIno(subdir string) (uint64, error)
- func (mw *MetaWrapper) GetSummary_ll(parentIno uint64, path string, goroutineNum int32) (proto.SummaryInfo, error)
- func (mw *MetaWrapper) InitMultipart_ll(path string, extend map[string]string) (multipartId string, err error)
- func (mw *MetaWrapper) InodeCreate_ll(mode, uid, gid uint32, target []byte) (*proto.InodeInfo, error)
- func (mw *MetaWrapper) InodeDelete_ll(inode uint64) error
- func (mw *MetaWrapper) InodeGet_ll(inode uint64) (*proto.InodeInfo, error)
- func (mw *MetaWrapper) InodeLink_ll(inode uint64) (*proto.InodeInfo, error)
- func (mw *MetaWrapper) InodeUnlink_ll(inode uint64) (*proto.InodeInfo, error)
- func (mw *MetaWrapper) Link(parentID uint64, name string, ino uint64) (*proto.InodeInfo, error)
- func (mw *MetaWrapper) ListMultipart_ll(prefix, delimiter, keyMarker string, multipartIdMarker string, ...) (sessionResponse []*proto.MultipartInfo, err error)
- func (mw *MetaWrapper) LocalIP() string
- func (mw *MetaWrapper) LookupPath(subdir string) (uint64, error)
- func (mw *MetaWrapper) Lookup_ll(parentID uint64, name string) (inode uint64, mode uint32, err error)
- func (mw *MetaWrapper) OSSSecure() (accessKey, secretKey string)
- func (mw *MetaWrapper) Owner() string
- func (mw *MetaWrapper) ReadDirOnly_ll(parentID uint64) ([]proto.Dentry, error)
- func (mw *MetaWrapper) ReadDir_ll(parentID uint64) ([]proto.Dentry, error)
- func (mw *MetaWrapper) RefreshSummary_ll(parentIno uint64, path string, goroutineNum int32) error
- func (mw *MetaWrapper) RemoveMultipart_ll(path, multipartID string) (err error)
- func (mw *MetaWrapper) Rename_ll(srcParentID uint64, srcName string, dstParentID uint64, dstName string) (err error)
- func (mw *MetaWrapper) Setattr(inode uint64, valid, mode, uid, gid uint32, atime, mtime int64) error
- func (mw *MetaWrapper) Statfs() (total, used, inodeCount uint64)
- func (mw *MetaWrapper) Truncate(inode, size uint64) error
- func (mw *MetaWrapper) UpdateSummary_ll(parentIno uint64, filesInc int64, dirsInc int64, bytesInc int64)
- func (mw *MetaWrapper) VolCreateTime() int64
- func (mw *MetaWrapper) XAttrDel_ll(inode uint64, name string) error
- func (mw *MetaWrapper) XAttrGet_ll(inode uint64, name string) (*proto.XAttrInfo, error)
- func (mw *MetaWrapper) XAttrSet_ll(inode uint64, name, value []byte) error
- func (mw *MetaWrapper) XAttrsList_ll(inode uint64) ([]string, error)
- type OSSSecure
- type Ticket
- type VolStatInfo
- type VolumeView
Constants ¶
const ( OpenRetryInterval = 5 * time.Millisecond OpenRetryLimit = 1000 )
const ( MaxSummaryGoroutineNum = 120 BatchGetBufLen = 500 BatchSize = 200 UpdateSummaryRetry = 3 )
const ( SendRetryLimit = 100 SendRetryInterval = 100 * time.Millisecond SendTimeLimit = 20 * time.Second )
const ( HostsSeparator = "," RefreshMetaPartitionsInterval = time.Minute * 5 )
const ( MaxMountRetryLimit = 5 MountRetryInterval = time.Second * 5 /* * Minimum interval of forceUpdateMetaPartitions in seconds, * i.e. only one force update request is allowed every 5 sec. */ MinForceUpdateMetaPartitionsInterval = 5 )
const (
BatchIgetRespBuf = 1000
)
const (
MaxSendToMaster = 3
)
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type AsyncTaskErrorFunc ¶
type AsyncTaskErrorFunc func(err error)
func (AsyncTaskErrorFunc) OnError ¶
func (f AsyncTaskErrorFunc) OnError(err error)
type MetaConfig ¶
type MetaConfig struct { Volume string Owner string Masters []string Authenticate bool TicketMess auth.TicketMess ValidateOwner bool OnAsyncTaskError AsyncTaskErrorFunc EnableSummary bool }
type MetaPartition ¶
type MetaPartition struct { PartitionID uint64 Start uint64 End uint64 Members []string LeaderAddr string Status int8 }
func (*MetaPartition) Copy ¶
func (mp *MetaPartition) Copy() btree.Item
func (*MetaPartition) String ¶
func (mp *MetaPartition) String() string
type MetaWrapper ¶
type MetaWrapper struct { sync.RWMutex Ticket auth.Ticket EnableSummary bool // contains filtered or unexported fields }
func NewMetaWrapper ¶
func NewMetaWrapper(config *MetaConfig) (*MetaWrapper, error)
func (*MetaWrapper) AddMultipartPart_ll ¶ added in v1.5.0
func (*MetaWrapper) AppendExtentKey ¶
func (mw *MetaWrapper) AppendExtentKey(parentInode, inode uint64, ek proto.ExtentKey, discard []proto.ExtentKey) error
Used as a callback by stream sdk
func (*MetaWrapper) AppendExtentKeys ¶ added in v1.5.0
func (mw *MetaWrapper) AppendExtentKeys(inode uint64, eks []proto.ExtentKey) error
AppendExtentKeys append multiple extent key into specified inode with single request.
func (*MetaWrapper) BatchGetXAttr ¶ added in v1.5.0
func (*MetaWrapper) BatchInodeGet ¶
func (mw *MetaWrapper) BatchInodeGet(inodes []uint64) []*proto.InodeInfo
func (*MetaWrapper) Close ¶ added in v1.5.0
func (mw *MetaWrapper) Close() error
func (*MetaWrapper) Cluster ¶
func (mw *MetaWrapper) Cluster() string
func (*MetaWrapper) Delete_ll ¶
func (mw *MetaWrapper) Delete_ll(parentID uint64, name string, isDir bool) (*proto.InodeInfo, error)
* Note that the return value of InodeInfo might be nil without error, * and the caller should make sure InodeInfo is valid before using it.
func (*MetaWrapper) DentryCreate_ll ¶ added in v1.5.0
func (*MetaWrapper) DentryUpdate_ll ¶ added in v1.5.0
func (*MetaWrapper) Evict ¶
func (mw *MetaWrapper) Evict(inode uint64) error
func (*MetaWrapper) GetExtents ¶
func (*MetaWrapper) GetMultipart_ll ¶ added in v1.5.0
func (mw *MetaWrapper) GetMultipart_ll(path, multipartId string) (info *proto.MultipartInfo, err error)
func (*MetaWrapper) GetRootIno ¶
func (mw *MetaWrapper) GetRootIno(subdir string) (uint64, error)
func (*MetaWrapper) GetSummary_ll ¶
func (mw *MetaWrapper) GetSummary_ll(parentIno uint64, path string, goroutineNum int32) (proto.SummaryInfo, error)
func (*MetaWrapper) InitMultipart_ll ¶ added in v1.5.0
func (*MetaWrapper) InodeCreate_ll ¶ added in v1.5.0
func (*MetaWrapper) InodeDelete_ll ¶ added in v1.5.0
func (mw *MetaWrapper) InodeDelete_ll(inode uint64) error
InodeDelete_ll is a low-level api that removes specified inode immediately and do not effect extent data managed by this inode.
func (*MetaWrapper) InodeGet_ll ¶
func (mw *MetaWrapper) InodeGet_ll(inode uint64) (*proto.InodeInfo, error)
func (*MetaWrapper) InodeLink_ll ¶ added in v1.5.0
func (mw *MetaWrapper) InodeLink_ll(inode uint64) (*proto.InodeInfo, error)
InodeUnlink_ll is a low-level api that makes specified inode link value +1.
func (*MetaWrapper) InodeUnlink_ll ¶ added in v1.5.0
func (mw *MetaWrapper) InodeUnlink_ll(inode uint64) (*proto.InodeInfo, error)
InodeUnlink_ll is a low-level api that makes specified inode link value -1.
func (*MetaWrapper) ListMultipart_ll ¶ added in v1.5.0
func (mw *MetaWrapper) ListMultipart_ll(prefix, delimiter, keyMarker string, multipartIdMarker string, maxUploads uint64) (sessionResponse []*proto.MultipartInfo, err error)
func (*MetaWrapper) LocalIP ¶ added in v1.4.0
func (mw *MetaWrapper) LocalIP() string
func (*MetaWrapper) LookupPath ¶
func (mw *MetaWrapper) LookupPath(subdir string) (uint64, error)
Looks up absolute path and returns the ino
func (*MetaWrapper) OSSSecure ¶ added in v1.5.0
func (mw *MetaWrapper) OSSSecure() (accessKey, secretKey string)
func (*MetaWrapper) Owner ¶
func (mw *MetaWrapper) Owner() string
func (*MetaWrapper) ReadDirOnly_ll ¶
func (mw *MetaWrapper) ReadDirOnly_ll(parentID uint64) ([]proto.Dentry, error)
func (*MetaWrapper) ReadDir_ll ¶
func (mw *MetaWrapper) ReadDir_ll(parentID uint64) ([]proto.Dentry, error)
func (*MetaWrapper) RefreshSummary_ll ¶
func (mw *MetaWrapper) RefreshSummary_ll(parentIno uint64, path string, goroutineNum int32) error
func (*MetaWrapper) RemoveMultipart_ll ¶ added in v1.5.0
func (mw *MetaWrapper) RemoveMultipart_ll(path, multipartID string) (err error)
func (*MetaWrapper) Setattr ¶
func (mw *MetaWrapper) Setattr(inode uint64, valid, mode, uid, gid uint32, atime, mtime int64) error
func (*MetaWrapper) Statfs ¶
func (mw *MetaWrapper) Statfs() (total, used, inodeCount uint64)
func (*MetaWrapper) Truncate ¶
func (mw *MetaWrapper) Truncate(inode, size uint64) error
func (*MetaWrapper) UpdateSummary_ll ¶
func (mw *MetaWrapper) UpdateSummary_ll(parentIno uint64, filesInc int64, dirsInc int64, bytesInc int64)
func (*MetaWrapper) VolCreateTime ¶
func (mw *MetaWrapper) VolCreateTime() int64
func (*MetaWrapper) XAttrDel_ll ¶ added in v1.5.0
func (mw *MetaWrapper) XAttrDel_ll(inode uint64, name string) error
XAttrDel_ll is a low-level meta api that deletes specified xattr.
func (*MetaWrapper) XAttrGet_ll ¶ added in v1.5.0
func (*MetaWrapper) XAttrSet_ll ¶ added in v1.5.0
func (mw *MetaWrapper) XAttrSet_ll(inode uint64, name, value []byte) error
func (*MetaWrapper) XAttrsList_ll ¶
func (mw *MetaWrapper) XAttrsList_ll(inode uint64) ([]string, error)
type Ticket ¶ added in v1.5.0
type Ticket struct { ID string `json:"client_id"` SessionKey string `json:"session_key"` ServiceID string `json:"service_id"` Ticket string `json:"ticket"` }
the ticket from authnode
type VolStatInfo ¶
type VolStatInfo = proto.VolStatInfo
type VolumeView ¶
type VolumeView struct { Name string Owner string MetaPartitions []*MetaPartition OSSSecure *OSSSecure CreateTime int64 }