mirror of
https://github.com/wyx2685/V2bX.git
synced 2025-01-22 09:58:14 -05:00
132 lines
2.8 KiB
Go
132 lines
2.8 KiB
Go
package cmd
|
|
|
|
import (
|
|
"os"
|
|
"os/signal"
|
|
"runtime"
|
|
"syscall"
|
|
|
|
"github.com/InazumaV/V2bX/conf"
|
|
vCore "github.com/InazumaV/V2bX/core"
|
|
"github.com/InazumaV/V2bX/limiter"
|
|
"github.com/InazumaV/V2bX/node"
|
|
log "github.com/sirupsen/logrus"
|
|
"github.com/spf13/cobra"
|
|
"gopkg.in/natefinch/lumberjack.v2"
|
|
)
|
|
|
|
var (
|
|
config string
|
|
watch bool
|
|
)
|
|
|
|
var serverCommand = cobra.Command{
|
|
Use: "server",
|
|
Short: "Run V2bX server",
|
|
Run: serverHandle,
|
|
Args: cobra.NoArgs,
|
|
}
|
|
|
|
func init() {
|
|
serverCommand.PersistentFlags().
|
|
StringVarP(&config, "config", "c",
|
|
"/etc/V2bX/config.json", "config file path")
|
|
serverCommand.PersistentFlags().
|
|
BoolVarP(&watch, "watch", "w",
|
|
true, "watch file path change")
|
|
command.AddCommand(&serverCommand)
|
|
}
|
|
|
|
func serverHandle(_ *cobra.Command, _ []string) {
|
|
showVersion()
|
|
c := conf.New()
|
|
err := c.LoadFromPath(config)
|
|
if err != nil {
|
|
log.WithField("err", err).Error("Load config file failed")
|
|
return
|
|
}
|
|
switch c.LogConfig.Level {
|
|
case "debug":
|
|
log.SetLevel(log.DebugLevel)
|
|
case "info":
|
|
log.SetLevel(log.InfoLevel)
|
|
case "warn":
|
|
log.SetLevel(log.WarnLevel)
|
|
case "error":
|
|
log.SetLevel(log.ErrorLevel)
|
|
}
|
|
if c.LogConfig.Output != "" {
|
|
w := &lumberjack.Logger{
|
|
Filename: c.LogConfig.Output,
|
|
MaxSize: 100,
|
|
MaxBackups: 3,
|
|
MaxAge: 28,
|
|
Compress: true,
|
|
}
|
|
log.SetOutput(w)
|
|
}
|
|
limiter.Init()
|
|
log.Info("Start V2bX...")
|
|
vc, err := vCore.NewCore(c.CoresConfig)
|
|
if err != nil {
|
|
log.WithField("err", err).Error("new core failed")
|
|
return
|
|
}
|
|
err = vc.Start()
|
|
if err != nil {
|
|
log.WithField("err", err).Error("Start core failed")
|
|
return
|
|
}
|
|
defer vc.Close()
|
|
log.Info("Core ", vc.Type(), " started")
|
|
nodes := node.New()
|
|
err = nodes.Start(c.NodeConfig, vc)
|
|
if err != nil {
|
|
log.WithField("err", err).Error("Run nodes failed")
|
|
return
|
|
}
|
|
log.Info("Nodes started")
|
|
xdns := os.Getenv("XRAY_DNS_PATH")
|
|
sdns := os.Getenv("SING_DNS_PATH")
|
|
if watch {
|
|
err = c.Watch(config, xdns, sdns, func() {
|
|
nodes.Close()
|
|
err = vc.Close()
|
|
if err != nil {
|
|
log.WithField("err", err).Error("Restart node failed")
|
|
return
|
|
}
|
|
vc, err = vCore.NewCore(c.CoresConfig)
|
|
if err != nil {
|
|
log.WithField("err", err).Error("New core failed")
|
|
return
|
|
}
|
|
err = vc.Start()
|
|
if err != nil {
|
|
log.WithField("err", err).Error("Start core failed")
|
|
return
|
|
}
|
|
log.Info("Core ", vc.Type(), " restarted")
|
|
err = nodes.Start(c.NodeConfig, vc)
|
|
if err != nil {
|
|
log.WithField("err", err).Error("Run nodes failed")
|
|
return
|
|
}
|
|
log.Info("Nodes restarted")
|
|
runtime.GC()
|
|
})
|
|
if err != nil {
|
|
log.WithField("err", err).Error("start watch failed")
|
|
return
|
|
}
|
|
}
|
|
// clear memory
|
|
runtime.GC()
|
|
// wait exit signal
|
|
{
|
|
osSignals := make(chan os.Signal, 1)
|
|
signal.Notify(osSignals, syscall.SIGINT, syscall.SIGKILL, syscall.SIGTERM)
|
|
<-osSignals
|
|
}
|
|
}
|