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
/ *
2018-03-16 01:33:41 +05:30
* Minio Cloud Storage , ( C ) 2015 , 2016 , 2017 , 2018 Minio , Inc .
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
*
* 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
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
import (
2018-04-05 15:04:40 -07:00
"context"
2018-05-08 19:04:36 -07:00
"fmt"
2017-07-13 05:03:21 +05:30
"net/http"
2017-03-07 09:05:26 +05:30
"os"
2017-07-13 05:03:21 +05:30
"os/signal"
"syscall"
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
"github.com/minio/cli"
2017-06-05 12:25:04 -07:00
"github.com/minio/dsync"
2018-04-22 07:53:54 +05:30
xhttp "github.com/minio/minio/cmd/http"
2018-04-05 15:04:40 -07:00
"github.com/minio/minio/cmd/logger"
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-09-01 23:12:49 +01:00
var serverFlags = [ ] cli . Flag {
cli . StringFlag {
Name : "address" ,
2017-07-21 00:39:11 +01:00
Value : ":" + globalMinioPort ,
2017-02-24 14:19:20 -08:00
Usage : "Bind to a specific ADDRESS:PORT, ADDRESS can be an IP or hostname." ,
2016-09-01 23:12:49 +01: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 19:19:44 -07: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 15:27:10 -08:00
CustomHelpTemplate : ` NAME :
2017-03-16 12:21:58 -07:00
{ { . HelpName } } - { { . Usage } }
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
USAGE :
2018-02-15 17:45:57 -08:00
{ { . HelpName } } { { if . VisibleFlags } } [ FLAGS ] { { end } } DIR1 [ DIR2 . . ]
{ { . HelpName } } { { if . VisibleFlags } } [ FLAGS ] { { end } } DIR { 1. . .64 }
DIR :
DIR points to a directory on a filesystem . When you want to combine
multiple drives into a single large system , pass one directory per
filesystem separated by space . You may also use a ' ... ' convention
to abbreviate the directory arguments . Remote directories in a
distributed setup are encoded as HTTP ( s ) URIs .
2017-02-15 17:45:08 -08:00
{ { if . VisibleFlags } }
2016-08-28 20:04:47 -07:00
FLAGS :
2017-02-15 02:25:38 -08:00
{ { range . VisibleFlags } } { { . } }
2017-02-15 17:45:08 -08:00
{ { end } } { { end } }
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
ENVIRONMENT VARIABLES :
2016-07-10 14:38:15 -07:00
ACCESS :
2018-02-02 04:43:30 +01:00
MINIO_ACCESS_KEY : Custom username or access key of minimum 3 characters in length .
2017-08-03 20:03:37 -07:00
MINIO_SECRET_KEY : Custom password or secret key of minimum 8 characters in length .
2016-12-10 00:42:22 -08:00
BROWSER :
MINIO_BROWSER : To disable web browser access , set this value to "off" .
2016-07-10 14:38:15 -07:00
2018-03-28 14:14:06 -07:00
CACHE :
2018-04-01 21:55:09 -07:00
MINIO_CACHE_DRIVES : List of mounted drives or directories delimited by ";" .
2018-03-30 01:59:21 +05:30
MINIO_CACHE_EXCLUDE : List of cache exclusion patterns delimited by ";" .
MINIO_CACHE_EXPIRY : Cache expiry duration in days .
2018-03-28 14:14:06 -07:00
2017-06-20 22:02:18 +00:00
REGION :
2018-03-26 09:11:39 -07:00
MINIO_REGION : To set custom region . By default all regions are accepted .
2017-06-20 22:02:18 +00:00
2017-12-16 02:03:42 +05:30
UPDATE :
MINIO_UPDATE : To turn off in - place upgrades , set this value to "off" .
2018-03-26 09:11:39 -07:00
DOMAIN :
2018-03-30 01:59:21 +05:30
MINIO_DOMAIN : To enable virtual - host - style requests , set this value to Minio host domain name .
2018-03-26 09:11:39 -07:00
2018-03-28 05:14:45 +05:30
WORM :
MINIO_WORM : To turn on Write - Once - Read - Many in server , set this value to "on" .
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
EXAMPLES :
2016-11-09 23:37:12 -08:00
1. Start minio server on "/home/shared" directory .
2017-02-15 17:45:08 -08:00
$ { { . HelpName } } / home / shared
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
2017-02-24 14:19:20 -08:00
2. Start minio server bound to a specific ADDRESS : PORT .
2017-02-15 17:45:08 -08:00
$ { { . HelpName } } -- 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 15:27:10 -08:00
2018-03-26 09:11:39 -07:00
3. Start minio server and enable virtual - host - style requests .
$ export MINIO_DOMAIN = mydomain . com
$ { { . HelpName } } -- address mydomain . com : 9000 / mnt / export
2018-04-13 11:57:05 -07:00
4. Start minio server on 64 disks server .
2018-02-15 17:45:57 -08:00
$ { { . HelpName } } / mnt / export { 1. . .64 }
2018-04-13 11:57:05 -07:00
5. Start distributed minio server on an 8 node setup with 8 drives each . Run following command on all the 8 nodes .
2018-02-15 17:45:57 -08:00
$ export MINIO_ACCESS_KEY = minio
$ export MINIO_SECRET_KEY = miniostorage
$ { { . HelpName } } http : //node{1...8}.example.com/mnt/export/{1...8}
2018-03-28 14:14:06 -07:00
2018-04-13 11:57:05 -07:00
6. Start minio server with edge caching enabled .
2018-04-01 21:55:09 -07:00
$ export MINIO_CACHE_DRIVES = "/mnt/drive1;/mnt/drive2;/mnt/drive3;/mnt/drive4"
2018-03-28 14:14:06 -07:00
$ export MINIO_CACHE_EXCLUDE = "bucket1/*;*.png"
$ export MINIO_CACHE_EXPIRY = 40
$ { { . HelpName } } / 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 15:27:10 -08:00
` ,
}
2017-03-30 23:51:19 +05:30
func serverHandleCmdArgs ( ctx * cli . Context ) {
2017-06-09 19:50:51 -07:00
// Handle common command args.
handleCommonCmdArgs ( ctx )
2017-03-29 08:55:33 -07: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 19:19:44 -07:00
// Server address.
2017-04-12 04:14:27 +05:30
serverAddr := ctx . String ( "address" )
2018-05-08 19:04:36 -07:00
logger . FatalIf ( CheckLocalServerAddr ( serverAddr ) , "Unable to validate passed arguments" )
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
2017-04-12 04:14:27 +05:30
var setupType SetupType
2017-01-11 13:59:51 -08:00
var err error
2017-08-15 15:10:50 -07:00
2018-02-15 17:45:57 -08:00
if len ( ctx . Args ( ) ) > serverCommandLineArgsMax {
2018-05-08 19:04:36 -07:00
uErr := uiErrInvalidErasureEndpoints ( nil ) . Msg ( fmt . Sprintf ( "Invalid total number of endpoints (%d) passed, supported upto 32 unique arguments" , len ( ctx . Args ( ) ) ) )
logger . FatalIf ( uErr , "Unable to validate passed endpoints" )
2018-02-15 17:45:57 -08:00
}
globalMinioAddr , globalEndpoints , setupType , globalXLSetCount , globalXLSetDriveCount , err = createServerEndpoints ( serverAddr , ctx . Args ( ) ... )
2018-05-08 19:04:36 -07:00
logger . FatalIf ( err , "Invalid command line arguments" )
2018-02-15 17:45:57 -08:00
2017-04-12 04:14:27 +05:30
globalMinioHost , globalMinioPort = mustSplitHostPort ( globalMinioAddr )
2018-05-08 19:04:36 -07:00
// On macOS, if a process already listens on LOCALIPADDR:PORT, net.Listen() falls back
// to IPv6 address ie minio will start listening on IPv6 address whereas another
// (non-)minio process is listening on IPv4 of given port.
// To avoid this error sutiation we check for port availability.
logger . FatalIf ( checkPortAvailability ( globalMinioPort ) , "Unable to start the server" )
2016-08-30 19:22:27 -07:00
2017-04-12 04:14:27 +05:30
globalIsXL = ( setupType == XLSetupType )
globalIsDistXL = ( setupType == DistXLSetupType )
if globalIsDistXL {
2017-01-23 14:02:55 +05:30
globalIsXL = true
}
2017-03-30 23:51:19 +05:30
}
func serverHandleEnvVars ( ) {
2017-06-09 19:50:51 -07:00
// Handle common environment variables.
handleCommonEnvVars ( )
2017-04-09 10:44:10 -07:00
if serverRegion := os . Getenv ( "MINIO_REGION" ) ; serverRegion != "" {
// region Envs are set globally.
globalIsEnvRegion = true
globalServerRegion = serverRegion
}
2017-03-30 23:51:19 +05:30
}
2018-04-05 15:04:40 -07:00
func init ( ) {
logger . Init ( GOPATH )
}
2017-03-30 23:51:19 +05:30
// serverMain handler called for 'minio server' command.
func serverMain ( ctx * cli . Context ) {
2018-02-15 17:45:57 -08:00
if ( ! ctx . IsSet ( "sets" ) && ! ctx . Args ( ) . Present ( ) ) || ctx . Args ( ) . First ( ) == "help" {
2017-03-30 23:51:19 +05:30
cli . ShowCommandHelpAndExit ( ctx , "server" , 1 )
}
2018-05-08 19:04:36 -07:00
// Disable logging until server initialization is complete, any
// error during initialization will be shown as a fatal message
logger . Disable = true
2018-01-17 09:24:46 -06:00
// Get "json" flag from command line argument and
// enable json and quite modes if jason flag is turned on.
2018-02-28 20:13:33 -08:00
jsonFlag := ctx . IsSet ( "json" ) || ctx . GlobalIsSet ( "json" )
2018-01-17 09:24:46 -06:00
if jsonFlag {
2018-04-05 15:04:40 -07:00
logger . EnableJSON ( )
2018-01-17 09:24:46 -06:00
}
2017-03-30 23:51:19 +05:30
// Get quiet flag from command line argument.
2018-02-28 20:13:33 -08:00
quietFlag := ctx . IsSet ( "quiet" ) || ctx . GlobalIsSet ( "quiet" )
2017-03-30 23:51:19 +05:30
if quietFlag {
2018-04-05 15:04:40 -07:00
logger . EnableQuiet ( )
2017-03-30 23:51:19 +05:30
}
2018-05-08 19:04:36 -07:00
logger . RegisterUIError ( fmtError )
2017-06-09 19:50:51 -07:00
// Handle all server command args.
2017-03-30 23:51:19 +05:30
serverHandleCmdArgs ( ctx )
2017-06-09 19:50:51 -07:00
// Handle all server environment vars.
2017-03-30 23:51:19 +05:30
serverHandleEnvVars ( )
// Create certs path.
2018-05-08 19:04:36 -07:00
logger . FatalIf ( createConfigDir ( ) , "Unable to initialize configuration files" )
2017-03-30 23:51:19 +05:30
2017-06-09 19:50:51 -07:00
// Initialize server config.
2017-03-30 23:51:19 +05:30
initConfig ( )
// Check and load SSL certificates.
var err error
2017-07-13 05:03:21 +05:30
globalPublicCerts , globalRootCAs , globalTLSCertificate , globalIsSSL , err = getSSLConfig ( )
2018-05-08 19:04:36 -07:00
logger . FatalIf ( err , "Unable to load the TLS configuration" )
2017-03-30 23:51:19 +05:30
2017-12-03 22:47:12 -08:00
// Is distributed setup, error out if no certificates are found for HTTPS endpoints.
2018-04-09 19:10:23 -07:00
if globalIsDistXL {
if globalEndpoints . IsHTTPS ( ) && ! globalIsSSL {
2018-05-08 19:04:36 -07:00
logger . Fatal ( uiErrNoCertsAndHTTPSEndpoints ( nil ) , "Unable to start the server" )
2018-04-09 19:10:23 -07:00
}
if ! globalEndpoints . IsHTTPS ( ) && globalIsSSL {
2018-05-08 19:04:36 -07:00
logger . Fatal ( uiErrCertsAndHTTPEndpoints ( nil ) , "Unable to start the server" )
2018-04-09 19:10:23 -07:00
}
2017-12-03 22:47:12 -08:00
}
2017-03-16 12:21:58 -07:00
if ! quietFlag {
// Check for new updates from dl.minio.io.
mode := globalMinioModeFS
if globalIsDistXL {
mode = globalMinioModeDistXL
2017-04-12 04:14:27 +05:30
} else if globalIsXL {
mode = globalMinioModeXL
2017-03-16 12:21:58 -07:00
}
checkUpdate ( mode )
}
2017-03-30 23:51:19 +05:30
// Set system resources to maximum.
2018-04-05 15:04:40 -07:00
logger . LogIf ( context . Background ( ) , setMaxResources ( ) )
2017-03-30 23:51:19 +05:30
// Set nodes for dsync for distributed setup.
if globalIsDistXL {
2018-01-22 10:25:10 -08:00
globalDsync , err = dsync . New ( newDsyncNodes ( globalEndpoints ) )
2018-05-08 19:04:36 -07:00
if err != nil {
logger . Fatal ( err , "Unable to initialize distributed locking on %s" , globalEndpoints )
}
2017-03-30 23:51:19 +05:30
}
2016-10-05 12:48:07 -07:00
// Initialize name space lock.
2016-11-07 15:09:24 -05:00
initNSLock ( globalIsDistXL )
2016-10-05 12:48:07 -07:00
2018-01-22 14:54:55 -08:00
// Init global heal state
initAllHealState ( globalIsXL )
2017-03-30 23:51:19 +05:30
// Configure server.
2017-07-13 05:03:21 +05:30
var handler http . Handler
handler , err = configureServerHandler ( globalEndpoints )
2018-05-08 19:04:36 -07:00
if err != nil {
2018-05-09 15:11:24 -07:00
logger . Fatal ( uiErrUnexpectedError ( err ) , "Unable to configure one of server's RPC services" )
2018-05-08 19:04:36 -07:00
}
2017-01-16 17:05:00 -08:00
2018-04-25 04:23:30 +05:30
// Create new notification system.
2018-03-16 01:33:41 +05:30
globalNotificationSys , err = NewNotificationSys ( globalServerConfig , globalEndpoints )
2018-05-08 19:04:36 -07:00
if err != nil {
2018-05-09 15:11:24 -07:00
logger . Fatal ( err , "Unable to initialize the notification system" )
2018-05-08 19:04:36 -07:00
}
2018-04-25 04:23:30 +05:30
// Create new policy system.
globalPolicySys = NewPolicySys ( )
2017-01-19 11:32:13 -08:00
// Initialize Admin Peers inter-node communication only in distributed setup.
2017-03-30 23:51:19 +05:30
initGlobalAdminPeers ( globalEndpoints )
2017-01-19 11:32:13 -08:00
2018-04-22 07:53:54 +05:30
globalHTTPServer = xhttp . NewServer ( [ ] string { globalMinioAddr } , handler , globalTLSCertificate )
2017-09-07 11:16:45 -07:00
globalHTTPServer . ReadTimeout = globalConnReadTimeout
globalHTTPServer . WriteTimeout = globalConnWriteTimeout
2017-07-13 05:03:21 +05:30
globalHTTPServer . UpdateBytesReadFunc = globalConnStats . incInputBytes
globalHTTPServer . UpdateBytesWrittenFunc = globalConnStats . incOutputBytes
2017-01-11 13:59:51 -08:00
go func ( ) {
2017-07-13 05:03:21 +05:30
globalHTTPServerErrorCh <- globalHTTPServer . Start ( )
2017-01-11 13:59:51 -08:00
} ( )
2016-09-14 01:11:03 -07:00
2017-07-13 05:03:21 +05:30
signal . Notify ( globalOSSignalCh , os . Interrupt , syscall . SIGTERM )
2017-04-12 04:14:27 +05:30
newObject , err := newObjectLayer ( globalEndpoints )
2017-07-13 05:03:21 +05:30
if err != nil {
2018-05-08 19:04:36 -07:00
globalHTTPServer . Shutdown ( )
logger . FatalIf ( err , "Unable to initialize backend" )
2017-07-13 05:03:21 +05:30
}
2016-09-13 23:30:40 +05:30
2016-10-09 23:03:10 -07:00
globalObjLayerMutex . Lock ( )
2016-08-30 19:22:27 -07:00
globalObjectAPI = newObject
2016-10-09 23:03:10 -07:00
globalObjLayerMutex . Unlock ( )
2016-08-05 22:48:31 +02:00
2016-10-05 12:48:07 -07:00
// Prints the formatted startup message once object layer is initialized.
2017-07-13 05:03:21 +05:30
apiEndpoints := getAPIEndpoints ( globalMinioAddr )
2017-04-12 04:14:27 +05:30
printStartupMessage ( apiEndpoints )
2016-10-05 12:48:07 -07:00
2017-02-09 23:26:44 -08:00
// Set uptime time after object layer has initialized.
2017-03-18 23:58:41 +05:30
globalBootTime = UTCNow ( )
2017-02-09 23:26:44 -08:00
2018-05-08 19:04:36 -07:00
// Re-enable logging
logger . Disable = false
2017-07-13 05:03:21 +05:30
handleSignals ( )
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
}
2017-01-16 17:05:00 -08:00
// Initialize object layer with the supplied disks, objectLayer is nil upon any error.
2017-04-12 04:14:27 +05:30
func newObjectLayer ( endpoints EndpointList ) ( newObject ObjectLayer , err error ) {
2017-01-16 17:05:00 -08:00
// For FS only, directly use the disk.
2018-02-15 17:45:57 -08:00
2017-04-12 04:14:27 +05:30
isFS := len ( endpoints ) == 1
2017-01-16 17:05:00 -08:00
if isFS {
// Initialize new FS object layer.
2018-02-20 12:21:12 -08:00
return NewFSObjectLayer ( endpoints [ 0 ] . Path )
2017-01-16 17:05:00 -08:00
}
2018-04-05 15:04:40 -07:00
format , err := waitForFormatXL ( context . Background ( ) , endpoints [ 0 ] . IsLocal , endpoints , globalXLSetCount , globalXLSetDriveCount )
2017-01-16 17:05:00 -08:00
if err != nil {
return nil , err
}
2018-02-15 17:45:57 -08:00
return newXLSets ( endpoints , format , len ( format . XL . Sets ) , len ( format . XL . Sets [ 0 ] ) )
2017-01-16 17:05:00 -08:00
}