lagg/lacp poor traffic distribution
Eugene Grosbein
egrosbein at rdtc.ru
Tue Dec 21 07:32:25 UTC 2010
On 20.12.2010 17:21, Shtorm wrote:
> I had this problem with igb driver, and I found, that lagg selects
> outgoing interface based on packet header flowid field if M_FLOWID field
> is set. And in the igb driver code flowid is set as
>
> #if __FreeBSD_version >= 800000
> <------><------><------>rxr->fmp->m_pkthdr.flowid = que->msix;
> <------><------><------>rxr->fmp->m_flags |= M_FLOWID;
> #endif
>
> The same thing in em driver with MULTIQUEUE
>
> That does not give enough number of flows to balance traffic well, so I
> commented check in if_lagg.c
>
> lagg_lb_start(struct lagg_softc *sc, struct mbuf *m)
> {
> <------>struct lagg_lb *lb = (struct lagg_lb *)sc->sc_psc;
> <------>struct lagg_port *lp = NULL;
> <------>uint32_t p = 0;
>
> //<---->if (m->m_flags & M_FLOWID)
> //<----><------>p = m->m_pkthdr.flowid;
> //<---->else
>
> and with this change I have much better load distribution across interfaces.
>
> Hope it helps.
>
I've made new sysctl net.link.lagg.use_flows to enable/disable
this code in run time and disabled it. No change.
--- if_lagg.c.orig 2010-12-20 22:53:21.000000000 +0600
+++ if_lagg.c 2010-12-20 22:57:50.000000000 +0600
@@ -168,6 +168,11 @@
&lagg_failover_rx_all, 0,
"Accept input from any interface in a failover lagg");
+static int lagg_use_flows = 1;
+SYSCTL_INT(_net_link_lagg, OID_AUTO, use_flows, CTLFLAG_RW,
+ &lagg_use_flows, 1,
+ "Use flows for load sharing");
+
static int
lagg_modevent(module_t mod, int type, void *data)
{
@@ -1666,7 +1671,7 @@
struct lagg_port *lp = NULL;
uint32_t p = 0;
- if (m->m_flags & M_FLOWID)
+ if (lagg_use_flows && (m->m_flags & M_FLOWID))
p = m->m_pkthdr.flowid;
else
p = lagg_hashmbuf(m, lb->lb_key);
More information about the freebsd-net
mailing list