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...)
|
|
|
|
}
|