Files
EdgeAPI/internal/apis/api_node.go

69 lines
1.8 KiB
Go
Raw Normal View History

2020-07-21 17:27:00 +08:00
package apis
import (
"errors"
"github.com/TeaOSLab/EdgeAPI/internal/configs"
2020-07-24 09:17:48 +08:00
"github.com/TeaOSLab/EdgeAPI/internal/rpc/pb"
"github.com/TeaOSLab/EdgeAPI/internal/rpc/services"
2020-07-22 22:17:53 +08:00
"github.com/TeaOSLab/EdgeAPI/internal/utils"
2020-07-21 17:27:00 +08:00
"github.com/iwind/TeaGo/logs"
"google.golang.org/grpc"
"net"
"os"
"strconv"
)
var sharedAPIConfig *configs.APIConfig = nil
type APINode struct {
}
func NewAPINode() *APINode {
return &APINode{}
}
func (this *APINode) Start() {
logs.Println("[API]start api node, pid: " + strconv.Itoa(os.Getpid()))
config, err := configs.SharedAPIConfig()
if err != nil {
logs.Println("[API]start failed: " + err.Error())
return
}
sharedAPIConfig = config
2020-07-22 22:17:53 +08:00
// 设置rlimit
_ = utils.SetRLimit(1024 * 1024)
2020-07-21 17:27:00 +08:00
// 监听RPC服务
logs.Println("[API]start rpc: " + config.RPC.Listen)
err = this.listenRPC()
if err != nil {
logs.Println(err.Error())
return
}
}
// 启动RPC监听
func (this *APINode) listenRPC() error {
listener, err := net.Listen("tcp", sharedAPIConfig.RPC.Listen)
if err != nil {
return errors.New("[API]listen rpc failed: " + err.Error())
}
rpcServer := grpc.NewServer()
2020-07-24 09:17:48 +08:00
pb.RegisterDnsServiceServer(rpcServer, &services.DNSService{})
pb.RegisterLogServiceServer(rpcServer, &services.LogService{})
pb.RegisterMonitorServiceServer(rpcServer, &services.MonitorService{})
pb.RegisterNodeServiceServer(rpcServer, &services.NodeService{})
pb.RegisterProviderServiceServer(rpcServer, &services.ProviderService{})
pb.RegisterStatServiceServer(rpcServer, &services.StatService{})
pb.RegisterUserServiceServer(rpcServer, &services.UserService{})
pb.RegisterAdminServiceServer(rpcServer, &services.AdminService{})
2020-07-21 17:27:00 +08:00
err = rpcServer.Serve(listener)
if err != nil {
return errors.New("[API]start rpc failed: " + err.Error())
}
return nil
}