2020-08-21 18:01:59 +03:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2020-08-22 14:03:45 +03:00
|
|
|
"fmt"
|
2020-08-21 18:01:59 +03:00
|
|
|
"net"
|
|
|
|
|
2021-01-18 11:56:14 +03:00
|
|
|
"github.com/nspcc-dev/neofs-node/pkg/util/logger"
|
|
|
|
"go.uber.org/zap"
|
2020-08-21 18:01:59 +03:00
|
|
|
"google.golang.org/grpc"
|
2020-10-14 23:35:48 +03:00
|
|
|
"google.golang.org/grpc/reflection"
|
2020-08-21 18:01:59 +03:00
|
|
|
)
|
|
|
|
|
2020-08-24 12:40:32 +03:00
|
|
|
func initGRPC(c *cfg) {
|
|
|
|
var err error
|
2020-08-21 18:01:59 +03:00
|
|
|
|
2020-09-16 10:45:08 +03:00
|
|
|
c.cfgGRPC.listener, err = net.Listen("tcp", c.viper.GetString(cfgListenAddress))
|
2020-08-24 12:40:32 +03:00
|
|
|
fatalOnErr(err)
|
2020-08-22 18:20:47 +03:00
|
|
|
|
2020-10-02 11:01:54 +03:00
|
|
|
c.cfgGRPC.server = grpc.NewServer(
|
|
|
|
grpc.MaxSendMsgSize(c.viper.GetInt(cfgMaxMsgSize)),
|
|
|
|
)
|
2021-01-18 11:56:14 +03:00
|
|
|
|
|
|
|
c.onShutdown(func() {
|
|
|
|
stopGRPC("NeoFS Public API", c.cfgGRPC.server, c.log)
|
|
|
|
})
|
2020-08-24 12:40:32 +03:00
|
|
|
}
|
2020-08-22 14:03:45 +03:00
|
|
|
|
2020-08-24 12:40:32 +03:00
|
|
|
func serveGRPC(c *cfg) {
|
2020-12-29 18:50:41 +03:00
|
|
|
c.wg.Add(1)
|
|
|
|
|
2020-08-22 14:03:45 +03:00
|
|
|
go func() {
|
|
|
|
defer func() {
|
|
|
|
c.wg.Done()
|
|
|
|
}()
|
|
|
|
|
2020-10-14 23:35:48 +03:00
|
|
|
// read more about reflect service at
|
|
|
|
// https://github.com/grpc/grpc-go/blob/master/Documentation/server-reflection-tutorial.md
|
|
|
|
if c.cfgGRPC.enableReflectService {
|
|
|
|
reflection.Register(c.cfgGRPC.server)
|
|
|
|
}
|
|
|
|
|
2020-08-24 12:40:32 +03:00
|
|
|
if err := c.cfgGRPC.server.Serve(c.cfgGRPC.listener); err != nil {
|
2020-08-22 14:03:45 +03:00
|
|
|
fmt.Println("gRPC server error", err)
|
|
|
|
}
|
|
|
|
}()
|
2020-08-21 18:01:59 +03:00
|
|
|
}
|
2021-01-18 11:56:14 +03:00
|
|
|
|
|
|
|
func stopGRPC(name string, s *grpc.Server, l *logger.Logger) {
|
|
|
|
l = l.With(zap.String("name", name))
|
|
|
|
|
|
|
|
l.Info("stopping gRPC server...")
|
|
|
|
|
|
|
|
s.GracefulStop()
|
|
|
|
|
|
|
|
l.Info("gRPC server stopped successfully")
|
|
|
|
}
|