mirror of
				https://github.com/TeaOSLab/EdgeAPI.git
				synced 2025-11-04 07:50:25 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			66 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package apis
 | 
						|
 | 
						|
import (
 | 
						|
	"errors"
 | 
						|
	"github.com/TeaOSLab/EdgeAPI/internal/configs"
 | 
						|
	"github.com/TeaOSLab/EdgeAPI/internal/rpc/pb"
 | 
						|
	"github.com/TeaOSLab/EdgeAPI/internal/rpc/services"
 | 
						|
	"github.com/TeaOSLab/EdgeAPI/internal/utils"
 | 
						|
	"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
 | 
						|
 | 
						|
	// 设置rlimit
 | 
						|
	_ = utils.SetRLimit(1024 * 1024)
 | 
						|
 | 
						|
	// 监听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()
 | 
						|
	pb.RegisterAdminServiceServer(rpcServer, &services.AdminService{})
 | 
						|
	pb.RegisterNodeGrantServiceServer(rpcServer, &services.NodeGrantService{})
 | 
						|
	pb.RegisterServerServiceServer(rpcServer, &services.ServerService{})
 | 
						|
	pb.RegisterNodeServiceServer(rpcServer, &services.NodeService{})
 | 
						|
	pb.RegisterNodeClusterServiceServer(rpcServer, &services.NodeClusterService{})
 | 
						|
	err = rpcServer.Serve(listener)
 | 
						|
	if err != nil {
 | 
						|
		return errors.New("[API]start rpc failed: " + err.Error())
 | 
						|
	}
 | 
						|
 | 
						|
	return nil
 | 
						|
}
 |