|
@ -1,10 +1,11 @@ |
|
|
package filer |
|
|
package filer |
|
|
|
|
|
|
|
|
import ( |
|
|
import ( |
|
|
"os" |
|
|
|
|
|
|
|
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/glog" |
|
|
"github.com/chrislusf/seaweedfs/weed/glog" |
|
|
"github.com/spf13/viper" |
|
|
"github.com/spf13/viper" |
|
|
|
|
|
"os" |
|
|
|
|
|
"reflect" |
|
|
|
|
|
"strings" |
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
var ( |
|
|
var ( |
|
@ -15,28 +16,64 @@ func (f *Filer) LoadConfiguration(config *viper.Viper) { |
|
|
|
|
|
|
|
|
validateOneEnabledStore(config) |
|
|
validateOneEnabledStore(config) |
|
|
|
|
|
|
|
|
|
|
|
// load configuration for default filer store
|
|
|
|
|
|
hasDefaultStoreConfigured := false |
|
|
for _, store := range Stores { |
|
|
for _, store := range Stores { |
|
|
if config.GetBool(store.GetName() + ".enabled") { |
|
|
if config.GetBool(store.GetName() + ".enabled") { |
|
|
|
|
|
store = reflect.New(reflect.ValueOf(store).Elem().Type()).Interface().(FilerStore) |
|
|
if err := store.Initialize(config, store.GetName()+"."); err != nil { |
|
|
if err := store.Initialize(config, store.GetName()+"."); err != nil { |
|
|
glog.Fatalf("Failed to initialize store for %s: %+v", |
|
|
|
|
|
store.GetName(), err) |
|
|
|
|
|
|
|
|
glog.Fatalf("failed to initialize store for %s: %+v", store.GetName(), err) |
|
|
} |
|
|
} |
|
|
f.SetStore(store) |
|
|
f.SetStore(store) |
|
|
glog.V(0).Infof("Configure filer for %s", store.GetName()) |
|
|
|
|
|
return |
|
|
|
|
|
|
|
|
glog.V(0).Infof("configured filer for %s", store.GetName()) |
|
|
|
|
|
hasDefaultStoreConfigured = true |
|
|
|
|
|
break |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
// TODO load path-specific filer store here
|
|
|
|
|
|
// f.Store.AddPathSpecificStore(path, store)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if !hasDefaultStoreConfigured { |
|
|
println() |
|
|
println() |
|
|
println("Supported filer stores are:") |
|
|
println("Supported filer stores are:") |
|
|
for _, store := range Stores { |
|
|
for _, store := range Stores { |
|
|
println(" " + store.GetName()) |
|
|
println(" " + store.GetName()) |
|
|
} |
|
|
} |
|
|
|
|
|
os.Exit(-1) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// load path-specific filer store here
|
|
|
|
|
|
// f.Store.AddPathSpecificStore(path, store)
|
|
|
|
|
|
storeNames := make(map[string]FilerStore) |
|
|
|
|
|
for _, store := range Stores { |
|
|
|
|
|
storeNames[store.GetName()] = store |
|
|
|
|
|
} |
|
|
|
|
|
allKeys := config.AllKeys() |
|
|
|
|
|
for _, key := range allKeys { |
|
|
|
|
|
if !strings.HasSuffix(key, ".enabled") { |
|
|
|
|
|
continue |
|
|
|
|
|
} |
|
|
|
|
|
key = key[:len(key)-len(".enabled")] |
|
|
|
|
|
if !strings.Contains(key, ".") { |
|
|
|
|
|
continue |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
parts := strings.Split(key, ".") |
|
|
|
|
|
storeName, storeId := parts[0], parts[1] |
|
|
|
|
|
|
|
|
|
|
|
store := storeNames[storeName] |
|
|
|
|
|
store = reflect.New(reflect.ValueOf(store).Elem().Type()).Interface().(FilerStore) |
|
|
|
|
|
if err := store.Initialize(config, key+"."); err != nil { |
|
|
|
|
|
glog.Fatalf("Failed to initialize store for %s: %+v", key, err) |
|
|
|
|
|
} |
|
|
|
|
|
location := config.GetString(key+".location") |
|
|
|
|
|
if location == "" { |
|
|
|
|
|
glog.Errorf("path-specific filer store needs %s", key+".location") |
|
|
os.Exit(-1) |
|
|
os.Exit(-1) |
|
|
|
|
|
} |
|
|
|
|
|
f.Store.AddPathSpecificStore(location, storeId, store) |
|
|
|
|
|
|
|
|
|
|
|
glog.V(0).Infof("configure filer %s for %s", store.GetName(), location) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func validateOneEnabledStore(config *viper.Viper) { |
|
|
func validateOneEnabledStore(config *viper.Viper) { |
|
|