Files
nats-server/gnatsd.go
2013-07-30 18:04:33 -07:00

98 lines
2.7 KiB
Go

// Copyright 2012 Apcera Inc. All rights reserved.
package main
import (
"flag"
"log"
"net/http"
_ "net/http/pprof"
"strings"
"github.com/apcera/gnatsd/server"
)
func main() {
// logging setup
server.LogSetup()
opts := server.Options{}
var showVersion bool
var debugAndTrace bool
var configFile string
// Parse flags
flag.IntVar(&opts.Port, "port", server.DEFAULT_PORT, "Port to listen on.")
flag.IntVar(&opts.Port, "p", server.DEFAULT_PORT, "Port to listen on.")
flag.StringVar(&opts.Host, "host", server.DEFAULT_HOST, "Network host to listen on.")
flag.StringVar(&opts.Host, "h", server.DEFAULT_HOST, "Network host to listen on.")
flag.StringVar(&opts.Host, "net", server.DEFAULT_HOST, "Network host to listen on.")
flag.BoolVar(&opts.Debug, "D", false, "Enable Debug logging.")
flag.BoolVar(&opts.Debug, "debug", false, "Enable Debug logging.")
flag.BoolVar(&opts.Trace, "V", false, "Enable Trace logging.")
flag.BoolVar(&opts.Trace, "trace", false, "Enable Trace logging.")
flag.BoolVar(&debugAndTrace, "DV", false, "Enable Debug and Trace logging.")
flag.StringVar(&opts.Username, "user", "", "Username required for connection.")
flag.StringVar(&opts.Password, "pass", "", "Password required for connection.")
flag.StringVar(&opts.Authorization, "auth", "", "Authorization token required for connection.")
flag.IntVar(&opts.HttpPort, "m", 0, "HTTP Port for /varz, /connz endpoints.")
flag.IntVar(&opts.HttpPort, "http_port", 0, "HTTP Port for /varz, /connz endpoints.")
flag.StringVar(&configFile, "c", "", "Configuration file.")
flag.StringVar(&configFile, "config", "", "Configuration file.")
flag.BoolVar(&showVersion, "version", false, "Print version information.")
flag.BoolVar(&showVersion, "v", false, "Print version information.")
flag.Parse()
// Show version and exit
if showVersion {
server.PrintServerAndExit()
}
if debugAndTrace {
opts.Trace, opts.Debug = true, true
}
// Process args, version only for now
for _, arg := range flag.Args() {
arg = strings.ToLower(arg)
if arg == "version" {
server.PrintServerAndExit()
}
}
var fileOpts *server.Options
var err error
// Parse config if given
if configFile != "" {
fileOpts, err = server.ProcessConfigFile(configFile)
if err != nil {
panic(err)
}
}
// Create the server with appropriate options.
mOpts := server.MergeOptions(fileOpts, &opts)
s := server.New(mOpts)
// Start up the http server if needed.
if mOpts.HttpPort != 0 {
s.StartHTTPMonitoring()
}
// Start up routing as well if needed.
if mOpts.ClusterPort != 0 {
s.StartRouting()
}
// Pprof http endpoint for the profiler.
go func() {
log.Println(http.ListenAndServe("localhost:6062", nil))
}()
// Wait for clients.
s.AcceptLoop()
}