wheat-cache/gateway/cmd/root.go

70 lines
1.9 KiB
Go
Raw Normal View History

2021-09-29 21:43:59 +08:00
package cmd
import (
2021-10-16 22:52:37 +08:00
"fmt"
"net"
_ "gitee.com/timedb/wheatCache/conf"
wheatCodec "gitee.com/timedb/wheatCache/gateway/codec"
"gitee.com/timedb/wheatCache/gateway/proxy"
2021-10-24 20:03:35 +08:00
"gitee.com/timedb/wheatCache/gateway/transport"
2021-10-16 22:52:37 +08:00
"gitee.com/timedb/wheatCache/pkg/logx"
"gitee.com/timedb/wheatCache/pkg/util/server"
2021-09-29 21:43:59 +08:00
"github.com/spf13/cobra"
2021-10-16 22:52:37 +08:00
"github.com/spf13/viper"
"google.golang.org/grpc"
2021-09-29 21:43:59 +08:00
)
// rootCmd represents the base command when called without any subcommands
var rootCmd = &cobra.Command{
Use: "getway",
Short: "getway",
Long: `start getway server`,
2021-10-16 22:52:37 +08:00
Run: func(cmd *cobra.Command, args []string) {
host := viper.GetString("gateway.host")
port := viper.GetInt("gateway.port")
tcpAddr, err := net.ResolveTCPAddr("tcp", fmt.Sprintf("%s:%d", host, port))
if err != nil {
logx.Panic("get gateway addr err:%v", err)
}
listen, err := net.ListenTCP("tcp", tcpAddr)
if err != nil {
logx.Panic("get gateway tcp conn err:%v", err)
}
gatewayServer := GetGatewayServer()
server.ElegantExitServer(gatewayServer)
logx.Info("start gateway in addr: %s", tcpAddr.String())
if err := gatewayServer.Serve(listen); err != nil {
logx.Errorln(err)
}
},
2021-09-29 21:43:59 +08:00
}
// Execute adds all child commands to the root command and sets flags appropriately.
// This is called by main.main(). It only needs to happen once to the rootCmd.
func Execute() {
cobra.CheckErr(rootCmd.Execute())
}
2021-10-16 22:52:37 +08:00
func GetGatewayServer() *grpc.Server {
2021-10-24 20:03:35 +08:00
targets := viper.GetStringSlice("gateway.target")
logx.Debug("service target in %v", targets)
stream := proxy.GetDirectorByServiceHash()
transport := transport.NewHashTransport(transport.HashReplicasDefault, nil, targets...)
2021-10-16 22:52:37 +08:00
opts := make([]grpc.ServerOption, 0)
opts = append(
opts,
grpc.ForceServerCodec(wheatCodec.Codec()),
2021-10-24 20:03:35 +08:00
grpc.UnknownServiceHandler(proxy.TransparentHandler(stream, transport)),
2021-10-16 22:52:37 +08:00
)
return grpc.NewServer(opts...)
}