config/main: Re-write config files - add to new config v3
- New config format.
```
{
"version": "3",
"address": ":9000",
"backend": {
"type": "fs",
"disk": "/path"
},
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
},
"console": {
"enable": true,
"level": "fatal"
}
}
}
```
New command lines in lieu of supporting XL.
Minio initialize filesystem backend.
~~~
$ minio init fs <path>
~~~
Minio initialize XL backend.
~~~
$ minio init xl <url1>...<url16>
~~~
For 'fs' backend it starts the server.
~~~
$ minio server
~~~
For 'xl' backend it waits for servers to join.
~~~
$ minio server
... [PROGRESS BAR] of servers connecting
~~~
Now on other servers execute 'join' and they connect.
~~~
....
minio join <url1> -- from <url2> && minio server
minio join <url1> -- from <url3> && minio server
...
...
minio join <url1> -- from <url16> && minio server
~~~
2016-02-12 15:27:10 -08:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
|
|
|
|
"github.com/minio/minio/pkg/probe"
|
|
|
|
"github.com/minio/minio/pkg/quick"
|
|
|
|
)
|
|
|
|
|
|
|
|
/////////////////// Config V1 ///////////////////
|
|
|
|
type configV1 struct {
|
|
|
|
Version string `json:"version"`
|
|
|
|
AccessKeyID string `json:"accessKeyId"`
|
|
|
|
SecretAccessKey string `json:"secretAccessKey"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// loadConfigV1 load config
|
|
|
|
func loadConfigV1() (*configV1, *probe.Error) {
|
|
|
|
configPath, err := getConfigPath()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err.Trace()
|
|
|
|
}
|
|
|
|
configFile := filepath.Join(configPath, "fsUsers.json")
|
|
|
|
if _, err := os.Stat(configFile); err != nil {
|
|
|
|
return nil, probe.NewError(err)
|
|
|
|
}
|
|
|
|
a := &configV1{}
|
|
|
|
a.Version = "1"
|
|
|
|
qc, err := quick.New(a)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err.Trace()
|
|
|
|
}
|
|
|
|
if err := qc.Load(configFile); err != nil {
|
|
|
|
return nil, err.Trace()
|
|
|
|
}
|
|
|
|
return qc.Data().(*configV1), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
/////////////////// Config V2 ///////////////////
|
|
|
|
type configV2 struct {
|
|
|
|
Version string `json:"version"`
|
|
|
|
Credentials struct {
|
|
|
|
AccessKeyID string `json:"accessKeyId"`
|
|
|
|
SecretAccessKey string `json:"secretAccessKey"`
|
|
|
|
Region string `json:"region"`
|
|
|
|
} `json:"credentials"`
|
|
|
|
MongoLogger struct {
|
|
|
|
Addr string `json:"addr"`
|
|
|
|
DB string `json:"db"`
|
|
|
|
Collection string `json:"collection"`
|
|
|
|
} `json:"mongoLogger"`
|
|
|
|
SyslogLogger struct {
|
|
|
|
Network string `json:"network"`
|
|
|
|
Addr string `json:"addr"`
|
|
|
|
} `json:"syslogLogger"`
|
|
|
|
FileLogger struct {
|
|
|
|
Filename string `json:"filename"`
|
|
|
|
} `json:"fileLogger"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// loadConfigV2 load config version '2'.
|
|
|
|
func loadConfigV2() (*configV2, *probe.Error) {
|
|
|
|
configFile, err := getConfigFile()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err.Trace()
|
|
|
|
}
|
|
|
|
if _, err := os.Stat(configFile); err != nil {
|
|
|
|
return nil, probe.NewError(err)
|
|
|
|
}
|
|
|
|
a := &configV2{}
|
|
|
|
a.Version = "2"
|
|
|
|
qc, err := quick.New(a)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err.Trace()
|
|
|
|
}
|
|
|
|
if err := qc.Load(configFile); err != nil {
|
|
|
|
return nil, err.Trace()
|
|
|
|
}
|
|
|
|
return qc.Data().(*configV2), nil
|
|
|
|
}
|
config: Migrate to the new version. Remove backend details.
Migrate to new config format v4.
```
{
"version": "4",
"credential": {
"accessKey": "WLGDGYAQYIGI833EV05A",
"secretKey": "BYvgJM101sHngl2uzjXS/OBF/aMxAN06JrJ3qJlF"
},
"region": "us-east-1",
"logger": {
"console": {
"enable": true,
"level": "fatal"
},
"file": {
"enable": false,
"fileName": "",
"level": "error"
},
"syslog": {
"enable": false,
"address": "",
"level": "debug"
}
}
}
```
This patch also updates [minio cli spec](./minio.md)
2016-04-01 19:19:44 -07:00
|
|
|
|
|
|
|
/////////////////// Config V3 ///////////////////
|
|
|
|
|
|
|
|
// backendV3 type.
|
|
|
|
type backendV3 struct {
|
|
|
|
Type string `json:"type"`
|
|
|
|
Disk string `json:"disk,omitempty"`
|
|
|
|
Disks []string `json:"disks,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// loggerV3 type.
|
|
|
|
type loggerV3 struct {
|
|
|
|
Console struct {
|
|
|
|
Enable bool `json:"enable"`
|
|
|
|
Level string `json:"level"`
|
|
|
|
}
|
|
|
|
File struct {
|
|
|
|
Enable bool `json:"enable"`
|
|
|
|
Filename string `json:"fileName"`
|
|
|
|
Level string `json:"level"`
|
|
|
|
}
|
|
|
|
Syslog struct {
|
|
|
|
Enable bool `json:"enable"`
|
|
|
|
Addr string `json:"address"`
|
|
|
|
Level string `json:"level"`
|
|
|
|
} `json:"syslog"`
|
|
|
|
// Add new loggers here.
|
|
|
|
}
|
|
|
|
|
|
|
|
// configV3 server configuration version '3'.
|
|
|
|
type configV3 struct {
|
|
|
|
Version string `json:"version"`
|
|
|
|
|
|
|
|
// Backend configuration.
|
|
|
|
Backend backendV3 `json:"backend"`
|
|
|
|
|
|
|
|
// http Server configuration.
|
|
|
|
Addr string `json:"address"`
|
|
|
|
|
|
|
|
// S3 API configuration.
|
|
|
|
Credential credential `json:"credential"`
|
|
|
|
Region string `json:"region"`
|
|
|
|
|
|
|
|
// Additional error logging configuration.
|
|
|
|
Logger loggerV3 `json:"logger"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// loadConfigV3 load config version '3'.
|
|
|
|
func loadConfigV3() (*configV3, *probe.Error) {
|
|
|
|
configFile, err := getConfigFile()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err.Trace()
|
|
|
|
}
|
|
|
|
if _, err := os.Stat(configFile); err != nil {
|
|
|
|
return nil, probe.NewError(err)
|
|
|
|
}
|
|
|
|
a := &configV3{}
|
|
|
|
a.Version = "3"
|
|
|
|
qc, err := quick.New(a)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err.Trace()
|
|
|
|
}
|
|
|
|
if err := qc.Load(configFile); err != nil {
|
|
|
|
return nil, err.Trace()
|
|
|
|
}
|
|
|
|
return qc.Data().(*configV3), nil
|
|
|
|
}
|