From 247565124b062c879597a4d6792db2e6a75ca034 Mon Sep 17 00:00:00 2001 From: Trekkie Coder Date: Sat, 15 Jun 2024 18:23:29 +0900 Subject: [PATCH 1/2] Support for headless LB rules --- pkg/loxinet/rules.go | 67 +++++++++++++++++++++++++++----------------- 1 file changed, 41 insertions(+), 26 deletions(-) diff --git a/pkg/loxinet/rules.go b/pkg/loxinet/rules.go index bff9556da..f00ee6f40 100644 --- a/pkg/loxinet/rules.go +++ b/pkg/loxinet/rules.go @@ -1242,17 +1242,22 @@ func (R *RuleH) unFoldRecursiveEPs(r *ruleEnt) { // addVIPSys - system specific operations for VIPs of a LB rule func (R *RuleH) addVIPSys(r *ruleEnt) { if !strings.Contains(r.name, "ipvs") && !strings.Contains(r.name, "static") { - R.vipMap[r.tuples.l3Dst.addr.IP.String()]++ - if R.vipMap[r.tuples.l3Dst.addr.IP.String()] == 1 { - R.AdvRuleVIPIfL2(r.tuples.l3Dst.addr.IP) + if !r.tuples.l3Dst.addr.IP.IsUnspecified() { + R.vipMap[r.tuples.l3Dst.addr.IP.String()]++ + + if R.vipMap[r.tuples.l3Dst.addr.IP.String()] == 1 { + R.AdvRuleVIPIfL2(r.tuples.l3Dst.addr.IP) + } } // Take care of any secondary VIPs for _, sVIP := range r.secIP { - R.vipMap[sVIP.sIP.String()]++ - if R.vipMap[sVIP.sIP.String()] == 1 { - R.AdvRuleVIPIfL2(sVIP.sIP) + if !sVIP.sIP.IsUnspecified() { + R.vipMap[sVIP.sIP.String()]++ + if R.vipMap[sVIP.sIP.String()] == 1 { + R.AdvRuleVIPIfL2(sVIP.sIP) + } } } } @@ -1370,6 +1375,11 @@ func (R *RuleH) AddNatLbRule(serv cmn.LbServiceArg, servSecIPs []cmn.LbSecIPArg, return a < b }) + if sNetAddr.IP.IsUnspecified() && serv.Mode != cmn.LBModeHostOneArm { + serv.Mode = cmn.LBModeHostOneArm + tk.LogIt(tk.LogInfo, "nat lb-rule %s-%v-%s updated to hostOneArm\n", serv.ServIP, serv.ServPort, serv.Proto) + } + natActs.sel = serv.Sel natActs.mode = cmn.LBMode(serv.Mode) @@ -1557,33 +1567,38 @@ func (R *RuleH) AddNatLbRule(serv cmn.LbServiceArg, servSecIPs []cmn.LbSecIPArg, // deleteVIPSys - system specific operations for deleting VIPs of a LB rule func (R *RuleH) deleteVIPSys(r *ruleEnt) { if !strings.Contains(r.name, "ipvs") && !strings.Contains(r.name, "static") { - R.vipMap[r.tuples.l3Dst.addr.IP.String()]-- - if R.vipMap[r.tuples.l3Dst.addr.IP.String()] == 0 { - if utils.IsIPHostAddr(r.tuples.l3Dst.addr.IP.String()) { - loxinlp.DelAddrNoHook(r.tuples.l3Dst.addr.IP.String()+"/32", "lo") - } - dev := fmt.Sprintf("llb-rule-%s", r.tuples.l3Dst.addr.IP.String()) - ret, _ := mh.zr.L3.IfaFind(dev, r.tuples.l3Dst.addr.IP) - if ret == 0 { - mh.zr.L3.IfaDelete(dev, r.tuples.l3Dst.addr.IP.String()+"/32") + if !r.tuples.l3Dst.addr.IP.IsUnspecified() { + R.vipMap[r.tuples.l3Dst.addr.IP.String()]-- + + if R.vipMap[r.tuples.l3Dst.addr.IP.String()] == 0 { + if utils.IsIPHostAddr(r.tuples.l3Dst.addr.IP.String()) { + loxinlp.DelAddrNoHook(r.tuples.l3Dst.addr.IP.String()+"/32", "lo") + } + dev := fmt.Sprintf("llb-rule-%s", r.tuples.l3Dst.addr.IP.String()) + ret, _ := mh.zr.L3.IfaFind(dev, r.tuples.l3Dst.addr.IP) + if ret == 0 { + mh.zr.L3.IfaDelete(dev, r.tuples.l3Dst.addr.IP.String()+"/32") + } + delete(R.vipMap, r.tuples.l3Dst.addr.IP.String()) } - delete(R.vipMap, r.tuples.l3Dst.addr.IP.String()) } // Take care of any secondary VIPs for _, sVIP := range r.secIP { - R.vipMap[sVIP.sIP.String()]-- - if R.vipMap[sVIP.sIP.String()] == 0 { - if utils.IsIPHostAddr(sVIP.sIP.String()) { - loxinlp.DelAddrNoHook(sVIP.sIP.String()+"/32", "lo") - } - dev := fmt.Sprintf("llb-rule-%s", sVIP.sIP.String()) - ret, _ := mh.zr.L3.IfaFind(dev, sVIP.sIP) - if ret == 0 { - mh.zr.L3.IfaDelete(dev, sVIP.sIP.String()+"/32") + if !sVIP.sIP.IsUnspecified() { + R.vipMap[sVIP.sIP.String()]-- + if R.vipMap[sVIP.sIP.String()] == 0 { + if utils.IsIPHostAddr(sVIP.sIP.String()) { + loxinlp.DelAddrNoHook(sVIP.sIP.String()+"/32", "lo") + } + dev := fmt.Sprintf("llb-rule-%s", sVIP.sIP.String()) + ret, _ := mh.zr.L3.IfaFind(dev, sVIP.sIP) + if ret == 0 { + mh.zr.L3.IfaDelete(dev, sVIP.sIP.String()+"/32") + } + delete(R.vipMap, sVIP.sIP.String()) } - delete(R.vipMap, sVIP.sIP.String()) } } } From 6d5d584e401969cdb33eef919c58cb365b797226 Mon Sep 17 00:00:00 2001 From: UltraInstinct14 Date: Tue, 18 Jun 2024 12:46:41 +0900 Subject: [PATCH 2/2] [chore] update eks quick start guides in README --- README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/README.md b/README.md index 35d8b54cd..61d2694be 100644 --- a/README.md +++ b/README.md @@ -84,11 +84,13 @@ For deploying telco-cloud with cloud-native functions, loxilb can be used as a S - [K3s : loxilb with calico](https://github.com/loxilb-io/loxilbdocs/blob/main/docs/k3s_quick_start_calico.md) - [K3s : loxilb with cilium](https://github.com/loxilb-io/loxilbdocs/blob/main/docs/quick_start_with_cilium.md) - [K0s : loxilb with default kube-router networking](https://github.com/loxilb-io/loxilbdocs/blob/main/docs/k0s_quick_start.md) +- [EKS : loxilb ext-mode](https://github.com/loxilb-io/loxilbdocs/blob/main/docs/eks-external.md) #### loxilb as in-cluster pod - [K3s : loxilb in-cluster mode](https://github.com/loxilb-io/loxilbdocs/blob/main/docs/k3s_quick_start_incluster.md) - [K0s : loxilb in-cluster mode](https://github.com/loxilb-io/loxilbdocs/blob/main/docs/k0s_quick_start_incluster.md) - [MicroK8s : loxilb in-cluster mode](https://github.com/loxilb-io/loxilbdocs/blob/main/docs/microk8s_quick_start_incluster.md) +- [EKS : loxilb in-cluster mode](https://github.com/loxilb-io/loxilbdocs/blob/main/docs/eks-incluster.md) #### loxilb as service-proxy (kube-proxy replacement) - [K3s : loxilb service-proxy with flannel](https://github.com/loxilb-io/loxilbdocs/blob/main/docs/service-proxy-flannel.md)