2018-05-26 18:49:46 +08:00
|
|
|
package filer2
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/glog"
|
2018-08-20 06:18:37 +08:00
|
|
|
"github.com/spf13/viper"
|
2018-05-26 18:49:46 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
Stores []FilerStore
|
|
|
|
)
|
|
|
|
|
2018-08-20 06:17:55 +08:00
|
|
|
func (f *Filer) LoadConfiguration(config *viper.Viper) {
|
2018-05-26 18:49:46 +08:00
|
|
|
|
2018-12-06 16:44:41 +08:00
|
|
|
validateOneEnabledStore(config)
|
2018-12-06 16:32:36 +08:00
|
|
|
|
2018-05-26 18:49:46 +08:00
|
|
|
for _, store := range Stores {
|
2018-08-20 06:17:55 +08:00
|
|
|
if config.GetBool(store.GetName() + ".enabled") {
|
|
|
|
viperSub := config.Sub(store.GetName())
|
2018-05-26 18:49:46 +08:00
|
|
|
if err := store.Initialize(viperSub); err != nil {
|
|
|
|
glog.Fatalf("Failed to initialize store for %s: %+v",
|
|
|
|
store.GetName(), err)
|
|
|
|
}
|
|
|
|
f.SetStore(store)
|
2018-08-20 06:17:55 +08:00
|
|
|
glog.V(0).Infof("Configure filer for %s", store.GetName())
|
2018-05-26 18:49:46 +08:00
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
println()
|
|
|
|
println("Supported filer stores are:")
|
|
|
|
for _, store := range Stores {
|
|
|
|
println(" " + store.GetName())
|
|
|
|
}
|
|
|
|
|
|
|
|
os.Exit(-1)
|
|
|
|
}
|
2018-12-06 16:44:41 +08:00
|
|
|
|
|
|
|
func validateOneEnabledStore(config *viper.Viper) {
|
|
|
|
enabledStore := ""
|
|
|
|
for _, store := range Stores {
|
|
|
|
if config.GetBool(store.GetName() + ".enabled") {
|
|
|
|
if enabledStore == "" {
|
|
|
|
enabledStore = store.GetName()
|
|
|
|
} else {
|
|
|
|
glog.Fatalf("Filer store is enabled for both %s and %s", enabledStore, store.GetName())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|