Skip to content

Commit

Permalink
update policy route when subnet cidr changed
Browse files Browse the repository at this point in the history
  • Loading branch information
hongzhen-ma committed Jan 9, 2024
1 parent 6fad3a1 commit d4413fc
Show file tree
Hide file tree
Showing 2 changed files with 91 additions and 1 deletion.
74 changes: 73 additions & 1 deletion pkg/controller/subnet.go
Original file line number Diff line number Diff line change
Expand Up @@ -1159,7 +1159,13 @@ func (c *Controller) reconcileOvnRoute(subnet *kubeovnv1.Subnet) error {
}
}
} else {
if err = c.addCommonRoutesForSubnet(subnet); err != nil {
// It's diffcult to update policy route when subnet cidr is changed, add check for cidr changed situation
if err := c.reconcilePolicyRouteForCidrChangedSubnet(subnet, true); err != nil {
klog.Error(err)
return err
}

if err := c.addCommonRoutesForSubnet(subnet); err != nil {
klog.Error(err)
return err
}
Expand Down Expand Up @@ -1326,6 +1332,11 @@ func (c *Controller) reconcileOvnRoute(subnet *kubeovnv1.Subnet) error {
return fmt.Errorf("failed to add ecmp policy route, no gateway node exists")
}

if err := c.reconcilePolicyRouteForCidrChangedSubnet(subnet, false); err != nil {
klog.Error(err)
return err
}

if c.config.EnableEcmp {
// centralized subnet, enable ecmp, add ecmp policy route
gatewayNodes := strings.Split(subnet.Spec.GatewayNode, ",")
Expand Down Expand Up @@ -2353,3 +2364,64 @@ func (c *Controller) clearOldU2OResource(subnet *kubeovnv1.Subnet) error {
}
return nil
}

func (c *Controller) reconcilePolicyRouteForCidrChangedSubnet(subnet *kubeovnv1.Subnet, isCommonRoute bool) error {
var match string
var priority int32

if isCommonRoute {
priority = util.SubnetRouterPolicyPriority
} else {
priority = util.GatewayRouterPolicyPriority
}

policyMatches, err := c.ovnLegacyClient.FilterSubnetPolicyRoutes(priority, subnet.Name)
if err != nil {
klog.Errorf("failed to list logical router policies: %v", err)
return err
}
if len(policyMatches) == 0 {
return nil
}

for _, policyMatch := range policyMatches {
policyProtocol := kubeovnv1.ProtocolIPv4
if strings.Contains(policyMatch, "ip6") {
policyProtocol = kubeovnv1.ProtocolIPv6
}

for _, cidr := range strings.Split(subnet.Spec.CIDRBlock, ",") {
if cidr == "" {
continue
}
if policyProtocol != util.CheckProtocol(cidr) {
continue
}

af := 4
if util.CheckProtocol(cidr) == kubeovnv1.ProtocolIPv6 {
af = 6
}

if isCommonRoute {
match = fmt.Sprintf("ip%d.dst == %s", af, cidr)
} else {
if subnet.Spec.GatewayType == kubeovnv1.GWCentralizedType {
match = fmt.Sprintf("ip%d.src == %s", af, cidr)
} else {
// distributed subnet does not need process gateway route policy
continue
}
}

if policyMatch != match {
klog.Infof("delete old policy route for subnet %s with match %s priority %d, new match %v", subnet.Name, policyMatch, priority, match)
if err = c.ovnLegacyClient.DeletePolicyRoute(subnet.Spec.Vpc, priority, policyMatch); err != nil {
klog.Errorf("failed to delete policy route for subnet %s: %v", subnet.Name, err)
return err
}
}
}
}
return nil
}
18 changes: 18 additions & 0 deletions pkg/ovs/ovn-nbctl-legacy.go
Original file line number Diff line number Diff line change
Expand Up @@ -2652,6 +2652,24 @@ func (c *LegacyClient) GetPolicyRouteParas(priority int32, match string) ([]stri
return result[0]["nexthops"], nameIpMap, nil
}

func (c *LegacyClient) FilterSubnetPolicyRoutes(priority int32, subnetName string) ([]string, error) {
results, err := c.CustomFindEntity("Logical_Router_Policy", []string{"match"}, fmt.Sprintf("priority=%d", priority), fmt.Sprintf("external_ids:subnet=\"%s\"", subnetName), fmt.Sprintf("external_ids:vendor=\"%s\"", util.CniTypeName))
if err != nil {
klog.Errorf("customFindEntity failed, %v", err)
return nil, err
}
if len(results) == 0 {
return nil, nil
}

var policyMatches []string
for _, result := range results {
policyMatches = append(policyMatches, strings.Join(result["match"], " "))
}

return policyMatches, nil
}

func (c LegacyClient) SetPolicyRouteExternalIds(priority int32, match string, nameIpMaps map[string]string) error {
result, err := c.CustomFindEntity("Logical_Router_Policy", []string{"_uuid"}, fmt.Sprintf("priority=%d", priority), fmt.Sprintf("match=\"%s\"", match))
if err != nil {
Expand Down

0 comments on commit d4413fc

Please sign in to comment.