mirror of
https://github.com/TeaOSLab/EdgeAPI.git
synced 2025-11-03 15:00:27 +08:00
节点IP地址可以设置专属集群
This commit is contained in:
@@ -113,7 +113,7 @@ func CheckClusterDNS(tx *dbs.Tx, cluster *models.NodeCluster, checkNodeIssues bo
|
|||||||
// TODO 检查节点数量不能为0
|
// TODO 检查节点数量不能为0
|
||||||
|
|
||||||
for _, node := range nodes {
|
for _, node := range nodes {
|
||||||
nodeId := int64(node.Id)
|
var nodeId = int64(node.Id)
|
||||||
|
|
||||||
routeCodes, err := node.DNSRouteCodesForDomainId(domainId)
|
routeCodes, err := node.DNSRouteCodesForDomainId(domainId)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|||||||
@@ -121,7 +121,7 @@ func (this *NodeIPAddressDAO) FindAddressIsHealthy(tx *dbs.Tx, addressId int64)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// CreateAddress 创建IP地址
|
// CreateAddress 创建IP地址
|
||||||
func (this *NodeIPAddressDAO) CreateAddress(tx *dbs.Tx, adminId int64, nodeId int64, role nodeconfigs.NodeRole, name string, ip string, canAccess bool, isUp bool, groupId int64) (addressId int64, err error) {
|
func (this *NodeIPAddressDAO) CreateAddress(tx *dbs.Tx, adminId int64, nodeId int64, role nodeconfigs.NodeRole, name string, ip string, canAccess bool, isUp bool, groupId int64, clusterIds []int64) (addressId int64, err error) {
|
||||||
if len(role) == 0 {
|
if len(role) == 0 {
|
||||||
role = nodeconfigs.NodeRoleNode
|
role = nodeconfigs.NodeRoleNode
|
||||||
}
|
}
|
||||||
@@ -135,6 +135,17 @@ func (this *NodeIPAddressDAO) CreateAddress(tx *dbs.Tx, adminId int64, nodeId in
|
|||||||
op.IsUp = isUp
|
op.IsUp = isUp
|
||||||
op.GroupId = groupId
|
op.GroupId = groupId
|
||||||
|
|
||||||
|
// 集群
|
||||||
|
if len(clusterIds) == 0 {
|
||||||
|
op.ClusterIds = "[]"
|
||||||
|
} else {
|
||||||
|
clusterIdsJSON, err := json.Marshal(clusterIds)
|
||||||
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
op.ClusterIds = clusterIdsJSON
|
||||||
|
}
|
||||||
|
|
||||||
op.State = NodeIPAddressStateEnabled
|
op.State = NodeIPAddressStateEnabled
|
||||||
addressId, err = this.SaveInt64(tx, op)
|
addressId, err = this.SaveInt64(tx, op)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -156,7 +167,7 @@ func (this *NodeIPAddressDAO) CreateAddress(tx *dbs.Tx, adminId int64, nodeId in
|
|||||||
}
|
}
|
||||||
|
|
||||||
// UpdateAddress 修改IP地址
|
// UpdateAddress 修改IP地址
|
||||||
func (this *NodeIPAddressDAO) UpdateAddress(tx *dbs.Tx, adminId int64, addressId int64, name string, ip string, canAccess bool, isOn bool, isUp bool) (err error) {
|
func (this *NodeIPAddressDAO) UpdateAddress(tx *dbs.Tx, adminId int64, addressId int64, name string, ip string, canAccess bool, isOn bool, isUp bool, clusterIds []int64) (err error) {
|
||||||
if addressId <= 0 {
|
if addressId <= 0 {
|
||||||
return errors.New("invalid addressId")
|
return errors.New("invalid addressId")
|
||||||
}
|
}
|
||||||
@@ -169,6 +180,17 @@ func (this *NodeIPAddressDAO) UpdateAddress(tx *dbs.Tx, adminId int64, addressId
|
|||||||
op.IsOn = isOn
|
op.IsOn = isOn
|
||||||
op.IsUp = isUp
|
op.IsUp = isUp
|
||||||
|
|
||||||
|
// 集群
|
||||||
|
if len(clusterIds) == 0 {
|
||||||
|
op.ClusterIds = "[]"
|
||||||
|
} else {
|
||||||
|
clusterIdsJSON, err := json.Marshal(clusterIds)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
op.ClusterIds = clusterIdsJSON
|
||||||
|
}
|
||||||
|
|
||||||
op.State = NodeIPAddressStateEnabled // 恢复状态
|
op.State = NodeIPAddressStateEnabled // 恢复状态
|
||||||
err = this.Save(tx, op)
|
err = this.Save(tx, op)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ import "github.com/iwind/TeaGo/dbs"
|
|||||||
type NodeIPAddress struct {
|
type NodeIPAddress struct {
|
||||||
Id uint32 `field:"id"` // ID
|
Id uint32 `field:"id"` // ID
|
||||||
NodeId uint32 `field:"nodeId"` // 节点ID
|
NodeId uint32 `field:"nodeId"` // 节点ID
|
||||||
|
ClusterIds dbs.JSON `field:"clusterIds"` // 所属集群IDs
|
||||||
Role string `field:"role"` // 节点角色
|
Role string `field:"role"` // 节点角色
|
||||||
GroupId uint32 `field:"groupId"` // 所属分组ID
|
GroupId uint32 `field:"groupId"` // 所属分组ID
|
||||||
Name string `field:"name"` // 名称
|
Name string `field:"name"` // 名称
|
||||||
@@ -26,25 +27,26 @@ type NodeIPAddress struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type NodeIPAddressOperator struct {
|
type NodeIPAddressOperator struct {
|
||||||
Id interface{} // ID
|
Id any // ID
|
||||||
NodeId interface{} // 节点ID
|
NodeId any // 节点ID
|
||||||
Role interface{} // 节点角色
|
ClusterIds any // 所属集群IDs
|
||||||
GroupId interface{} // 所属分组ID
|
Role any // 节点角色
|
||||||
Name interface{} // 名称
|
GroupId any // 所属分组ID
|
||||||
Ip interface{} // IP地址
|
Name any // 名称
|
||||||
Description interface{} // 描述
|
Ip any // IP地址
|
||||||
State interface{} // 状态
|
Description any // 描述
|
||||||
Order interface{} // 排序
|
State any // 状态
|
||||||
CanAccess interface{} // 是否可以访问
|
Order any // 排序
|
||||||
IsOn interface{} // 是否启用
|
CanAccess any // 是否可以访问
|
||||||
IsUp interface{} // 是否上线
|
IsOn any // 是否启用
|
||||||
IsHealthy interface{} // 是否健康
|
IsUp any // 是否上线
|
||||||
Thresholds interface{} // 上线阈值
|
IsHealthy any // 是否健康
|
||||||
Connectivity interface{} // 连通性状态
|
Thresholds any // 上线阈值
|
||||||
BackupIP interface{} // 备用IP
|
Connectivity any // 连通性状态
|
||||||
BackupThresholdId interface{} // 触发备用IP的阈值
|
BackupIP any // 备用IP
|
||||||
CountUp interface{} // UP状态次数
|
BackupThresholdId any // 触发备用IP的阈值
|
||||||
CountDown interface{} // DOWN状态次数
|
CountUp any // UP状态次数
|
||||||
|
CountDown any // DOWN状态次数
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewNodeIPAddressOperator() *NodeIPAddressOperator {
|
func NewNodeIPAddressOperator() *NodeIPAddressOperator {
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import (
|
|||||||
"encoding/json"
|
"encoding/json"
|
||||||
"github.com/TeaOSLab/EdgeAPI/internal/remotelogs"
|
"github.com/TeaOSLab/EdgeAPI/internal/remotelogs"
|
||||||
"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
|
"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
|
||||||
|
"github.com/iwind/TeaGo/lists"
|
||||||
)
|
)
|
||||||
|
|
||||||
// DecodeConnectivity 解析联通数值
|
// DecodeConnectivity 解析联通数值
|
||||||
@@ -12,7 +13,7 @@ func (this *NodeIPAddress) DecodeConnectivity() *nodeconfigs.Connectivity {
|
|||||||
if len(this.Connectivity) > 0 {
|
if len(this.Connectivity) > 0 {
|
||||||
err := json.Unmarshal(this.Connectivity, connectivity)
|
err := json.Unmarshal(this.Connectivity, connectivity)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
remotelogs.Error("NodeIPAddress.DecodeConnectivity", "decode failed: "+err.Error())
|
remotelogs.Error("NodeIPAddress", "DecodeConnectivity(): decode failed: "+err.Error())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return connectivity
|
return connectivity
|
||||||
@@ -33,7 +34,7 @@ func (this *NodeIPAddress) DecodeBackupIP() string {
|
|||||||
// 阈值是否存在
|
// 阈值是否存在
|
||||||
b, err := SharedNodeIPAddressThresholdDAO.ExistsEnabledThreshold(nil, int64(this.BackupThresholdId))
|
b, err := SharedNodeIPAddressThresholdDAO.ExistsEnabledThreshold(nil, int64(this.BackupThresholdId))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
remotelogs.Error("NodeIPAddress.DNSIP", "check enabled threshold failed: "+err.Error())
|
remotelogs.Error("NodeIPAddress", "DecodeBackupIP(): check enabled threshold failed: "+err.Error())
|
||||||
} else {
|
} else {
|
||||||
if b {
|
if b {
|
||||||
return this.BackupIP
|
return this.BackupIP
|
||||||
@@ -42,3 +43,26 @@ func (this *NodeIPAddress) DecodeBackupIP() string {
|
|||||||
}
|
}
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// DecodeClusterIds 解析集群ID
|
||||||
|
func (this *NodeIPAddress) DecodeClusterIds() []int64 {
|
||||||
|
if IsNull(this.ClusterIds) {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var clusterIds = []int64{}
|
||||||
|
err := json.Unmarshal(this.ClusterIds, &clusterIds)
|
||||||
|
if err != nil {
|
||||||
|
remotelogs.Error("NodeIPAddress", "DecodeClusterIds(): "+err.Error())
|
||||||
|
}
|
||||||
|
return clusterIds
|
||||||
|
}
|
||||||
|
|
||||||
|
// IsValidInCluster 检查在某个集群中是否有效
|
||||||
|
func (this *NodeIPAddress) IsValidInCluster(clusterId int64) bool {
|
||||||
|
var clusterIds = this.DecodeClusterIds()
|
||||||
|
if len(clusterIds) == 0 {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return lists.ContainsInt64(clusterIds, clusterId)
|
||||||
|
}
|
||||||
|
|||||||
@@ -493,7 +493,12 @@ func (this *DNSDomainService) findClusterDNSChanges(cluster *models.NodeCluster,
|
|||||||
}
|
}
|
||||||
for _, route := range routeCodes {
|
for _, route := range routeCodes {
|
||||||
for _, ipAddress := range ipAddresses {
|
for _, ipAddress := range ipAddresses {
|
||||||
ip := ipAddress.DNSIP()
|
// 检查专属节点
|
||||||
|
if !ipAddress.IsValidInCluster(clusterId) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
var ip = ipAddress.DNSIP()
|
||||||
if len(ip) == 0 {
|
if len(ip) == 0 {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@@ -504,7 +509,7 @@ func (this *DNSDomainService) findClusterDNSChanges(cluster *models.NodeCluster,
|
|||||||
nodeKeys = append(nodeKeys, key)
|
nodeKeys = append(nodeKeys, key)
|
||||||
record, ok := nodeRecordMapping[key]
|
record, ok := nodeRecordMapping[key]
|
||||||
if !ok {
|
if !ok {
|
||||||
recordType := dnstypes.RecordTypeA
|
var recordType = dnstypes.RecordTypeA
|
||||||
if utils.IsIPv6(ip) {
|
if utils.IsIPv6(ip) {
|
||||||
recordType = dnstypes.RecordTypeAAAA
|
recordType = dnstypes.RecordTypeAAAA
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1347,6 +1347,11 @@ func (this *NodeService) FindAllEnabledNodesDNSWithNodeClusterId(ctx context.Con
|
|||||||
}
|
}
|
||||||
|
|
||||||
for _, ipAddress := range ipAddresses {
|
for _, ipAddress := range ipAddresses {
|
||||||
|
// 检查专属节点
|
||||||
|
if !ipAddress.IsValidInCluster(req.NodeClusterId) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
var ip = ipAddress.DNSIP()
|
var ip = ipAddress.DNSIP()
|
||||||
if len(ip) == 0 {
|
if len(ip) == 0 {
|
||||||
continue
|
continue
|
||||||
@@ -1539,7 +1544,7 @@ func (this *NodeService) UpdateNodeDNS(ctx context.Context, req *pb.UpdateNodeDN
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
_, err = models.SharedNodeIPAddressDAO.CreateAddress(tx, adminId, req.NodeId, nodeconfigs.NodeRoleNode, "DNS IP", req.IpAddr, true, true, 0)
|
_, err = models.SharedNodeIPAddressDAO.CreateAddress(tx, adminId, req.NodeId, nodeconfigs.NodeRoleNode, "DNS IP", req.IpAddr, true, true, 0, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,6 +3,8 @@ package services
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"github.com/TeaOSLab/EdgeAPI/internal/db/models"
|
"github.com/TeaOSLab/EdgeAPI/internal/db/models"
|
||||||
|
"github.com/TeaOSLab/EdgeAPI/internal/utils"
|
||||||
|
"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
|
||||||
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
||||||
"github.com/iwind/TeaGo/types"
|
"github.com/iwind/TeaGo/types"
|
||||||
)
|
)
|
||||||
@@ -21,7 +23,7 @@ func (this *NodeIPAddressService) CreateNodeIPAddress(ctx context.Context, req *
|
|||||||
|
|
||||||
var tx = this.NullTx()
|
var tx = this.NullTx()
|
||||||
|
|
||||||
addressId, err := models.SharedNodeIPAddressDAO.CreateAddress(tx, adminId, req.NodeId, req.Role, req.Name, req.Ip, req.CanAccess, req.IsUp, 0)
|
addressId, err := models.SharedNodeIPAddressDAO.CreateAddress(tx, adminId, req.NodeId, req.Role, req.Name, req.Ip, req.CanAccess, req.IsUp, 0, req.NodeClusterIds)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@@ -47,7 +49,7 @@ func (this *NodeIPAddressService) CreateNodeIPAddresses(ctx context.Context, req
|
|||||||
|
|
||||||
var result = []int64{}
|
var result = []int64{}
|
||||||
for _, ip := range req.IpList {
|
for _, ip := range req.IpList {
|
||||||
addressId, err := models.SharedNodeIPAddressDAO.CreateAddress(tx, adminId, req.NodeId, req.Role, req.Name, ip, req.CanAccess, req.IsUp, groupId)
|
addressId, err := models.SharedNodeIPAddressDAO.CreateAddress(tx, adminId, req.NodeId, req.Role, req.Name, ip, req.CanAccess, req.IsUp, groupId, req.NodeClusterIds)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@@ -67,7 +69,7 @@ func (this *NodeIPAddressService) UpdateNodeIPAddress(ctx context.Context, req *
|
|||||||
|
|
||||||
var tx = this.NullTx()
|
var tx = this.NullTx()
|
||||||
|
|
||||||
err = models.SharedNodeIPAddressDAO.UpdateAddress(tx, adminId, req.NodeIPAddressId, req.Name, req.Ip, req.CanAccess, req.IsOn, req.IsUp)
|
err = models.SharedNodeIPAddressDAO.UpdateAddress(tx, adminId, req.NodeIPAddressId, req.Name, req.Ip, req.CanAccess, req.IsOn, req.IsUp, req.ClusterIds)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@@ -143,27 +145,48 @@ func (this *NodeIPAddressService) FindEnabledNodeIPAddress(ctx context.Context,
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
if address == nil {
|
||||||
|
return &pb.FindEnabledNodeIPAddressResponse{
|
||||||
|
NodeIPAddress: nil,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
var result *pb.NodeIPAddress = nil
|
// CDN集群
|
||||||
if address != nil {
|
var pbNodeClusters = []*pb.NodeCluster{}
|
||||||
result = &pb.NodeIPAddress{
|
if len(address.ClusterIds) > 0 {
|
||||||
Id: int64(address.Id),
|
if address.Role == nodeconfigs.NodeRoleNode { // 边缘节点
|
||||||
NodeId: int64(address.NodeId),
|
var clusterIds = address.DecodeClusterIds()
|
||||||
Role: address.Role,
|
for _, clusterId := range clusterIds {
|
||||||
Name: address.Name,
|
cluster, err := models.SharedNodeClusterDAO.FindClusterBasicInfo(tx, clusterId, nil)
|
||||||
Ip: address.Ip,
|
if err != nil {
|
||||||
Description: address.Description,
|
return nil, err
|
||||||
State: int64(address.State),
|
}
|
||||||
Order: int64(address.Order),
|
if cluster != nil {
|
||||||
CanAccess: address.CanAccess,
|
pbNodeClusters = append(pbNodeClusters, &pb.NodeCluster{
|
||||||
IsOn: address.IsOn,
|
Id: int64(cluster.Id),
|
||||||
IsUp: address.IsUp,
|
Name: cluster.Name,
|
||||||
IsHealthy: address.IsHealthy,
|
})
|
||||||
BackupIP: address.DecodeBackupIP(),
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return &pb.FindEnabledNodeIPAddressResponse{NodeIPAddress: result}, nil
|
return &pb.FindEnabledNodeIPAddressResponse{NodeIPAddress: &pb.NodeIPAddress{
|
||||||
|
Id: int64(address.Id),
|
||||||
|
NodeId: int64(address.NodeId),
|
||||||
|
Role: address.Role,
|
||||||
|
Name: address.Name,
|
||||||
|
Ip: address.Ip,
|
||||||
|
Description: address.Description,
|
||||||
|
State: int64(address.State),
|
||||||
|
Order: int64(address.Order),
|
||||||
|
CanAccess: address.CanAccess,
|
||||||
|
IsOn: address.IsOn,
|
||||||
|
IsUp: address.IsUp,
|
||||||
|
IsHealthy: address.IsHealthy,
|
||||||
|
BackupIP: address.DecodeBackupIP(),
|
||||||
|
NodeClusters: pbNodeClusters,
|
||||||
|
}}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// FindAllEnabledNodeIPAddressesWithNodeId 查找节点的所有地址
|
// FindAllEnabledNodeIPAddressesWithNodeId 查找节点的所有地址
|
||||||
@@ -181,22 +204,44 @@ func (this *NodeIPAddressService) FindAllEnabledNodeIPAddressesWithNodeId(ctx co
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
result := []*pb.NodeIPAddress{}
|
var result = []*pb.NodeIPAddress{}
|
||||||
|
var cacheMap = utils.NewCacheMap()
|
||||||
for _, address := range addresses {
|
for _, address := range addresses {
|
||||||
|
// 集群
|
||||||
|
var pbNodeClusters = []*pb.NodeCluster{}
|
||||||
|
var clusterIds = address.DecodeClusterIds()
|
||||||
|
if len(clusterIds) > 0 {
|
||||||
|
if address.Role == nodeconfigs.NodeRoleNode { // 边缘节点
|
||||||
|
for _, clusterId := range clusterIds {
|
||||||
|
nodeCluster, err := models.SharedNodeClusterDAO.FindClusterBasicInfo(tx, clusterId, cacheMap)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if nodeCluster != nil {
|
||||||
|
pbNodeClusters = append(pbNodeClusters, &pb.NodeCluster{
|
||||||
|
Id: int64(nodeCluster.Id),
|
||||||
|
Name: nodeCluster.Name,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
result = append(result, &pb.NodeIPAddress{
|
result = append(result, &pb.NodeIPAddress{
|
||||||
Id: int64(address.Id),
|
Id: int64(address.Id),
|
||||||
NodeId: int64(address.NodeId),
|
NodeId: int64(address.NodeId),
|
||||||
Role: address.Role,
|
Role: address.Role,
|
||||||
Name: address.Name,
|
Name: address.Name,
|
||||||
Ip: address.Ip,
|
Ip: address.Ip,
|
||||||
Description: address.Description,
|
Description: address.Description,
|
||||||
State: int64(address.State),
|
State: int64(address.State),
|
||||||
Order: int64(address.Order),
|
Order: int64(address.Order),
|
||||||
CanAccess: address.CanAccess,
|
CanAccess: address.CanAccess,
|
||||||
IsOn: address.IsOn,
|
IsOn: address.IsOn,
|
||||||
IsUp: address.IsUp,
|
IsUp: address.IsUp,
|
||||||
IsHealthy: address.IsHealthy,
|
IsHealthy: address.IsHealthy,
|
||||||
BackupIP: address.DecodeBackupIP(),
|
BackupIP: address.DecodeBackupIP(),
|
||||||
|
NodeClusters: pbNodeClusters,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -236,18 +281,38 @@ func (this *NodeIPAddressService) ListEnabledNodeIPAddresses(ctx context.Context
|
|||||||
|
|
||||||
var pbAddrs = []*pb.NodeIPAddress{}
|
var pbAddrs = []*pb.NodeIPAddress{}
|
||||||
for _, addr := range addresses {
|
for _, addr := range addresses {
|
||||||
|
var clusterIds = addr.DecodeClusterIds()
|
||||||
|
var pbNodeClusters = []*pb.NodeCluster{}
|
||||||
|
if len(clusterIds) > 0 {
|
||||||
|
if addr.Role == nodeconfigs.NodeRoleNode { // 边缘节点
|
||||||
|
for _, clusterId := range clusterIds {
|
||||||
|
cluster, err := models.SharedNodeClusterDAO.FindClusterBasicInfo(tx, clusterId, nil)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if cluster != nil {
|
||||||
|
pbNodeClusters = append(pbNodeClusters, &pb.NodeCluster{
|
||||||
|
Id: int64(cluster.Id),
|
||||||
|
Name: cluster.Name,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pbAddrs = append(pbAddrs, &pb.NodeIPAddress{
|
pbAddrs = append(pbAddrs, &pb.NodeIPAddress{
|
||||||
Id: int64(addr.Id),
|
Id: int64(addr.Id),
|
||||||
NodeId: int64(addr.NodeId),
|
NodeId: int64(addr.NodeId),
|
||||||
Role: addr.Role,
|
Role: addr.Role,
|
||||||
Name: addr.Name,
|
Name: addr.Name,
|
||||||
Ip: addr.Ip,
|
Ip: addr.Ip,
|
||||||
Description: addr.Description,
|
Description: addr.Description,
|
||||||
CanAccess: addr.CanAccess,
|
CanAccess: addr.CanAccess,
|
||||||
IsOn: addr.IsOn,
|
IsOn: addr.IsOn,
|
||||||
IsUp: addr.IsUp,
|
IsUp: addr.IsUp,
|
||||||
IsHealthy: addr.IsHealthy,
|
IsHealthy: addr.IsHealthy,
|
||||||
BackupIP: addr.DecodeBackupIP(),
|
BackupIP: addr.DecodeBackupIP(),
|
||||||
|
NodeClusters: pbNodeClusters,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
return &pb.ListEnabledNodeIPAddressesResponse{NodeIPAddresses: pbAddrs}, nil
|
return &pb.ListEnabledNodeIPAddressesResponse{NodeIPAddresses: pbAddrs}, nil
|
||||||
|
|||||||
@@ -387,6 +387,11 @@ func (this *DNSTaskExecutor) doCluster(taskId int64, clusterId int64) error {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
for _, ipAddress := range ipAddresses {
|
for _, ipAddress := range ipAddresses {
|
||||||
|
// 检查专属节点
|
||||||
|
if !ipAddress.IsValidInCluster(clusterId) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
var ip = ipAddress.DNSIP()
|
var ip = ipAddress.DNSIP()
|
||||||
if len(ip) == 0 || !ipAddress.CanAccess || !ipAddress.IsUp || !ipAddress.IsOn {
|
if len(ip) == 0 || !ipAddress.CanAccess || !ipAddress.IsUp || !ipAddress.IsOn {
|
||||||
continue
|
continue
|
||||||
|
|||||||
Reference in New Issue
Block a user