2015-02-08 05:54:21 -05:00
|
|
|
/*
|
2015-03-19 17:35:50 -04:00
|
|
|
* Minimalist Object Storage, (C) 2015 Minio, Inc.
|
2015-02-08 05:54:21 -05: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.
|
|
|
|
*/
|
|
|
|
|
2015-01-14 14:29:04 -05:00
|
|
|
package main
|
|
|
|
|
2015-01-25 20:15:18 -05:00
|
|
|
import (
|
2015-04-02 15:48:22 -04:00
|
|
|
"fmt"
|
2015-01-28 22:52:30 -05:00
|
|
|
"os"
|
2015-04-02 15:48:22 -04:00
|
|
|
"os/user"
|
|
|
|
"runtime"
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
2015-03-25 14:49:04 -04:00
|
|
|
"time"
|
2015-01-28 19:07:53 -05:00
|
|
|
|
2015-03-24 23:33:36 -04:00
|
|
|
"github.com/minio-io/cli"
|
2015-03-25 14:44:43 -04:00
|
|
|
"github.com/minio-io/iodine"
|
2015-01-25 20:15:18 -05:00
|
|
|
"github.com/minio-io/minio/pkg/server"
|
2015-03-23 21:12:20 -04:00
|
|
|
"github.com/minio-io/minio/pkg/utils/log"
|
2015-01-25 20:15:18 -05:00
|
|
|
)
|
|
|
|
|
2015-04-02 15:48:22 -04:00
|
|
|
var globalDebugFlag = false
|
|
|
|
|
2015-03-24 23:33:36 -04:00
|
|
|
var flags = []cli.Flag{
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "domain,d",
|
|
|
|
Value: "",
|
|
|
|
Usage: "domain used for routing incoming API requests",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "api-address,a",
|
|
|
|
Value: ":9000",
|
|
|
|
Usage: "address for incoming API requests",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "web-address,w",
|
|
|
|
Value: ":9001",
|
|
|
|
Usage: "address for incoming Management UI requests",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "cert,c",
|
|
|
|
Hide: true,
|
|
|
|
Value: "",
|
|
|
|
Usage: "cert.pem",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "key,k",
|
|
|
|
Hide: true,
|
|
|
|
Value: "",
|
|
|
|
Usage: "key.pem",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "driver-type,t",
|
|
|
|
Value: "donut",
|
|
|
|
Usage: "valid entries: file,inmemory,donut",
|
|
|
|
},
|
2015-04-02 15:48:22 -04:00
|
|
|
cli.BoolFlag{
|
|
|
|
Name: "debug",
|
|
|
|
Usage: "print debug information",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
// Check for the environment early on and gracefuly report.
|
|
|
|
_, err := user.Current()
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("minio: Unable to obtain user's home directory. \nError: %s\n", err)
|
|
|
|
}
|
2015-03-24 23:33:36 -04:00
|
|
|
}
|
|
|
|
|
2015-03-23 23:40:21 -04:00
|
|
|
func getDriverType(input string) server.DriverType {
|
2015-02-01 05:35:00 -05:00
|
|
|
switch {
|
|
|
|
case input == "file":
|
2015-03-06 00:09:16 -05:00
|
|
|
return server.File
|
2015-03-16 14:46:16 -04:00
|
|
|
case input == "memory":
|
|
|
|
return server.Memory
|
2015-03-23 23:06:15 -04:00
|
|
|
case input == "donut":
|
|
|
|
return server.Donut
|
2015-03-25 20:03:21 -04:00
|
|
|
case input == "":
|
|
|
|
return server.Donut
|
2015-02-01 05:35:00 -05:00
|
|
|
default:
|
|
|
|
{
|
2015-03-25 20:03:21 -04:00
|
|
|
log.Fatal("Unknown driver type: '", input, "', Please specify a valid driver.")
|
|
|
|
return -1 // should never reach here
|
2015-02-01 05:35:00 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func runCmd(c *cli.Context) {
|
2015-03-23 23:40:21 -04:00
|
|
|
driverTypeStr := c.String("driver-type")
|
2015-02-23 05:11:27 -05:00
|
|
|
domain := c.String("domain")
|
2015-02-01 05:35:00 -05:00
|
|
|
apiaddress := c.String("api-address")
|
|
|
|
webaddress := c.String("web-address")
|
|
|
|
certFile := c.String("cert")
|
|
|
|
keyFile := c.String("key")
|
|
|
|
if (certFile != "" && keyFile == "") || (certFile == "" && keyFile != "") {
|
|
|
|
log.Fatal("Both certificate and key must be provided to enable https")
|
|
|
|
}
|
|
|
|
tls := (certFile != "" && keyFile != "")
|
2015-03-23 23:40:21 -04:00
|
|
|
driverType := getDriverType(driverTypeStr)
|
2015-03-06 00:09:16 -05:00
|
|
|
var serverConfigs []server.Config
|
|
|
|
apiServerConfig := server.Config{
|
2015-02-23 05:11:27 -05:00
|
|
|
Domain: domain,
|
2015-02-01 05:35:00 -05:00
|
|
|
Address: apiaddress,
|
2015-03-06 00:09:16 -05:00
|
|
|
TLS: tls,
|
2015-02-01 05:35:00 -05:00
|
|
|
CertFile: certFile,
|
|
|
|
KeyFile: keyFile,
|
2015-03-06 00:09:16 -05:00
|
|
|
APIType: server.MinioAPI{
|
2015-03-23 23:40:21 -04:00
|
|
|
DriverType: driverType,
|
2015-02-01 05:35:00 -05:00
|
|
|
},
|
|
|
|
}
|
2015-03-06 00:09:16 -05:00
|
|
|
webUIServerConfig := server.Config{
|
2015-02-23 05:11:27 -05:00
|
|
|
Domain: domain,
|
2015-02-01 05:35:00 -05:00
|
|
|
Address: webaddress,
|
2015-03-06 00:09:16 -05:00
|
|
|
TLS: false,
|
2015-02-01 05:35:00 -05:00
|
|
|
CertFile: "",
|
|
|
|
KeyFile: "",
|
2015-03-18 20:49:33 -04:00
|
|
|
APIType: server.Web{
|
2015-02-01 05:35:00 -05:00
|
|
|
Websocket: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
serverConfigs = append(serverConfigs, apiServerConfig)
|
2015-03-03 15:00:28 -05:00
|
|
|
serverConfigs = append(serverConfigs, webUIServerConfig)
|
2015-02-01 05:35:00 -05:00
|
|
|
server.Start(serverConfigs)
|
|
|
|
}
|
|
|
|
|
2015-04-02 15:48:22 -04:00
|
|
|
// Convert bytes to human readable string. Like a 2 MB, 64.2 KB, 52 B
|
|
|
|
func formatBytes(i int64) (result string) {
|
|
|
|
switch {
|
|
|
|
case i > (1024 * 1024 * 1024 * 1024):
|
|
|
|
result = fmt.Sprintf("%.02f TB", float64(i)/1024/1024/1024/1024)
|
|
|
|
case i > (1024 * 1024 * 1024):
|
|
|
|
result = fmt.Sprintf("%.02f GB", float64(i)/1024/1024/1024)
|
|
|
|
case i > (1024 * 1024):
|
|
|
|
result = fmt.Sprintf("%.02f MB", float64(i)/1024/1024)
|
|
|
|
case i > 1024:
|
|
|
|
result = fmt.Sprintf("%.02f KB", float64(i)/1024)
|
|
|
|
default:
|
|
|
|
result = fmt.Sprintf("%d B", i)
|
|
|
|
}
|
|
|
|
result = strings.Trim(result, " ")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Tries to get os/arch/platform specific information
|
|
|
|
// Returns a map of current os/arch/platform/memstats
|
|
|
|
func getSystemData() map[string]string {
|
|
|
|
host, err := os.Hostname()
|
|
|
|
if err != nil {
|
|
|
|
host = ""
|
|
|
|
}
|
|
|
|
memstats := &runtime.MemStats{}
|
|
|
|
runtime.ReadMemStats(memstats)
|
|
|
|
mem := fmt.Sprintf("Used: %s | Allocated: %s | Used-Heap: %s | Allocated-Heap: %s",
|
|
|
|
formatBytes(int64(memstats.Alloc)),
|
|
|
|
formatBytes(int64(memstats.TotalAlloc)),
|
|
|
|
formatBytes(int64(memstats.HeapAlloc)),
|
|
|
|
formatBytes(int64(memstats.HeapSys)))
|
|
|
|
platform := fmt.Sprintf("Host: %s | OS: %s | Arch: %s",
|
|
|
|
host,
|
|
|
|
runtime.GOOS,
|
|
|
|
runtime.GOARCH)
|
|
|
|
goruntime := fmt.Sprintf("Version: %s | CPUs: %s", runtime.Version(), strconv.Itoa(runtime.NumCPU()))
|
|
|
|
return map[string]string{
|
|
|
|
"PLATFORM": platform,
|
|
|
|
"RUNTIME": goruntime,
|
|
|
|
"MEM": mem,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-14 14:29:04 -05:00
|
|
|
func main() {
|
2015-03-25 14:44:43 -04:00
|
|
|
// set up iodine
|
2015-04-02 15:48:22 -04:00
|
|
|
iodine.SetGlobalState("minio.git", minioGitCommitHash)
|
2015-03-25 14:44:43 -04:00
|
|
|
iodine.SetGlobalState("minio.starttime", time.Now().Format(time.RFC3339))
|
|
|
|
|
|
|
|
// set up app
|
2015-01-28 22:52:30 -05:00
|
|
|
app := cli.NewApp()
|
|
|
|
app.Name = "minio"
|
2015-04-02 15:48:22 -04:00
|
|
|
app.Version = minioGitCommitHash
|
2015-03-24 23:33:36 -04:00
|
|
|
app.Author = "Minio.io"
|
|
|
|
app.Usage = "Minimalist Object Storage"
|
|
|
|
app.EnableBashCompletion = true
|
|
|
|
app.Flags = flags
|
2015-02-01 05:35:00 -05:00
|
|
|
app.Action = runCmd
|
2015-04-02 15:48:22 -04:00
|
|
|
app.Before = func(c *cli.Context) error {
|
|
|
|
globalDebugFlag = c.GlobalBool("debug")
|
|
|
|
if globalDebugFlag {
|
|
|
|
app.ExtraInfo = getSystemData()
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
2015-03-25 20:03:21 -04:00
|
|
|
err := app.Run(os.Args)
|
2015-03-28 16:23:54 -04:00
|
|
|
if err != nil {
|
2015-03-28 18:58:48 -04:00
|
|
|
log.Error.Println(err)
|
2015-03-25 20:03:21 -04:00
|
|
|
}
|
2015-03-28 16:23:54 -04:00
|
|
|
|
2015-01-14 14:29:04 -05:00
|
|
|
}
|