package services import ( "context" "encoding/json" "errors" "github.com/TeaOSLab/EdgeAPI/internal/db/models" rpcutils "github.com/TeaOSLab/EdgeAPI/internal/rpc/utils" "github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb" "github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs" "github.com/iwind/TeaGo/logs" ) type ServerService struct { BaseService } // 创建服务 func (this *ServerService) CreateServer(ctx context.Context, req *pb.CreateServerRequest) (*pb.CreateServerResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } serverId, err := models.SharedServerDAO.CreateServer(req.AdminId, req.UserId, req.Type, req.Name, req.Description, string(req.ServerNamesJON), string(req.HttpJSON), string(req.HttpsJSON), string(req.TcpJSON), string(req.TlsJSON), string(req.UnixJSON), string(req.UdpJSON), req.WebId, req.ReverseProxyJSON, req.NodeClusterId, string(req.IncludeNodesJSON), string(req.ExcludeNodesJSON), req.GroupIds) if err != nil { return nil, err } // 更新节点版本 err = models.SharedNodeDAO.IncreaseAllNodesLatestVersionMatch(req.NodeClusterId) if err != nil { return nil, err } return &pb.CreateServerResponse{ServerId: serverId}, nil } // 修改服务 func (this *ServerService) UpdateServerBasic(ctx context.Context, req *pb.UpdateServerBasicRequest) (*pb.RPCSuccess, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } if req.ServerId <= 0 { return nil, errors.New("invalid serverId") } // 查询老的节点信息 server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return nil, errors.New("can not find server") } err = models.SharedServerDAO.UpdateServerBasic(req.ServerId, req.Name, req.Description, req.NodeClusterId, req.IsOn, req.GroupIds) if err != nil { return nil, err } // 检查服务变化 oldIsOn := server.IsOn == 1 if oldIsOn != req.IsOn { go func() { err := this.notifyServerDNSChanged(req.ServerId) if err != nil { logs.Println("[DNS]notify server changed: " + err.Error()) } }() } // 更新老的节点版本 if req.NodeClusterId != int64(server.ClusterId) { err = models.SharedNodeDAO.IncreaseAllNodesLatestVersionMatch(int64(server.ClusterId)) if err != nil { return nil, err } } // 更新新的节点版本 err = models.SharedNodeDAO.IncreaseAllNodesLatestVersionMatch(req.NodeClusterId) if err != nil { return nil, err } return this.Success() } // 修改HTTP服务 func (this *ServerService) UpdateServerHTTP(ctx context.Context, req *pb.UpdateServerHTTPRequest) (*pb.RPCSuccess, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } if req.ServerId <= 0 { return nil, errors.New("invalid serverId") } // 查询老的节点信息 server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return nil, errors.New("can not find server") } // 修改配置 err = models.SharedServerDAO.UpdateServerHTTP(req.ServerId, req.Config) if err != nil { return nil, err } return this.Success() } // 修改HTTPS服务 func (this *ServerService) UpdateServerHTTPS(ctx context.Context, req *pb.UpdateServerHTTPSRequest) (*pb.RPCSuccess, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } if req.ServerId <= 0 { return nil, errors.New("invalid serverId") } // 查询老的节点信息 server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return nil, errors.New("can not find server") } // 修改配置 err = models.SharedServerDAO.UpdateServerHTTPS(req.ServerId, req.Config) if err != nil { return nil, err } return this.Success() } // 修改TCP服务 func (this *ServerService) UpdateServerTCP(ctx context.Context, req *pb.UpdateServerTCPRequest) (*pb.RPCSuccess, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } if req.ServerId <= 0 { return nil, errors.New("invalid serverId") } // 查询老的节点信息 server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return nil, errors.New("can not find server") } // 修改配置 err = models.SharedServerDAO.UpdateServerTCP(req.ServerId, req.Config) if err != nil { return nil, err } return this.Success() } // 修改TLS服务 func (this *ServerService) UpdateServerTLS(ctx context.Context, req *pb.UpdateServerTLSRequest) (*pb.RPCSuccess, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } if req.ServerId <= 0 { return nil, errors.New("invalid serverId") } // 查询老的节点信息 server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return nil, errors.New("can not find server") } // 修改配置 err = models.SharedServerDAO.UpdateServerTLS(req.ServerId, req.Config) if err != nil { return nil, err } return this.Success() } // 修改Unix服务 func (this *ServerService) UpdateServerUnix(ctx context.Context, req *pb.UpdateServerUnixRequest) (*pb.RPCSuccess, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } if req.ServerId <= 0 { return nil, errors.New("invalid serverId") } // 查询老的节点信息 server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return nil, errors.New("can not find server") } // 修改配置 err = models.SharedServerDAO.UpdateServerUnix(req.ServerId, req.Config) if err != nil { return nil, err } return this.Success() } // 修改UDP服务 func (this *ServerService) UpdateServerUDP(ctx context.Context, req *pb.UpdateServerUDPRequest) (*pb.RPCSuccess, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } if req.ServerId <= 0 { return nil, errors.New("invalid serverId") } // 查询老的节点信息 server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return nil, errors.New("can not find server") } // 修改配置 err = models.SharedServerDAO.UpdateServerUDP(req.ServerId, req.Config) if err != nil { return nil, err } return this.Success() } // 修改Web服务 func (this *ServerService) UpdateServerWeb(ctx context.Context, req *pb.UpdateServerWebRequest) (*pb.RPCSuccess, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } if req.ServerId <= 0 { return nil, errors.New("invalid serverId") } // 查询老的节点信息 server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return nil, errors.New("can not find server") } // 修改配置 err = models.SharedServerDAO.UpdateServerWeb(req.ServerId, req.WebId) if err != nil { return nil, err } return this.Success() } // 修改反向代理服务 func (this *ServerService) UpdateServerReverseProxy(ctx context.Context, req *pb.UpdateServerReverseProxyRequest) (*pb.RPCSuccess, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } if req.ServerId <= 0 { return nil, errors.New("invalid serverId") } // 查询老的节点信息 server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return nil, errors.New("can not find server") } // 修改配置 err = models.SharedServerDAO.UpdateServerReverseProxy(req.ServerId, req.ReverseProxyJSON) if err != nil { return nil, err } return this.Success() } // 查找服务的域名设置 func (this *ServerService) FindServerNames(ctx context.Context, req *pb.FindServerNamesRequest) (*pb.FindServerNamesResponse, error) { _, err := this.ValidateAdmin(ctx, 0) if err != nil { return nil, err } serverNamesJSON, err := models.SharedServerDAO.FindServerNames(req.ServerId) if err != nil { return nil, err } return &pb.FindServerNamesResponse{ServerNamesJSON: serverNamesJSON}, nil } // 修改域名服务 func (this *ServerService) UpdateServerNames(ctx context.Context, req *pb.UpdateServerNamesRequest) (*pb.RPCSuccess, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } if req.ServerId <= 0 { return nil, errors.New("invalid serverId") } // 查询老的节点信息 server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return nil, errors.New("can not find server") } // 修改配置 err = models.SharedServerDAO.UpdateServerNames(req.ServerId, req.Config) if err != nil { return nil, err } return this.Success() } // 计算服务数量 func (this *ServerService) CountAllEnabledServersMatch(ctx context.Context, req *pb.CountAllEnabledServersMatchRequest) (*pb.RPCCountResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } count, err := models.SharedServerDAO.CountAllEnabledServersMatch(req.GroupId, req.Keyword, 0) if err != nil { return nil, err } return this.SuccessCount(count) } // 列出单页服务 func (this *ServerService) ListEnabledServersMatch(ctx context.Context, req *pb.ListEnabledServersMatchRequest) (*pb.ListEnabledServersMatchResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } servers, err := models.SharedServerDAO.ListEnabledServersMatch(req.Offset, req.Size, req.GroupId, req.Keyword) if err != nil { return nil, err } result := []*pb.Server{} for _, server := range servers { clusterName, err := models.SharedNodeClusterDAO.FindNodeClusterName(int64(server.ClusterId)) if err != nil { return nil, err } // 分组信息 pbGroups := []*pb.ServerGroup{} if len(server.GroupIds) > 0 { groupIds := []int64{} err = json.Unmarshal([]byte(server.GroupIds), &groupIds) if err != nil { return nil, err } for _, groupId := range groupIds { group, err := models.SharedServerGroupDAO.FindEnabledServerGroup(groupId) if err != nil { return nil, err } if group == nil { continue } pbGroups = append(pbGroups, &pb.ServerGroup{ Id: int64(group.Id), Name: group.Name, }) } } // 用户 user, err := models.SharedUserDAO.FindEnabledBasicUser(int64(server.UserId)) if err != nil { return nil, err } var pbUser *pb.User = nil if user != nil { pbUser = &pb.User{ Id: int64(user.Id), Fullname: user.Fullname, } } result = append(result, &pb.Server{ Id: int64(server.Id), IsOn: server.IsOn == 1, Type: server.Type, Config: []byte(server.Config), Name: server.Name, Description: server.Description, HttpJSON: []byte(server.Http), HttpsJSON: []byte(server.Https), TcpJSON: []byte(server.Tcp), TlsJSON: []byte(server.Tls), UnixJSON: []byte(server.Unix), UdpJSON: []byte(server.Udp), IncludeNodes: []byte(server.IncludeNodes), ExcludeNodes: []byte(server.ExcludeNodes), ServerNamesJSON: []byte(server.ServerNames), CreatedAt: int64(server.CreatedAt), DnsName: server.DnsName, NodeCluster: &pb.NodeCluster{ Id: int64(server.ClusterId), Name: clusterName, }, Groups: pbGroups, User: pbUser, }) } return &pb.ListEnabledServersMatchResponse{Servers: result}, nil } // 禁用某服务 func (this *ServerService) DisableServer(ctx context.Context, req *pb.DisableServerRequest) (*pb.DisableServerResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } // 查找服务 server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return nil, errors.New("can not find the server") } // 禁用服务 err = models.SharedServerDAO.DisableServer(req.ServerId) if err != nil { return nil, err } // 更新节点版本 err = models.SharedNodeDAO.IncreaseAllNodesLatestVersionMatch(int64(server.ClusterId)) if err != nil { return nil, err } return &pb.DisableServerResponse{}, nil } // 查找单个服务 func (this *ServerService) FindEnabledServer(ctx context.Context, req *pb.FindEnabledServerRequest) (*pb.FindEnabledServerResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } server, err := models.SharedServerDAO.FindEnabledServer(req.ServerId) if err != nil { return nil, err } if server == nil { return &pb.FindEnabledServerResponse{}, nil } // 集群信息 clusterName, err := models.SharedNodeClusterDAO.FindNodeClusterName(int64(server.ClusterId)) if err != nil { return nil, err } // 分组信息 pbGroups := []*pb.ServerGroup{} if len(server.GroupIds) > 0 { groupIds := []int64{} err = json.Unmarshal([]byte(server.GroupIds), &groupIds) if err != nil { return nil, err } for _, groupId := range groupIds { group, err := models.SharedServerGroupDAO.FindEnabledServerGroup(groupId) if err != nil { return nil, err } if group == nil { continue } pbGroups = append(pbGroups, &pb.ServerGroup{ Id: int64(group.Id), Name: group.Name, }) } } return &pb.FindEnabledServerResponse{Server: &pb.Server{ Id: int64(server.Id), IsOn: server.IsOn == 1, Type: server.Type, Name: server.Name, Description: server.Description, DnsName: server.DnsName, Config: []byte(server.Config), ServerNamesJSON: []byte(server.ServerNames), HttpJSON: []byte(server.Http), HttpsJSON: []byte(server.Https), TcpJSON: []byte(server.Tcp), TlsJSON: []byte(server.Tls), UnixJSON: []byte(server.Unix), UdpJSON: []byte(server.Udp), WebId: int64(server.WebId), ReverseProxyJSON: []byte(server.ReverseProxy), IncludeNodes: []byte(server.IncludeNodes), ExcludeNodes: []byte(server.ExcludeNodes), CreatedAt: int64(server.CreatedAt), NodeCluster: &pb.NodeCluster{ Id: int64(server.ClusterId), Name: clusterName, }, Groups: pbGroups, }}, nil } // func (this *ServerService) FindEnabledServerType(ctx context.Context, req *pb.FindEnabledServerTypeRequest) (*pb.FindEnabledServerTypeResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } serverType, err := models.SharedServerDAO.FindEnabledServerType(req.ServerId) if err != nil { return nil, err } return &pb.FindEnabledServerTypeResponse{Type: serverType}, nil } // 查找反向代理设置 func (this *ServerService) FindAndInitServerReverseProxyConfig(ctx context.Context, req *pb.FindAndInitServerReverseProxyConfigRequest) (*pb.FindAndInitServerReverseProxyConfigResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } reverseProxyRef, err := models.SharedServerDAO.FindReverseProxyRef(req.ServerId) if err != nil { return nil, err } if reverseProxyRef == nil { reverseProxyId, err := models.SharedReverseProxyDAO.CreateReverseProxy(nil, nil, nil) if err != nil { return nil, err } reverseProxyRef = &serverconfigs.ReverseProxyRef{ IsOn: false, ReverseProxyId: reverseProxyId, } refJSON, err := json.Marshal(reverseProxyRef) if err != nil { return nil, err } err = models.SharedServerDAO.UpdateServerReverseProxy(req.ServerId, refJSON) if err != nil { return nil, err } } reverseProxyConfig, err := models.SharedReverseProxyDAO.ComposeReverseProxyConfig(reverseProxyRef.ReverseProxyId) if err != nil { return nil, err } configJSON, err := json.Marshal(reverseProxyConfig) if err != nil { return nil, err } refJSON, err := json.Marshal(reverseProxyRef) if err != nil { return nil, err } return &pb.FindAndInitServerReverseProxyConfigResponse{ReverseProxyJSON: configJSON, ReverseProxyRefJSON: refJSON}, nil } // 初始化Web设置 func (this *ServerService) FindAndInitServerWebConfig(ctx context.Context, req *pb.FindAndInitServerWebConfigRequest) (*pb.FindAndInitServerWebConfigResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } webId, err := models.SharedServerDAO.FindServerWebId(req.ServerId) if err != nil { return nil, err } if webId == 0 { webId, err = models.SharedServerDAO.InitServerWeb(req.ServerId) if err != nil { return nil, err } } config, err := models.SharedHTTPWebDAO.ComposeWebConfig(webId) if err != nil { return nil, err } configJSON, err := json.Marshal(config) if err != nil { return nil, err } return &pb.FindAndInitServerWebConfigResponse{WebJSON: configJSON}, nil } // 计算使用某个SSL证书的服务数量 func (this *ServerService) CountAllEnabledServersWithSSLCertId(ctx context.Context, req *pb.CountAllEnabledServersWithSSLCertIdRequest) (*pb.RPCCountResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } policyIds, err := models.SharedSSLPolicyDAO.FindAllEnabledPolicyIdsWithCertId(req.CertId) if err != nil { return nil, err } if len(policyIds) == 0 { return this.SuccessCount(0) } count, err := models.SharedServerDAO.CountAllEnabledServersWithSSLPolicyIds(policyIds) if err != nil { return nil, err } return this.SuccessCount(count) } // 查找使用某个SSL证书的所有服务 func (this *ServerService) FindAllEnabledServersWithSSLCertId(ctx context.Context, req *pb.FindAllEnabledServersWithSSLCertIdRequest) (*pb.FindAllEnabledServersWithSSLCertIdResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } policyIds, err := models.SharedSSLPolicyDAO.FindAllEnabledPolicyIdsWithCertId(req.CertId) if err != nil { return nil, err } if len(policyIds) == 0 { return &pb.FindAllEnabledServersWithSSLCertIdResponse{Servers: nil}, nil } servers, err := models.SharedServerDAO.FindAllEnabledServersWithSSLPolicyIds(policyIds) if err != nil { return nil, err } result := []*pb.Server{} for _, server := range servers { result = append(result, &pb.Server{ Id: int64(server.Id), Name: server.Name, IsOn: server.IsOn == 1, Type: server.Type, }) } return &pb.FindAllEnabledServersWithSSLCertIdResponse{Servers: result}, nil } // 计算运行在某个集群上的所有服务数量 func (this *ServerService) CountAllEnabledServersWithNodeClusterId(ctx context.Context, req *pb.CountAllEnabledServersWithNodeClusterIdRequest) (*pb.RPCCountResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } count, err := models.SharedServerDAO.CountAllEnabledServersWithNodeClusterId(req.NodeClusterId) if err != nil { return nil, err } return this.SuccessCount(count) } // 计算使用某个分组的服务数量 func (this *ServerService) CountAllEnabledServersWithGroupId(ctx context.Context, req *pb.CountAllEnabledServersWithGroupIdRequest) (*pb.RPCCountResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } count, err := models.SharedServerDAO.CountAllEnabledServersWithGroupId(req.GroupId) if err != nil { return nil, err } return this.SuccessCount(count) } // 通知更新 func (this *ServerService) NotifyServersChange(ctx context.Context, req *pb.NotifyServersChangeRequest) (*pb.NotifyServersChangeResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } err = models.SharedSysEventDAO.CreateEvent(models.NewServerChangeEvent()) if err != nil { return nil, err } return &pb.NotifyServersChangeResponse{}, nil } // 取得某个集群下的所有服务相关的DNS func (this *ServerService) FindAllEnabledServersDNSWithClusterId(ctx context.Context, req *pb.FindAllEnabledServersDNSWithClusterIdRequest) (*pb.FindAllEnabledServersDNSWithClusterIdResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } servers, err := models.SharedServerDAO.FindAllServersDNSWithClusterId(req.NodeClusterId) if err != nil { return nil, err } result := []*pb.ServerDNSInfo{} for _, server := range servers { // 如果子域名为空 if len(server.DnsName) == 0 { // 自动生成子域名 dnsName, err := models.SharedServerDAO.GenerateServerDNSName(int64(server.Id)) if err != nil { return nil, err } server.DnsName = dnsName } result = append(result, &pb.ServerDNSInfo{ Id: int64(server.Id), Name: server.Name, DnsName: server.DnsName, }) } return &pb.FindAllEnabledServersDNSWithClusterIdResponse{Servers: result}, nil } // 查找单个服务的DNS信息 func (this *ServerService) FindEnabledServerDNS(ctx context.Context, req *pb.FindEnabledServerDNSRequest) (*pb.FindEnabledServerDNSResponse, error) { // 校验请求 _, _, err := rpcutils.ValidateRequest(ctx, rpcutils.UserTypeAdmin) if err != nil { return nil, err } dnsName, err := models.SharedServerDAO.FindServerDNSName(req.ServerId) if err != nil { return nil, err } clusterId, err := models.SharedServerDAO.FindServerClusterId(req.ServerId) if err != nil { return nil, err } var pbDomain *pb.DNSDomain = nil if clusterId > 0 { clusterDNS, err := models.SharedNodeClusterDAO.FindClusterDNSInfo(clusterId) if err != nil { return nil, err } if clusterDNS != nil { domainId := int64(clusterDNS.DnsDomainId) if domainId > 0 { domain, err := models.SharedDNSDomainDAO.FindEnabledDNSDomain(domainId) if err != nil { return nil, err } if domain != nil { pbDomain = &pb.DNSDomain{ Id: domainId, Name: domain.Name, } } } } } return &pb.FindEnabledServerDNSResponse{ DnsName: dnsName, Domain: pbDomain, }, nil } // 自动同步DNS状态 func (this *ServerService) notifyServerDNSChanged(serverId int64) error { clusterId, err := models.SharedServerDAO.FindServerClusterId(serverId) if err != nil { return err } dnsInfo, err := models.SharedNodeClusterDAO.FindClusterDNSInfo(clusterId) if err != nil { return err } if dnsInfo == nil { return nil } if len(dnsInfo.DnsName) == 0 || dnsInfo.DnsDomainId == 0 { return nil } dnsConfig, err := dnsInfo.DecodeDNSConfig() if err != nil { return err } if !dnsConfig.ServersAutoSync { return nil } // 执行同步 domainService := &DNSDomainService{} resp, err := domainService.syncClusterDNS(&pb.SyncDNSDomainDataRequest{ DnsDomainId: int64(dnsInfo.DnsDomainId), NodeClusterId: clusterId, }) if err != nil { return err } if !resp.IsOk { err = models.SharedMessageDAO.CreateClusterMessage(clusterId, models.MessageTypeClusterDNSSyncFailed, models.LevelError, "集群DNS同步失败:"+resp.Error, nil) if err != nil { logs.Println("[NODE_SERVICE]" + err.Error()) } } return nil }