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 18:27:10 -05:00
|
|
|
/*
|
|
|
|
* Minio Cloud Storage, (C) 2015, 2016 Minio, Inc.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2016-08-18 19:23:42 -04:00
|
|
|
package cmd
|
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 18:27:10 -05:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2016-11-11 10:18:44 -05:00
|
|
|
"io/ioutil"
|
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 18:27:10 -05:00
|
|
|
"net"
|
|
|
|
"net/http"
|
2016-10-27 06:30:52 -04:00
|
|
|
"net/url"
|
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 18:27:10 -05:00
|
|
|
"os"
|
|
|
|
"strings"
|
|
|
|
|
2016-10-28 11:45:32 -04:00
|
|
|
"regexp"
|
|
|
|
"runtime"
|
|
|
|
|
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 18:27:10 -05:00
|
|
|
"github.com/minio/cli"
|
|
|
|
)
|
|
|
|
|
2016-09-01 18:12:49 -04:00
|
|
|
var serverFlags = []cli.Flag{
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "address",
|
|
|
|
Value: ":9000",
|
2016-11-10 02:37:12 -05:00
|
|
|
Usage: `Bind to a specific IP:PORT. Defaults to ":9000".`,
|
2016-09-01 18:12:49 -04:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
var serverCmd = cli.Command{
|
|
|
|
Name: "server",
|
|
|
|
Usage: "Start object storage server.",
|
|
|
|
Flags: append(serverFlags, globalFlags...),
|
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 22:19:44 -04:00
|
|
|
Action: serverMain,
|
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 18:27:10 -05:00
|
|
|
CustomHelpTemplate: `NAME:
|
|
|
|
minio {{.Name}} - {{.Usage}}
|
|
|
|
|
|
|
|
USAGE:
|
2016-08-28 23:04:47 -04:00
|
|
|
minio {{.Name}} [FLAGS] PATH [PATH...]
|
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 18:27:10 -05:00
|
|
|
|
2016-08-28 23:04:47 -04:00
|
|
|
FLAGS:
|
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 18:27:10 -05:00
|
|
|
{{range .Flags}}{{.}}
|
|
|
|
{{end}}
|
|
|
|
ENVIRONMENT VARIABLES:
|
2016-07-10 17:38:15 -04:00
|
|
|
ACCESS:
|
2016-12-10 03:42:22 -05:00
|
|
|
MINIO_ACCESS_KEY: Custom username or access key of 5 to 20 characters in length.
|
|
|
|
MINIO_SECRET_KEY: Custom password or secret key of 8 to 40 characters in length.
|
|
|
|
|
|
|
|
BROWSER:
|
|
|
|
MINIO_BROWSER: To disable web browser access, set this value to "off".
|
2016-07-10 17:38:15 -04:00
|
|
|
|
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 18:27:10 -05:00
|
|
|
EXAMPLES:
|
2016-11-10 02:37:12 -05:00
|
|
|
1. Start minio server on "/home/shared" directory.
|
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 22:19:44 -04:00
|
|
|
$ minio {{.Name}} /home/shared
|
|
|
|
|
2016-11-10 02:37:12 -05:00
|
|
|
2. Start minio server bound to a specific IP:PORT.
|
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 22:19:44 -04:00
|
|
|
$ minio {{.Name}} --address 192.168.1.101:9000 /home/shared
|
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 18:27:10 -05:00
|
|
|
|
2016-11-10 02:37:12 -05:00
|
|
|
3. Start erasure coded minio server on a 12 disks server.
|
2016-09-01 16:29:26 -04:00
|
|
|
$ minio {{.Name}} /mnt/export1/ /mnt/export2/ /mnt/export3/ /mnt/export4/ \
|
|
|
|
/mnt/export5/ /mnt/export6/ /mnt/export7/ /mnt/export8/ /mnt/export9/ \
|
|
|
|
/mnt/export10/ /mnt/export11/ /mnt/export12/
|
2016-07-10 17:38:15 -04:00
|
|
|
|
2016-11-10 02:37:12 -05:00
|
|
|
4. Start erasure coded distributed minio server on a 4 node setup with 1 drive each. Run following commands on all the 4 nodes.
|
2016-08-18 17:29:23 -04:00
|
|
|
$ export MINIO_ACCESS_KEY=minio
|
|
|
|
$ export MINIO_SECRET_KEY=miniostorage
|
2016-10-27 06:30:52 -04:00
|
|
|
$ minio {{.Name}} http://192.168.1.11/mnt/export/ http://192.168.1.12/mnt/export/ \
|
|
|
|
http://192.168.1.13/mnt/export/ http://192.168.1.14/mnt/export/
|
|
|
|
|
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 18:27:10 -05:00
|
|
|
`,
|
|
|
|
}
|
|
|
|
|
2016-04-12 15:45:15 -04:00
|
|
|
type serverCmdConfig struct {
|
2016-11-11 19:36:07 -05:00
|
|
|
serverAddr string
|
|
|
|
endpoints []*url.URL
|
|
|
|
storageDisks []StorageAPI
|
2016-10-18 15:49:24 -04:00
|
|
|
}
|
|
|
|
|
2016-10-27 06:30:52 -04:00
|
|
|
// Parse an array of end-points (from the command line)
|
|
|
|
func parseStorageEndpoints(eps []string) (endpoints []*url.URL, err error) {
|
2016-10-18 15:49:24 -04:00
|
|
|
for _, ep := range eps {
|
|
|
|
if ep == "" {
|
2016-10-27 06:30:52 -04:00
|
|
|
return nil, errInvalidArgument
|
2016-10-18 15:49:24 -04:00
|
|
|
}
|
2016-10-27 06:30:52 -04:00
|
|
|
var u *url.URL
|
|
|
|
u, err = url.Parse(ep)
|
2016-10-18 15:49:24 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2016-11-04 15:14:19 -04:00
|
|
|
if u.Host != "" {
|
|
|
|
_, port, err := net.SplitHostPort(u.Host)
|
|
|
|
// Ignore the missing port error as the default port can be globalMinioPort.
|
|
|
|
if err != nil && !strings.Contains(err.Error(), "missing port in address") {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if globalMinioHost == "" {
|
|
|
|
// For ex.: minio server host1:port1 host2:port2...
|
|
|
|
// we return error as port is configurable only
|
|
|
|
// using "--address :port"
|
|
|
|
if port != "" {
|
|
|
|
errorIf(fmt.Errorf("Invalid argument %s, port configurable using --address :<port>", u.Host), "")
|
|
|
|
return nil, errInvalidArgument
|
|
|
|
}
|
|
|
|
u.Host = net.JoinHostPort(u.Host, globalMinioPort)
|
|
|
|
} else {
|
|
|
|
// For ex.: minio server --address host:port host1:port1 host2:port2...
|
|
|
|
// i.e if "--address host:port" is specified
|
|
|
|
// port info in u.Host is mandatory else return error.
|
|
|
|
if port == "" {
|
|
|
|
errorIf(fmt.Errorf("Invalid argument %s, port mandatory when --address <host>:<port> is used", u.Host), "")
|
|
|
|
return nil, errInvalidArgument
|
|
|
|
}
|
|
|
|
}
|
2016-10-27 06:30:52 -04:00
|
|
|
}
|
|
|
|
endpoints = append(endpoints, u)
|
2016-10-18 15:49:24 -04:00
|
|
|
}
|
|
|
|
return endpoints, nil
|
2016-04-12 15:45:15 -04:00
|
|
|
}
|
|
|
|
|
2016-05-07 00:18:29 -04:00
|
|
|
// getListenIPs - gets all the ips to listen on.
|
2016-11-09 13:50:14 -05:00
|
|
|
func getListenIPs(serverAddr string) (hosts []string, port string, err error) {
|
2016-10-24 02:55:12 -04:00
|
|
|
var host string
|
2016-11-09 13:50:14 -05:00
|
|
|
host, port, err = net.SplitHostPort(serverAddr)
|
2016-10-24 02:55:12 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, port, fmt.Errorf("Unable to parse host address %s", err)
|
2016-07-13 02:21:18 -04:00
|
|
|
}
|
2016-10-24 02:55:12 -04:00
|
|
|
if host == "" {
|
2016-10-24 05:43:16 -04:00
|
|
|
var ipv4s []net.IP
|
|
|
|
ipv4s, err = getInterfaceIPv4s()
|
2016-10-24 02:55:12 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, port, fmt.Errorf("Unable reverse sorted ips from hosts %s", err)
|
|
|
|
}
|
2016-10-24 05:43:16 -04:00
|
|
|
for _, ip := range ipv4s {
|
|
|
|
hosts = append(hosts, ip.String())
|
|
|
|
}
|
2016-10-24 02:55:12 -04:00
|
|
|
return hosts, port, nil
|
|
|
|
} // if host != "" {
|
|
|
|
// Proceed to append itself, since user requested a specific endpoint.
|
|
|
|
hosts = append(hosts, host)
|
|
|
|
return hosts, port, nil
|
2016-05-07 00:18:29 -04:00
|
|
|
}
|
|
|
|
|
2016-07-13 02:21:18 -04:00
|
|
|
// Finalizes the endpoints based on the host list and port.
|
|
|
|
func finalizeEndpoints(tls bool, apiServer *http.Server) (endPoints []string) {
|
|
|
|
// Verify current scheme.
|
|
|
|
scheme := "http"
|
|
|
|
if tls {
|
|
|
|
scheme = "https"
|
|
|
|
}
|
|
|
|
|
2016-10-24 02:55:12 -04:00
|
|
|
// Get list of listen ips and port.
|
2016-11-09 13:50:14 -05:00
|
|
|
hosts, port, err := getListenIPs(apiServer.Addr)
|
2016-10-24 02:55:12 -04:00
|
|
|
fatalIf(err, "Unable to get list of ips to listen on")
|
2016-07-13 09:34:59 -04:00
|
|
|
|
2016-07-13 02:21:18 -04:00
|
|
|
// Construct proper endpoints.
|
2016-10-24 02:55:12 -04:00
|
|
|
for _, host := range hosts {
|
|
|
|
endPoints = append(endPoints, fmt.Sprintf("%s://%s:%s", scheme, host, port))
|
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 18:27:10 -05:00
|
|
|
}
|
2016-07-13 02:21:18 -04:00
|
|
|
|
|
|
|
// Success.
|
|
|
|
return endPoints
|
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 18:27:10 -05:00
|
|
|
}
|
|
|
|
|
2016-11-11 10:18:44 -05:00
|
|
|
// loadRootCAs fetches CA files provided in minio config and adds them to globalRootCAs
|
|
|
|
// Currently under Windows, there is no way to load system + user CAs at the same time
|
|
|
|
func loadRootCAs() {
|
|
|
|
caFiles := mustGetCAFiles()
|
|
|
|
if len(caFiles) == 0 {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
// Get system cert pool, and empty cert pool under Windows because it is not supported
|
|
|
|
globalRootCAs = mustGetSystemCertPool()
|
|
|
|
// Load custom root CAs for client requests
|
|
|
|
for _, caFile := range mustGetCAFiles() {
|
|
|
|
caCert, err := ioutil.ReadFile(caFile)
|
|
|
|
if err != nil {
|
|
|
|
fatalIf(err, "Unable to load a CA file")
|
|
|
|
}
|
|
|
|
globalRootCAs.AppendCertsFromPEM(caCert)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
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 22:19:44 -04:00
|
|
|
// initServerConfig initialize server config.
|
|
|
|
func initServerConfig(c *cli.Context) {
|
2016-07-30 17:55:20 -04:00
|
|
|
// Create certs path.
|
|
|
|
err := createCertsPath()
|
|
|
|
fatalIf(err, "Unable to create \"certs\" directory.")
|
|
|
|
|
2016-11-11 10:18:44 -05:00
|
|
|
// Load user supplied root CAs
|
|
|
|
loadRootCAs()
|
|
|
|
|
2016-10-18 02:14:41 -04:00
|
|
|
// When credentials inherited from the env, server cmd has to save them in the disk
|
|
|
|
if os.Getenv("MINIO_ACCESS_KEY") != "" && os.Getenv("MINIO_SECRET_KEY") != "" {
|
|
|
|
// Env credentials are already loaded in serverConfig, just save in the disk
|
2016-08-02 19:48:21 -04:00
|
|
|
err = serverConfig.Save()
|
2016-10-18 02:14:41 -04:00
|
|
|
fatalIf(err, "Unable to save credentials in the disk.")
|
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 18:27:10 -05:00
|
|
|
}
|
2016-04-19 01:05:32 -04:00
|
|
|
|
|
|
|
// Set maxOpenFiles, This is necessary since default operating
|
|
|
|
// system limits of 1024, 2048 are not enough for Minio server.
|
|
|
|
setMaxOpenFiles()
|
2016-10-06 16:35:56 -04:00
|
|
|
|
2016-07-30 11:50:49 -04:00
|
|
|
// Set maxMemory, This is necessary since default operating
|
|
|
|
// system limits might be changed and we need to make sure we
|
|
|
|
// do not crash the server so the set the maxCacheSize appropriately.
|
|
|
|
setMaxMemory()
|
|
|
|
|
2016-04-19 01:05:32 -04:00
|
|
|
// Do not fail if this is not allowed, lower limits are fine as well.
|
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 18:27:10 -05:00
|
|
|
}
|
|
|
|
|
2016-08-26 03:11:53 -04:00
|
|
|
// Validate if input disks are sufficient for initializing XL.
|
2016-10-27 06:30:52 -04:00
|
|
|
func checkSufficientDisks(eps []*url.URL) error {
|
2016-08-26 03:11:53 -04:00
|
|
|
// Verify total number of disks.
|
2016-10-18 15:49:24 -04:00
|
|
|
total := len(eps)
|
|
|
|
if total > maxErasureBlocks {
|
2016-08-26 03:11:53 -04:00
|
|
|
return errXLMaxDisks
|
|
|
|
}
|
2016-10-18 15:49:24 -04:00
|
|
|
if total < minErasureBlocks {
|
2016-08-26 03:11:53 -04:00
|
|
|
return errXLMinDisks
|
|
|
|
}
|
|
|
|
|
|
|
|
// isEven function to verify if a given number if even.
|
|
|
|
isEven := func(number int) bool {
|
|
|
|
return number%2 == 0
|
|
|
|
}
|
|
|
|
|
|
|
|
// Verify if we have even number of disks.
|
|
|
|
// only combination of 4, 6, 8, 10, 12, 14, 16 are supported.
|
2016-10-18 15:49:24 -04:00
|
|
|
if !isEven(total) {
|
2016-08-26 03:11:53 -04:00
|
|
|
return errXLNumDisks
|
|
|
|
}
|
|
|
|
|
|
|
|
// Success.
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2016-08-23 22:19:24 -04:00
|
|
|
// Returns if slice of disks is a distributed setup.
|
2016-11-07 15:09:24 -05:00
|
|
|
func isDistributedSetup(eps []*url.URL) bool {
|
2016-10-27 06:30:52 -04:00
|
|
|
// Validate if one the disks is not local.
|
2016-10-18 15:49:24 -04:00
|
|
|
for _, ep := range eps {
|
|
|
|
if !isLocalStorage(ep) {
|
2016-11-07 15:09:24 -05:00
|
|
|
// One or more disks supplied as arguments are
|
|
|
|
// not attached to the local node.
|
|
|
|
return true
|
2016-08-23 22:19:24 -04:00
|
|
|
}
|
|
|
|
}
|
2016-11-07 15:09:24 -05:00
|
|
|
return false
|
2016-08-23 22:19:24 -04:00
|
|
|
}
|
|
|
|
|
2016-12-14 23:42:19 -05:00
|
|
|
// Check if the endpoints are following expected syntax, i.e
|
|
|
|
// valid scheme, valid path across all platforms.
|
|
|
|
func checkEndpointsSyntax(eps []*url.URL, disks []string) error {
|
2016-10-28 11:45:32 -04:00
|
|
|
for i, u := range eps {
|
|
|
|
switch u.Scheme {
|
2016-12-14 23:42:19 -05:00
|
|
|
case "":
|
|
|
|
// "/" is not allowed.
|
|
|
|
if u.Path == "" || u.Path == "/" {
|
|
|
|
return fmt.Errorf("Root path is not allowed : %s (%s)", u.Path, disks[i])
|
|
|
|
}
|
|
|
|
case "http", "https":
|
|
|
|
// "http://server1/" is not allowed
|
|
|
|
if u.Path == "" || u.Path == "/" || u.Path == "\\" {
|
|
|
|
return fmt.Errorf("Root path is not allowed : %s (%s)", u.Path, disks[i])
|
|
|
|
}
|
2016-10-28 11:45:32 -04:00
|
|
|
default:
|
|
|
|
if runtime.GOOS == "windows" {
|
|
|
|
// On windows for "C:\export" scheme will be "C"
|
|
|
|
matched, err := regexp.MatchString("^[a-zA-Z]$", u.Scheme)
|
2016-12-14 23:42:19 -05:00
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Invalid scheme : %s (%s), ERROR %s", u.Scheme, disks[i], err)
|
|
|
|
}
|
2016-10-28 11:45:32 -04:00
|
|
|
if matched {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
2016-12-14 23:42:19 -05:00
|
|
|
return fmt.Errorf("Invalid scheme : %s (%s)", u.Scheme, disks[i])
|
2016-10-28 11:45:32 -04:00
|
|
|
}
|
|
|
|
}
|
2016-12-14 23:42:19 -05:00
|
|
|
return nil
|
2016-10-28 11:45:32 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// Make sure all the command line parameters are OK and exit in case of invalid parameters.
|
|
|
|
func checkServerSyntax(c *cli.Context) {
|
|
|
|
serverAddr := c.String("address")
|
|
|
|
|
|
|
|
host, portStr, err := net.SplitHostPort(serverAddr)
|
|
|
|
fatalIf(err, "Unable to parse %s.", serverAddr)
|
|
|
|
|
|
|
|
// Verify syntax for all the XL disks.
|
|
|
|
disks := c.Args()
|
|
|
|
endpoints, err := parseStorageEndpoints(disks)
|
2016-12-14 23:42:19 -05:00
|
|
|
fatalIf(err, "Unable to parse storage endpoints %s", strings.Join(disks, " "))
|
|
|
|
|
|
|
|
// Validate if endpoints follow the expected syntax.
|
|
|
|
err = checkEndpointsSyntax(endpoints, disks)
|
|
|
|
fatalIf(err, "Invalid endpoints found %s", strings.Join(disks, " "))
|
|
|
|
|
|
|
|
// Validate for duplicate endpoints are supplied.
|
|
|
|
err = checkDuplicateEndpoints(endpoints)
|
|
|
|
fatalIf(err, "Duplicate entries in %s", strings.Join(disks, " "))
|
2016-10-28 11:45:32 -04:00
|
|
|
|
|
|
|
if len(endpoints) > 1 {
|
2016-12-14 23:42:19 -05:00
|
|
|
// Validate if we have sufficient disks for XL setup.
|
2016-10-28 11:45:32 -04:00
|
|
|
err = checkSufficientDisks(endpoints)
|
|
|
|
fatalIf(err, "Storage endpoint error.")
|
|
|
|
}
|
|
|
|
|
|
|
|
if !isDistributedSetup(endpoints) {
|
|
|
|
// for FS and singlenode-XL validation is done, return.
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Rest of the checks applies only to distributed XL setup.
|
|
|
|
if host != "" {
|
|
|
|
// We are here implies --address host:port is passed, hence the user is trying
|
|
|
|
// to run one minio process per export disk.
|
|
|
|
if portStr == "" {
|
|
|
|
fatalIf(errInvalidArgument, "Port missing, Host:Port should be specified for --address")
|
|
|
|
}
|
|
|
|
foundCnt := 0
|
|
|
|
for _, ep := range endpoints {
|
|
|
|
if ep.Host == serverAddr {
|
|
|
|
foundCnt++
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if foundCnt == 0 {
|
|
|
|
// --address host:port should be available in the XL disk list.
|
|
|
|
fatalIf(errInvalidArgument, "%s is not available in %s", serverAddr, strings.Join(disks, " "))
|
|
|
|
}
|
|
|
|
if foundCnt > 1 {
|
|
|
|
// --address host:port should match exactly one entry in the XL disk list.
|
|
|
|
fatalIf(errInvalidArgument, "%s matches % entries in %s", serverAddr, foundCnt, strings.Join(disks, " "))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
tls := isSSL()
|
|
|
|
for _, ep := range endpoints {
|
|
|
|
if ep.Scheme == "https" && !tls {
|
|
|
|
// Certificates should be provided for https configuration.
|
|
|
|
fatalIf(errInvalidArgument, "Certificates not provided for https")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-14 23:42:19 -05:00
|
|
|
// Checks if any of the endpoints supplied is local to this server.
|
2016-12-13 14:18:31 -05:00
|
|
|
func isAnyEndpointLocal(eps []*url.URL) bool {
|
|
|
|
anyLocalEp := false
|
|
|
|
for _, ep := range eps {
|
|
|
|
if isLocalStorage(ep) {
|
|
|
|
anyLocalEp = true
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return anyLocalEp
|
|
|
|
}
|
|
|
|
|
2016-07-13 02:21:18 -04:00
|
|
|
// serverMain handler called for 'minio server' command.
|
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 22:19:44 -04:00
|
|
|
func serverMain(c *cli.Context) {
|
2016-10-05 15:48:07 -04:00
|
|
|
if !c.Args().Present() || c.Args().First() == "help" {
|
|
|
|
cli.ShowCommandHelpAndExit(c, "server", 1)
|
|
|
|
}
|
2016-07-01 17:32:53 -04:00
|
|
|
|
2016-11-28 15:15:36 -05:00
|
|
|
// Set global variables after parsing passed arguments
|
|
|
|
setGlobalsFromContext(c)
|
|
|
|
|
|
|
|
// Initialization routine, such as config loading, enable logging, ..
|
|
|
|
minioInit()
|
|
|
|
|
2016-12-14 23:42:19 -05:00
|
|
|
// Check for minio updates from dl.minio.io
|
2016-11-28 15:15:36 -05:00
|
|
|
checkUpdate()
|
2016-11-23 18:48:10 -05:00
|
|
|
|
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 22:19:44 -04:00
|
|
|
// Server address.
|
2016-10-10 02:03:10 -04:00
|
|
|
serverAddr := c.String("address")
|
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 22:19:44 -04:00
|
|
|
|
2016-04-12 15:45:15 -04:00
|
|
|
// Check if requested port is available.
|
2016-10-18 15:49:24 -04:00
|
|
|
host, portStr, err := net.SplitHostPort(serverAddr)
|
|
|
|
fatalIf(err, "Unable to parse %s.", serverAddr)
|
2016-11-22 20:01:15 -05:00
|
|
|
if portStr == "0" || portStr == "" {
|
|
|
|
// Port zero or empty means use requested to choose any freely available
|
|
|
|
// port. Avoid this since it won't work with any configured clients,
|
|
|
|
// can lead to serious loss of availability.
|
|
|
|
fatalIf(errInvalidArgument, "Invalid port `%s`, please use `--address` to pick a specific port", portStr)
|
|
|
|
}
|
2016-10-18 15:49:24 -04:00
|
|
|
globalMinioHost = host
|
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 22:19:44 -04:00
|
|
|
|
2016-10-27 06:30:52 -04:00
|
|
|
// Check if requested port is available.
|
|
|
|
fatalIf(checkPortAvailability(portStr), "Port unavailable %s", portStr)
|
|
|
|
globalMinioPort = portStr
|
|
|
|
|
2016-10-28 11:45:32 -04:00
|
|
|
// Check server syntax and exit in case of errors.
|
|
|
|
// Done after globalMinioHost and globalMinioPort is set as parseStorageEndpoints()
|
|
|
|
// depends on it.
|
|
|
|
checkServerSyntax(c)
|
|
|
|
|
2016-07-10 17:38:15 -04:00
|
|
|
// Disks to be used in server init.
|
2016-10-27 06:30:52 -04:00
|
|
|
endpoints, err := parseStorageEndpoints(c.Args())
|
2016-10-18 15:49:24 -04:00
|
|
|
fatalIf(err, "Unable to parse storage endpoints %s", c.Args())
|
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 18:27:10 -05:00
|
|
|
|
2016-12-14 23:42:19 -05:00
|
|
|
// Should exit gracefully if none of the endpoints passed
|
|
|
|
// as command line args are local to this server.
|
2016-12-13 14:18:31 -05:00
|
|
|
if !isAnyEndpointLocal(endpoints) {
|
2016-12-14 23:42:19 -05:00
|
|
|
fatalIf(errInvalidArgument, "None of the disks passed as command line args are local to this server.")
|
2016-12-13 14:18:31 -05:00
|
|
|
}
|
|
|
|
|
2016-11-11 19:36:07 -05:00
|
|
|
storageDisks, err := initStorageDisks(endpoints)
|
2016-11-23 18:48:10 -05:00
|
|
|
fatalIf(err, "Unable to initialize storage disk(s).")
|
2016-10-06 16:35:56 -04:00
|
|
|
|
2016-10-19 22:59:48 -04:00
|
|
|
// Cleanup objects that weren't successfully written into the namespace.
|
|
|
|
fatalIf(houseKeeping(storageDisks), "Unable to purge temporary files.")
|
|
|
|
|
2016-10-27 06:30:52 -04:00
|
|
|
// Initialize server config.
|
|
|
|
initServerConfig(c)
|
|
|
|
|
2016-10-05 15:48:07 -04:00
|
|
|
// First disk argument check if it is local.
|
2016-10-27 06:30:52 -04:00
|
|
|
firstDisk := isLocalStorage(endpoints[0])
|
2016-10-05 15:48:07 -04:00
|
|
|
|
2016-10-28 11:45:32 -04:00
|
|
|
// Check if endpoints are part of distributed setup.
|
2016-11-07 15:09:24 -05:00
|
|
|
globalIsDistXL = isDistributedSetup(endpoints)
|
2016-10-28 11:45:32 -04:00
|
|
|
|
fs: Break fs package to top-level and introduce ObjectAPI interface.
ObjectAPI interface brings in changes needed for XL ObjectAPI layer.
The new interface for any ObjectAPI layer is as below
```
// ObjectAPI interface.
type ObjectAPI interface {
// Bucket resource API.
DeleteBucket(bucket string) *probe.Error
ListBuckets() ([]BucketInfo, *probe.Error)
MakeBucket(bucket string) *probe.Error
GetBucketInfo(bucket string) (BucketInfo, *probe.Error)
// Bucket query API.
ListObjects(bucket, prefix, marker, delimiter string, maxKeys int) (ListObjectsResult, *probe.Error)
ListMultipartUploads(bucket string, resources BucketMultipartResourcesMetadata) (BucketMultipartResourcesMetadata, *probe.Error)
// Object resource API.
GetObject(bucket, object string, startOffset int64) (io.ReadCloser, *probe.Error)
GetObjectInfo(bucket, object string) (ObjectInfo, *probe.Error)
PutObject(bucket string, object string, size int64, data io.Reader, metadata map[string]string) (ObjectInfo, *probe.Error)
DeleteObject(bucket, object string) *probe.Error
// Object query API.
NewMultipartUpload(bucket, object string) (string, *probe.Error)
PutObjectPart(bucket, object, uploadID string, partID int, size int64, data io.Reader, md5Hex string) (string, *probe.Error)
ListObjectParts(bucket, object string, resources ObjectResourcesMetadata) (ObjectResourcesMetadata, *probe.Error)
CompleteMultipartUpload(bucket string, object string, uploadID string, parts []CompletePart) (ObjectInfo, *probe.Error)
AbortMultipartUpload(bucket, object, uploadID string) *probe.Error
}
```
2016-03-30 19:15:28 -04:00
|
|
|
// Configure server.
|
2016-10-05 15:48:07 -04:00
|
|
|
srvConfig := serverCmdConfig{
|
2016-11-11 19:36:07 -05:00
|
|
|
serverAddr: serverAddr,
|
|
|
|
endpoints: endpoints,
|
|
|
|
storageDisks: storageDisks,
|
2016-07-31 17:11:14 -04:00
|
|
|
}
|
2016-08-30 22:22:27 -04:00
|
|
|
|
2016-07-31 17:11:14 -04:00
|
|
|
// Configure server.
|
2016-10-13 02:13:24 -04:00
|
|
|
handler, err := configureServerHandler(srvConfig)
|
|
|
|
fatalIf(err, "Unable to configure one of server's RPC services.")
|
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 18:27:10 -05:00
|
|
|
|
2016-10-05 15:48:07 -04:00
|
|
|
// Set nodes for dsync for distributed setup.
|
2016-11-07 15:09:24 -05:00
|
|
|
if globalIsDistXL {
|
2016-10-27 06:30:52 -04:00
|
|
|
fatalIf(initDsyncNodes(endpoints), "Unable to initialize distributed locking")
|
2016-10-05 15:48:07 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// Initialize name space lock.
|
2016-11-07 15:09:24 -05:00
|
|
|
initNSLock(globalIsDistXL)
|
2016-10-05 15:48:07 -04:00
|
|
|
|
|
|
|
// Initialize a new HTTP server.
|
2016-10-10 02:03:10 -04:00
|
|
|
apiServer := NewServerMux(serverAddr, handler)
|
2016-08-12 00:33:55 -04:00
|
|
|
|
2016-10-28 11:45:32 -04:00
|
|
|
// If https.
|
|
|
|
tls := isSSL()
|
|
|
|
|
2016-07-13 02:21:18 -04:00
|
|
|
// Fetch endpoints which we are going to serve from.
|
2016-11-04 15:13:22 -04:00
|
|
|
endPoints := finalizeEndpoints(tls, apiServer.Server)
|
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 18:27:10 -05:00
|
|
|
|
2016-10-17 19:38:29 -04:00
|
|
|
// Initialize local server address
|
|
|
|
globalMinioAddr = getLocalAddress(srvConfig)
|
|
|
|
|
|
|
|
// Initialize S3 Peers inter-node communication
|
2016-10-27 06:30:52 -04:00
|
|
|
initGlobalS3Peers(endpoints)
|
2016-10-17 19:38:29 -04:00
|
|
|
|
2016-12-16 01:26:15 -05:00
|
|
|
// Initialize Admin Peers inter-node communication
|
|
|
|
initGlobalAdminPeers(endpoints)
|
|
|
|
|
2016-10-10 02:03:10 -04:00
|
|
|
// Start server, automatically configures TLS if certs are available.
|
|
|
|
go func(tls bool) {
|
|
|
|
var lerr error
|
2016-11-05 23:32:13 -04:00
|
|
|
cert, key := "", ""
|
2016-10-10 02:03:10 -04:00
|
|
|
if tls {
|
2016-11-05 23:32:13 -04:00
|
|
|
cert, key = mustGetCertFile(), mustGetKeyFile()
|
2016-10-10 02:03:10 -04:00
|
|
|
}
|
2016-11-05 23:32:13 -04:00
|
|
|
lerr = apiServer.ListenAndServe(cert, key)
|
2016-10-10 02:03:10 -04:00
|
|
|
fatalIf(lerr, "Failed to start minio server.")
|
|
|
|
}(tls)
|
2016-09-14 04:11:03 -04:00
|
|
|
|
|
|
|
// Wait for formatting of disks.
|
2016-11-23 18:48:10 -05:00
|
|
|
formattedDisks, err := waitForFormatDisks(firstDisk, endpoints, storageDisks)
|
2016-10-05 15:48:07 -04:00
|
|
|
fatalIf(err, "formatting storage disks failed")
|
2016-09-14 04:11:03 -04:00
|
|
|
|
|
|
|
// Once formatted, initialize object layer.
|
2016-11-23 18:48:10 -05:00
|
|
|
newObject, err := newObjectLayer(formattedDisks)
|
2016-10-05 15:48:07 -04:00
|
|
|
fatalIf(err, "intializing object layer failed")
|
2016-09-13 14:00:40 -04:00
|
|
|
|
2016-10-10 02:03:10 -04:00
|
|
|
globalObjLayerMutex.Lock()
|
2016-08-30 22:22:27 -04:00
|
|
|
globalObjectAPI = newObject
|
2016-10-10 02:03:10 -04:00
|
|
|
globalObjLayerMutex.Unlock()
|
2016-08-05 16:48:31 -04:00
|
|
|
|
2016-10-05 15:48:07 -04:00
|
|
|
// Prints the formatted startup message once object layer is initialized.
|
|
|
|
printStartupMessage(endPoints)
|
|
|
|
|
2016-09-14 04:11:03 -04:00
|
|
|
// Waits on the server.
|
2016-10-10 02:03:10 -04:00
|
|
|
<-globalServiceDoneCh
|
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 18:27:10 -05:00
|
|
|
}
|