2015-12-07 14:12:47 -08:00
|
|
|
/*
|
2017-01-18 12:24:34 -08:00
|
|
|
* Minio Cloud Storage, (C) 2015, 2016, 2017 Minio, Inc.
|
2015-12-07 14:12:47 -08:00
|
|
|
*
|
|
|
|
* 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 16:23:42 -07:00
|
|
|
package cmd
|
2015-12-07 14:12:47 -08:00
|
|
|
|
2016-07-08 20:34:27 -07:00
|
|
|
import (
|
2016-11-11 16:18:44 +01:00
|
|
|
"crypto/x509"
|
2017-01-23 14:02:55 +05:30
|
|
|
"net/url"
|
2017-01-09 22:22:10 +00:00
|
|
|
"runtime"
|
2016-09-09 23:33:35 +01:00
|
|
|
"time"
|
|
|
|
|
2016-11-22 18:18:22 -08:00
|
|
|
humanize "github.com/dustin/go-humanize"
|
2016-07-08 20:34:27 -07:00
|
|
|
"github.com/fatih/color"
|
2016-11-28 21:15:36 +01:00
|
|
|
"github.com/minio/cli"
|
|
|
|
"github.com/minio/mc/pkg/console"
|
2016-07-08 20:34:27 -07:00
|
|
|
"github.com/minio/minio/pkg/objcache"
|
|
|
|
)
|
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
|
|
|
|
|
|
|
// minio configuration related constants.
|
|
|
|
const (
|
2017-01-09 22:22:10 +00:00
|
|
|
globalMinioConfigVersion = "13"
|
2016-10-14 13:48:08 +02:00
|
|
|
globalMinioConfigDir = ".minio"
|
|
|
|
globalMinioCertsDir = "certs"
|
2016-11-11 16:18:44 +01:00
|
|
|
globalMinioCertsCADir = "CAs"
|
2016-10-14 13:48:08 +02:00
|
|
|
globalMinioCertFile = "public.crt"
|
|
|
|
globalMinioKeyFile = "private.key"
|
|
|
|
globalMinioConfigFile = "config.json"
|
2016-10-14 11:15:59 -07:00
|
|
|
globalMinioCertExpireWarnDays = time.Hour * 24 * 30 // 30 days.
|
2017-01-18 12:24:34 -08:00
|
|
|
|
|
|
|
globalMinioDefaultRegion = "us-east-1"
|
|
|
|
globalMinioDefaultOwnerID = "minio"
|
|
|
|
globalMinioDefaultStorageClass = "STANDARD"
|
|
|
|
globalWindowsOSName = "windows"
|
2017-02-09 11:57:35 +05:30
|
|
|
globalNetBSDOSName = "netbsd"
|
|
|
|
globalSolarisOSName = "solaris"
|
2016-05-09 16:18:56 -07:00
|
|
|
// Add new global values here.
|
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
|
|
|
)
|
|
|
|
|
2016-11-22 20:13:20 -08:00
|
|
|
const (
|
|
|
|
// Limit fields size (except file) to 1Mib since Policy document
|
|
|
|
// can reach that size according to https://aws.amazon.com/articles/1434
|
|
|
|
maxFormFieldSize = int64(1 * humanize.MiByte)
|
|
|
|
|
2017-02-02 19:45:00 +01:00
|
|
|
// Limit memory allocation to store multipart data
|
|
|
|
maxFormMemory = int64(5 * humanize.MiByte)
|
|
|
|
|
2016-11-22 20:13:20 -08:00
|
|
|
// The maximum allowed difference between the request generation time and the server processing time
|
|
|
|
globalMaxSkewTime = 15 * time.Minute
|
|
|
|
)
|
|
|
|
|
2016-03-24 17:20:49 -07:00
|
|
|
var (
|
2016-11-28 21:15:36 +01:00
|
|
|
globalQuiet = false // quiet flag set via command line.
|
|
|
|
globalConfigDir = mustGetConfigPath() // config-dir flag set via command line
|
2016-11-23 17:27:42 -08:00
|
|
|
// Add new global flags here.
|
|
|
|
|
2017-01-16 17:05:00 -08:00
|
|
|
// Indicates if the running minio server is distributed setup.
|
|
|
|
globalIsDistXL = false
|
2016-11-28 21:15:36 +01:00
|
|
|
|
2017-01-23 14:02:55 +05:30
|
|
|
// Indicates if the running minio server is an erasure-code backend.
|
|
|
|
globalIsXL = false
|
|
|
|
|
2017-02-27 23:59:53 +01:00
|
|
|
// This flag is set to 'true' by default
|
|
|
|
globalIsBrowserEnabled = true
|
|
|
|
// This flag is set to 'true' when MINIO_BROWSER env is set.
|
|
|
|
globalIsEnvBrowser = false
|
|
|
|
// Set to true if credentials were passed from env, default is false.
|
|
|
|
globalIsEnvCreds = false
|
2016-12-10 00:42:22 -08:00
|
|
|
|
2016-12-08 20:35:07 -08:00
|
|
|
// Maximum cache size. Defaults to disabled.
|
|
|
|
// Caching is enabled only for RAM size > 8GiB.
|
|
|
|
globalMaxCacheSize = uint64(0)
|
|
|
|
|
2017-01-31 00:44:42 +01:00
|
|
|
// Maximum size of internal objects parts
|
|
|
|
globalPutPartSize = int64(64 * 1024 * 1024)
|
|
|
|
|
2016-07-08 20:34:27 -07:00
|
|
|
// Cache expiry.
|
|
|
|
globalCacheExpiry = objcache.DefaultExpiry
|
2017-01-10 16:43:48 -08:00
|
|
|
|
2016-10-12 01:03:50 -07:00
|
|
|
// Minio local server address (in `host:port` format)
|
|
|
|
globalMinioAddr = ""
|
2016-10-05 12:48:07 -07:00
|
|
|
// Minio default port, can be changed through command line.
|
2016-10-27 03:30:52 -07:00
|
|
|
globalMinioPort = "9000"
|
2016-10-19 01:19:24 +05:30
|
|
|
// Holds the host that was passed using --address
|
|
|
|
globalMinioHost = ""
|
2016-12-29 03:13:51 -08:00
|
|
|
|
2017-01-10 16:43:48 -08:00
|
|
|
// Holds the list of API endpoints for a given server.
|
|
|
|
globalAPIEndpoints = []string{}
|
|
|
|
|
2016-10-12 01:03:50 -07:00
|
|
|
// Peer communication struct
|
|
|
|
globalS3Peers = s3Peers{}
|
|
|
|
|
2016-11-11 16:18:44 +01:00
|
|
|
// CA root certificates, a nil value means system certs pool will be used
|
|
|
|
globalRootCAs *x509.CertPool
|
|
|
|
|
2017-01-11 13:59:51 -08:00
|
|
|
// IsSSL indicates if the server is configured with SSL.
|
|
|
|
globalIsSSL bool
|
|
|
|
|
2016-12-29 03:13:51 -08:00
|
|
|
// List of admin peers.
|
2016-12-16 11:56:15 +05:30
|
|
|
globalAdminPeers = adminPeers{}
|
2016-12-29 03:13:51 -08:00
|
|
|
|
2017-01-09 22:22:10 +00:00
|
|
|
// Minio server user agent string.
|
|
|
|
globalServerUserAgent = "Minio/" + ReleaseTag + " (" + runtime.GOOS + "; " + runtime.GOARCH + ")"
|
|
|
|
|
2017-01-23 14:02:55 +05:30
|
|
|
// url.URL endpoints of disks that belong to the object storage.
|
|
|
|
globalEndpoints = []*url.URL{}
|
|
|
|
|
2017-02-06 18:29:53 +01:00
|
|
|
// Global server's network statistics
|
|
|
|
globalConnStats = newConnStats()
|
2017-02-08 13:43:02 +05:30
|
|
|
|
2017-02-06 18:29:53 +01:00
|
|
|
// Global HTTP request statisitics
|
|
|
|
globalHTTPStats = newHTTPStats()
|
|
|
|
|
2017-02-08 13:43:02 +05:30
|
|
|
// Time when object layer was initialized on start up.
|
|
|
|
globalBootTime time.Time
|
|
|
|
|
2016-06-26 03:18:07 -07:00
|
|
|
// Add new variable global values here.
|
2016-03-24 17:20:49 -07:00
|
|
|
)
|
|
|
|
|
2016-07-28 21:02:22 +02:00
|
|
|
var (
|
2016-10-21 22:56:27 -07:00
|
|
|
// Keeps the connection active by waiting for following amount of time.
|
|
|
|
// Primarily used in ListenBucketNotification.
|
|
|
|
globalSNSConnAlive = 5 * time.Second
|
2016-09-09 23:33:35 +01: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 15:27:10 -08:00
|
|
|
// global colors.
|
|
|
|
var (
|
2017-01-18 12:24:34 -08:00
|
|
|
colorBold = color.New(color.Bold).SprintFunc()
|
|
|
|
colorBlue = color.New(color.FgBlue).SprintfFunc()
|
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
|
|
|
)
|
2016-11-28 21:15:36 +01:00
|
|
|
|
|
|
|
// Parse command arguments and set global variables accordingly
|
|
|
|
func setGlobalsFromContext(c *cli.Context) {
|
|
|
|
// Set config dir
|
|
|
|
switch {
|
|
|
|
case c.IsSet("config-dir"):
|
|
|
|
globalConfigDir = c.String("config-dir")
|
|
|
|
case c.GlobalIsSet("config-dir"):
|
|
|
|
globalConfigDir = c.GlobalString("config-dir")
|
|
|
|
}
|
|
|
|
if globalConfigDir == "" {
|
|
|
|
console.Fatalf("Unable to get config file. Config directory is empty.")
|
|
|
|
}
|
2017-01-15 16:53:01 -08:00
|
|
|
|
2016-11-28 21:15:36 +01:00
|
|
|
// Set global quiet flag.
|
|
|
|
globalQuiet = c.Bool("quiet") || c.GlobalBool("quiet")
|
|
|
|
}
|