2020-04-30 15:07:27 +08:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
|
|
|
"net"
|
|
|
|
_ "net/http/pprof"
|
|
|
|
"os"
|
|
|
|
"os/signal"
|
|
|
|
"strings"
|
|
|
|
"syscall"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/pingcap-incubator/tinykv/kv/config"
|
|
|
|
"github.com/pingcap-incubator/tinykv/kv/server"
|
|
|
|
"github.com/pingcap-incubator/tinykv/kv/storage"
|
|
|
|
"github.com/pingcap-incubator/tinykv/kv/storage/raft_storage"
|
|
|
|
"github.com/pingcap-incubator/tinykv/kv/storage/standalone_storage"
|
|
|
|
"github.com/pingcap-incubator/tinykv/log"
|
|
|
|
"github.com/pingcap-incubator/tinykv/proto/pkg/tinykvpb"
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
"google.golang.org/grpc/keepalive"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
schedulerAddr = flag.String("scheduler", "", "scheduler address")
|
|
|
|
storeAddr = flag.String("addr", "", "store address")
|
2020-03-21 23:16:07 +08:00
|
|
|
dbPath = flag.String("path", "", "directory path of db")
|
|
|
|
logLevel = flag.String("loglevel", "", "the level of log")
|
2020-04-30 15:07:27 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
flag.Parse()
|
|
|
|
conf := config.NewDefaultConfig()
|
|
|
|
if *schedulerAddr != "" {
|
|
|
|
conf.SchedulerAddr = *schedulerAddr
|
|
|
|
}
|
|
|
|
if *storeAddr != "" {
|
|
|
|
conf.StoreAddr = *storeAddr
|
|
|
|
}
|
2020-03-21 23:16:07 +08:00
|
|
|
if *dbPath != "" {
|
|
|
|
conf.DBPath = *dbPath
|
|
|
|
}
|
|
|
|
if *logLevel != "" {
|
|
|
|
conf.LogLevel = *logLevel
|
|
|
|
}
|
|
|
|
|
2020-04-30 15:07:27 +08:00
|
|
|
log.SetLevelByString(conf.LogLevel)
|
|
|
|
log.SetFlags(log.Ldate | log.Ltime | log.Lmicroseconds | log.Lshortfile)
|
2020-03-21 23:16:07 +08:00
|
|
|
log.Infof("Server started with conf %+v", conf)
|
2020-04-30 15:07:27 +08:00
|
|
|
|
|
|
|
var storage storage.Storage
|
|
|
|
if conf.Raft {
|
|
|
|
storage = raft_storage.NewRaftStorage(conf)
|
|
|
|
} else {
|
|
|
|
storage = standalone_storage.NewStandAloneStorage(conf)
|
|
|
|
}
|
|
|
|
if err := storage.Start(); err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
server := server.NewServer(storage)
|
|
|
|
|
|
|
|
var alivePolicy = keepalive.EnforcementPolicy{
|
|
|
|
MinTime: 2 * time.Second, // If a client pings more than once every 2 seconds, terminate the connection
|
|
|
|
PermitWithoutStream: true, // Allow pings even when there are no active streams
|
|
|
|
}
|
|
|
|
|
|
|
|
grpcServer := grpc.NewServer(
|
|
|
|
grpc.KeepaliveEnforcementPolicy(alivePolicy),
|
|
|
|
grpc.InitialWindowSize(1<<30),
|
|
|
|
grpc.InitialConnWindowSize(1<<30),
|
|
|
|
grpc.MaxRecvMsgSize(10*1024*1024),
|
|
|
|
)
|
|
|
|
tinykvpb.RegisterTinyKvServer(grpcServer, server)
|
|
|
|
listenAddr := conf.StoreAddr[strings.IndexByte(conf.StoreAddr, ':'):]
|
|
|
|
l, err := net.Listen("tcp", listenAddr)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
handleSignal(grpcServer)
|
|
|
|
|
|
|
|
err = grpcServer.Serve(l)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
log.Info("Server stopped.")
|
|
|
|
}
|
|
|
|
|
|
|
|
func handleSignal(grpcServer *grpc.Server) {
|
|
|
|
sigCh := make(chan os.Signal, 1)
|
|
|
|
signal.Notify(sigCh,
|
|
|
|
syscall.SIGHUP,
|
|
|
|
syscall.SIGINT,
|
|
|
|
syscall.SIGTERM,
|
|
|
|
syscall.SIGQUIT)
|
|
|
|
go func() {
|
|
|
|
sig := <-sigCh
|
|
|
|
log.Infof("Got signal [%s] to exit.", sig)
|
|
|
|
grpcServer.Stop()
|
|
|
|
}()
|
|
|
|
}
|