18 Star 179 Fork 36

vearch/vearch

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
startup.go 6.57 KB
一键复制 编辑 原始数据 按行查看 历史
ljeagle 提交于 2019-10-31 12:32 . Release v0.2
// Copyright 2019 The Vearch Authors.
//
// 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.
package main
import (
"context"
"flag"
"fmt"
"github.com/spf13/cast"
"github.com/vearch/vearch/util/reflect"
"github.com/vearch/vearch/util/vearchlog"
"net/http"
_ "net/http/pprof"
"os"
"runtime"
"strings"
"github.com/vearch/vearch/util/metrics/mserver"
"github.com/vearch/vearch/util/log"
"github.com/vearch/vearch/config"
"github.com/vearch/vearch/master"
"github.com/vearch/vearch/ps"
"github.com/vearch/vearch/router"
tigos "github.com/vearch/vearch/util/runtime/os"
"github.com/vearch/vearch/util/signals"
"time"
)
var (
BuildVersion = "0.0"
BuildTime = "0"
CommitID = "xxxxx"
confPath string
masterName string
)
func init() {
flag.StringVar(&confPath, "conf", getDefaultConfigFile(), "vearch config path")
flag.StringVar(&masterName, "master", "", "vearch config for master name , is on local start two master must use it")
}
const (
psTag = "ps"
masterTag = "master"
routerTag = "router"
allTag = "all"
)
func main() {
log.Info("start server by version:[%s] commitID:[%s]", BuildVersion, CommitID)
config.SetConfigVersion(BuildVersion, BuildTime, CommitID)
flag.Parse()
if strings.Compare(confPath, "") == 0 {
log.Error("Can not get the config file ,then exit the program!")
os.Exit(1)
}
log.Info("The Config File Is: %v", confPath)
config.InitConfig(confPath)
log.Info("The configuration content is:\n%s", reflect.ToString("conf", config.Conf()))
args := flag.Args()
if len(args) == 0 {
args = []string{allTag}
}
tags := map[string]bool{allTag: false, psTag: false, routerTag: false, masterTag: false}
for _, a := range args {
if _, ok := tags[a]; !ok {
panic(fmt.Sprintf("not found tags: %s it only support [ps,router, master or all]", a))
} else {
tags[a] = true
}
}
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
if log.IsDebugEnabled() {
go func() {
for {
select {
case <-ctx.Done():
return
default:
}
var mem runtime.MemStats
runtime.ReadMemStats(&mem)
log.Debug(fmt.Sprint("mem.Alloc:", mem.Alloc, " mem.TotalAlloc:", mem.TotalAlloc, " mem.HeapAlloc:", mem.HeapAlloc, " mem.HeapSys:", mem.HeapSys, " routing :", runtime.NumGoroutine()))
time.Sleep(10 * time.Second)
}
}()
}
sigsHook := signals.NewSignalHook()
var paths = make(map[string]bool)
var models []string
//start master
if tags[masterTag] || tags[allTag] {
if err := config.Conf().CurrentByMasterNameDomainIp(masterName); err != nil {
panic(err)
}
if err := config.Conf().Validate(config.Master); err != nil {
panic(err)
}
self := config.Conf().Masters.Self()
mserver.SetIp(self.Address, true)
paths[config.Conf().GetDataDir(config.Master)] = true
paths[config.Conf().GetLogDir(config.Master)] = true
models = append(models, "master")
s, err := master.NewServer(ctx)
if err != nil {
panic(fmt.Sprintf("new master error : %s", err.Error()))
}
sigsHook.AddSignalHook(func() {
s.Stop()
})
go func() {
if err := s.Start(); err != nil {
log.Error(fmt.Sprintf("start master error :%v", err))
os.Exit(-1)
}
}()
if port := config.Conf().Masters.Self().PprofPort; port > 0 {
go func() {
if err := http.ListenAndServe("0.0.0.0:"+cast.ToString(port), nil); err != nil {
log.Error(err.Error())
}
}()
}
}
//start ps
if tags[psTag] || tags[allTag] {
if err := config.Conf().Validate(config.PS); err != nil {
panic(err)
}
server := ps.NewServer(ctx)
datas := config.Conf().GetDatas(config.PS)
for _, dp := range datas {
paths[dp] = true
}
paths[config.Conf().GetLogDir(config.PS)] = true
models = append(models, "ps")
log.Debug("dataDir: %s", config.Conf().GetDataDir(config.PS))
sigsHook.AddSignalHook(func() {
vearchlog.CloseIfNotNil(server)
})
go func() {
if err := server.Start(); err != nil {
log.Error(fmt.Sprintf("start ps error :%v", err))
os.Exit(-1)
}
}()
if port := config.Conf().PS.PprofPort; port > 0 {
go func() {
if err := http.ListenAndServe("0.0.0.0:"+cast.ToString(port), nil); err != nil {
log.Error(err.Error())
}
}()
}
}
//start router
if tags[routerTag] || tags[allTag] {
if err := config.Conf().Validate(config.Router); err != nil {
panic(err)
}
server, err := router.NewServer(ctx)
if err != nil {
panic(fmt.Sprintf("new router error :%v", err))
}
log.Info("Starting Router ...")
paths[config.Conf().GetDataDir(config.Router)] = true
paths[config.Conf().GetLogDir(config.Router)] = true
models = append(models, "router")
sigsHook.AddSignalHook(func() {
fmt.Println("stop router begin")
cancel()
server.Shutdown()
})
go func() {
if err := server.Start(); err != nil {
panic(fmt.Sprintf("start router error :%v", err))
}
}()
if port := config.Conf().Router.PprofPort; port > 0 {
go func() {
if err := http.ListenAndServe("0.0.0.0:"+cast.ToString(port), nil); err != nil {
log.Error(err.Error())
}
}()
}
}
var psPath []string
for k := range paths {
psPath = append(psPath, k)
}
mserver.Start(ctx, psPath)
mserver.AddLabel("models", strings.Join(models, ","))
sigsHook.WaitSignals()
sigsHook.AsyncInvokeHooks()
sigsHook.WaitUntilTimeout(30 * time.Second)
}
func getDefaultConfigFile() (defaultConfigFile string) {
if currentExePath, err := tigos.GetCurrentPath(); err == nil {
path := currentExePath + "config/config.toml"
if ok, err := pathExists(path); ok {
return path
} else if err != nil {
log.Error("check path:%s err : %s", path, err.Error())
}
}
if sourceCodeFileName, err := tigos.GetCurrentSourceCodePath(); nil == err {
lastIndex := strings.LastIndex(sourceCodeFileName, "/")
path := sourceCodeFileName[0:lastIndex+1] + "config/config.toml"
if ok, err := pathExists(path); ok {
return path
} else if err != nil {
log.Error("check path:%s err : %s", path, err.Error())
}
}
return
}
func pathExists(path string) (bool, error) {
_, err := os.Stat(path)
if err == nil {
return true, nil
}
if os.IsNotExist(err) {
return false, nil
}
return false, err
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/vearch/vearch.git
[email protected]:vearch/vearch.git
vearch
vearch
vearch
master

搜索帮助