1 Star 0 Fork 0

xiedongji/antgo

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
grpc_server.go 1.82 KB
一键复制 编辑 原始数据 按行查看 历史
xiedongji 提交于 2023-03-17 21:17 +08:00 . 独立成框架
package xrpc
import (
ctls "crypto/tls"
"crypto/x509"
"gitee.com/xiedongji/antgo/cpts/xlog"
"google.golang.org/grpc"
"google.golang.org/grpc/credentials"
"net"
"os"
)
func GetRpcServer(tls *Tls, opt ...grpc.ServerOption) *Server {
s := &Server{
opt: opt,
tls: tls,
}
return s
}
type Server struct {
grpcServer *grpc.Server
opt []grpc.ServerOption
middleware []grpc.UnaryServerInterceptor
tls *Tls
}
type Tls struct {
Crt string
Key string
CACrt string
}
// 添加中间件
func (t *Server) Use(middleware ...grpc.UnaryServerInterceptor) {
t.middleware = append(t.middleware, middleware...)
}
func (t *Server) NewServer() (server *grpc.Server, err error) {
if t.grpcServer == nil {
// 添加 多个中间件
t.opt = append(t.opt, grpc.UnaryInterceptor(ChainUnaryServer(t.middleware...)))
// tls 配置
if t.tls != nil {
certificate, err := ctls.LoadX509KeyPair(t.tls.Crt, t.tls.Key)
if err != nil {
return nil, err
}
certPool := x509.NewCertPool()
ca, err := os.ReadFile(t.tls.CACrt)
if err != nil {
return nil, err
}
if ok := certPool.AppendCertsFromPEM(ca); !ok {
panic("AppendCertsFromPEM failed")
}
creds := credentials.NewTLS(&ctls.Config{
Certificates: []ctls.Certificate{certificate},
ClientAuth: ctls.RequireAndVerifyClientCert,
ClientCAs: certPool,
})
t.opt = append(t.opt, grpc.Creds(creds))
}
t.grpcServer = grpc.NewServer(t.opt...)
}
return t.grpcServer, nil
}
// 启动 GRPC 监听服务
func (t *Server) Run(addr string) error {
listener, err := net.Listen("tcp", addr)
if err != nil {
return err
}
xlog.Logger("grpc", "run").Info().Str("addr", addr).Msg("server ready")
if err := t.grpcServer.Serve(listener); err != nil {
xlog.Logger("grpc", "run").Error().Err(err).Send()
return err
}
return nil
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/xiedongji/antgo.git
git@gitee.com:xiedongji/antgo.git
xiedongji
antgo
antgo
v1.0.18

搜索帮助