123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 |
- package backend
- import (
- "io"
- "os"
- "strings"
- "time"
- "github.com/chrislusf/seaweedfs/weed/util/log"
- "github.com/chrislusf/seaweedfs/weed/pb/master_pb"
- "github.com/chrislusf/seaweedfs/weed/pb/volume_server_pb"
- "github.com/spf13/viper"
- )
- type BackendStorageFile interface {
- io.ReaderAt
- io.WriterAt
- Truncate(off int64) error
- io.Closer
- GetStat() (datSize int64, modTime time.Time, err error)
- Name() string
- Sync() error
- }
- type BackendStorage interface {
- ToProperties() map[string]string
- NewStorageFile(key string, tierInfo *volume_server_pb.VolumeInfo) BackendStorageFile
- CopyFile(f *os.File, attributes map[string]string, fn func(progressed int64, percentage float32) error) (key string, size int64, err error)
- DownloadFile(fileName string, key string, fn func(progressed int64, percentage float32) error) (size int64, err error)
- DeleteFile(key string) (err error)
- }
- type StringProperties interface {
- GetString(key string) string
- }
- type StorageType string
- type BackendStorageFactory interface {
- StorageType() StorageType
- BuildStorage(configuration StringProperties, configPrefix string, id string) (BackendStorage, error)
- }
- var (
- BackendStorageFactories = make(map[StorageType]BackendStorageFactory)
- BackendStorages = make(map[string]BackendStorage)
- )
- // used by master to load remote storage configurations
- func LoadConfiguration(config *viper.Viper) {
- StorageBackendPrefix := "storage.backend"
- for backendTypeName := range config.GetStringMap(StorageBackendPrefix) {
- backendStorageFactory, found := BackendStorageFactories[StorageType(backendTypeName)]
- if !found {
- log.Fatalf("backend storage type %s not found", backendTypeName)
- }
- for backendStorageId := range config.GetStringMap(StorageBackendPrefix + "." + backendTypeName) {
- if !config.GetBool(StorageBackendPrefix + "." + backendTypeName + "." + backendStorageId + ".enabled") {
- continue
- }
- backendStorage, buildErr := backendStorageFactory.BuildStorage(config,
- StorageBackendPrefix+"."+backendTypeName+"."+backendStorageId+".", backendStorageId)
- if buildErr != nil {
- log.Fatalf("fail to create backend storage %s.%s", backendTypeName, backendStorageId)
- }
- BackendStorages[backendTypeName+"."+backendStorageId] = backendStorage
- if backendStorageId == "default" {
- BackendStorages[backendTypeName] = backendStorage
- }
- }
- }
- }
- // used by volume server to receive remote storage configurations from master
- func LoadFromPbStorageBackends(storageBackends []*master_pb.StorageBackend) {
- for _, storageBackend := range storageBackends {
- backendStorageFactory, found := BackendStorageFactories[StorageType(storageBackend.Type)]
- if !found {
- log.Warnf("storage type %s not found", storageBackend.Type)
- continue
- }
- backendStorage, buildErr := backendStorageFactory.BuildStorage(newProperties(storageBackend.Properties), "", storageBackend.Id)
- if buildErr != nil {
- log.Fatalf("fail to create backend storage %s.%s", storageBackend.Type, storageBackend.Id)
- }
- BackendStorages[storageBackend.Type+"."+storageBackend.Id] = backendStorage
- if storageBackend.Id == "default" {
- BackendStorages[storageBackend.Type] = backendStorage
- }
- }
- }
- type Properties struct {
- m map[string]string
- }
- func newProperties(m map[string]string) *Properties {
- return &Properties{m: m}
- }
- func (p *Properties) GetString(key string) string {
- if v, found := p.m[key]; found {
- return v
- }
- return ""
- }
- func ToPbStorageBackends() (backends []*master_pb.StorageBackend) {
- for sName, s := range BackendStorages {
- sType, sId := BackendNameToTypeId(sName)
- if sType == "" {
- continue
- }
- backends = append(backends, &master_pb.StorageBackend{
- Type: sType,
- Id: sId,
- Properties: s.ToProperties(),
- })
- }
- return
- }
- func BackendNameToTypeId(backendName string) (backendType, backendId string) {
- parts := strings.Split(backendName, ".")
- if len(parts) == 1 {
- return backendName, "default"
- }
- if len(parts) != 2 {
- return
- }
- backendType, backendId = parts[0], parts[1]
- return
- }
|