Re: [PATCH v2] ipvs: unify the formula to estimate the overhead of processing connections

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Thanks, I will send a pull request to Patrick.

On Wed, Feb 23, 2011 at 09:56:54AM +0800, Wensong Zhang wrote:
> Sure, I am ok with this patch. Thanks!
> 
> On Tue, Feb 22, 2011 at 1:56 PM, Simon Horman <horms@xxxxxxxxxxxx> wrote:
> > On Sat, Feb 19, 2011 at 05:32:28PM +0800, Changli Gao wrote:
> >> lc and wlc use the same formula, but lblc and lblcr use another one. There
> >> is no reason for using two different formulas for the lc variants.
> >>
> >> The formula used by lc is used by all the lc variants in this patch.
> >
> > Wensong, are you ok with this version of the patch?
> >
> >>
> >> Signed-off-by: Changli Gao <xiaosuo@xxxxxxxxx>
> >> ---
> >> v2: use ip_vs_dest_conn_overhead() instead.
> >> Âinclude/net/ip_vs.h       Â|  14 ++++++++++++++
> >> Ânet/netfilter/ipvs/ip_vs_lblc.c Â| Â 13 +++----------
> >> Ânet/netfilter/ipvs/ip_vs_lblcr.c | Â 25 +++++++------------------
> >> Ânet/netfilter/ipvs/ip_vs_lc.c  Â|  18 +-----------------
> >> Ânet/netfilter/ipvs/ip_vs_wlc.c  |  20 ++------------------
> >> Â5 files changed, 27 insertions(+), 63 deletions(-)
> >> diff --git a/include/net/ip_vs.h b/include/net/ip_vs.h
> >> index 5d75fea..e80ffb7 100644
> >> --- a/include/net/ip_vs.h
> >> +++ b/include/net/ip_vs.h
> >> @@ -1241,6 +1241,20 @@ static inline void ip_vs_conn_drop_conntrack(struct ip_vs_conn *cp)
> >> Â/* CONFIG_IP_VS_NFCT */
> >> Â#endif
> >>
> >> +static inline unsigned int
> >> +ip_vs_dest_conn_overhead(struct ip_vs_dest *dest)
> >> +{
> >> + Â Â /*
> >> + Â Â Â* We think the overhead of processing active connections is 256
> >> + Â Â Â* times higher than that of inactive connections in average. (This
> >> + Â Â Â* 256 times might not be accurate, we will change it later) We
> >> + Â Â Â* use the following formula to estimate the overhead now:
> >> + Â Â Â* Â Â Â Â Â Â Â Âdest->activeconns*256 + dest->inactconns
> >> + Â Â Â*/
> >> + Â Â return (atomic_read(&dest->activeconns) << 8) +
> >> + Â Â Â Â Â Â atomic_read(&dest->inactconns);
> >> +}
> >> +
> >> Â#endif /* __KERNEL__ */
> >>
> >> Â#endif    /* _NET_IP_VS_H */
> >> diff --git a/net/netfilter/ipvs/ip_vs_lblc.c b/net/netfilter/ipvs/ip_vs_lblc.c
> >> index 00b5ffa..58ae403 100644
> >> --- a/net/netfilter/ipvs/ip_vs_lblc.c
> >> +++ b/net/netfilter/ipvs/ip_vs_lblc.c
> >> @@ -389,12 +389,7 @@ __ip_vs_lblc_schedule(struct ip_vs_service *svc)
> >> Â Â Â int loh, doh;
> >>
> >> Â Â Â /*
> >> - Â Â Â* We think the overhead of processing active connections is fifty
> >> - Â Â Â* times higher than that of inactive connections in average. (This
> >> - Â Â Â* fifty times might not be accurate, we will change it later.) We
> >> - Â Â Â* use the following formula to estimate the overhead:
> >> - Â Â Â* Â Â Â Â Â Â Â Âdest->activeconns*50 + dest->inactconns
> >> - Â Â Â* and the load:
> >> + Â Â Â* We use the following formula to estimate the load:
> >> Â Â Â Â* Â Â Â Â Â Â Â Â(dest overhead) / dest->weight
> >> Â Â Â Â*
> >> Â Â Â Â* Remember -- no floats in kernel mode!!!
> >> @@ -410,8 +405,7 @@ __ip_vs_lblc_schedule(struct ip_vs_service *svc)
> >> Â Â Â Â Â Â Â Â Â Â Â continue;
> >> Â Â Â Â Â Â Â if (atomic_read(&dest->weight) > 0) {
> >> Â Â Â Â Â Â Â Â Â Â Â least = dest;
> >> - Â Â Â Â Â Â Â Â Â Â loh = atomic_read(&least->activeconns) * 50
> >> - Â Â Â Â Â Â Â Â Â Â Â Â Â Â + atomic_read(&least->inactconns);
> >> + Â Â Â Â Â Â Â Â Â Â loh = ip_vs_dest_conn_overhead(least);
> >> Â Â Â Â Â Â Â Â Â Â Â goto nextstage;
> >> Â Â Â Â Â Â Â }
> >> Â Â Â }
> >> @@ -425,8 +419,7 @@ __ip_vs_lblc_schedule(struct ip_vs_service *svc)
> >> Â Â Â Â Â Â Â if (dest->flags & IP_VS_DEST_F_OVERLOAD)
> >> Â Â Â Â Â Â Â Â Â Â Â continue;
> >>
> >> - Â Â Â Â Â Â doh = atomic_read(&dest->activeconns) * 50
> >> - Â Â Â Â Â Â Â Â Â Â + atomic_read(&dest->inactconns);
> >> + Â Â Â Â Â Â doh = ip_vs_dest_conn_overhead(dest);
> >> Â Â Â Â Â Â Â if (loh * atomic_read(&dest->weight) >
> >> Â Â Â Â Â Â Â Â Â doh * atomic_read(&least->weight)) {
> >> Â Â Â Â Â Â Â Â Â Â Â least = dest;
> >> diff --git a/net/netfilter/ipvs/ip_vs_lblcr.c b/net/netfilter/ipvs/ip_vs_lblcr.c
> >> index bfa25f1..2ddefe8 100644
> >> --- a/net/netfilter/ipvs/ip_vs_lblcr.c
> >> +++ b/net/netfilter/ipvs/ip_vs_lblcr.c
> >> @@ -178,8 +178,7 @@ static inline struct ip_vs_dest *ip_vs_dest_set_min(struct ip_vs_dest_set *set)
> >>
> >> Â Â Â Â Â Â Â if ((atomic_read(&least->weight) > 0)
> >> Â Â Â Â Â Â Â Â Â && (least->flags & IP_VS_DEST_F_AVAILABLE)) {
> >> - Â Â Â Â Â Â Â Â Â Â loh = atomic_read(&least->activeconns) * 50
> >> - Â Â Â Â Â Â Â Â Â Â Â Â Â Â + atomic_read(&least->inactconns);
> >> + Â Â Â Â Â Â Â Â Â Â loh = ip_vs_dest_conn_overhead(least);
> >> Â Â Â Â Â Â Â Â Â Â Â goto nextstage;
> >> Â Â Â Â Â Â Â }
> >> Â Â Â }
> >> @@ -192,8 +191,7 @@ static inline struct ip_vs_dest *ip_vs_dest_set_min(struct ip_vs_dest_set *set)
> >> Â Â Â Â Â Â Â if (dest->flags & IP_VS_DEST_F_OVERLOAD)
> >> Â Â Â Â Â Â Â Â Â Â Â continue;
> >>
> >> - Â Â Â Â Â Â doh = atomic_read(&dest->activeconns) * 50
> >> - Â Â Â Â Â Â Â Â Â Â + atomic_read(&dest->inactconns);
> >> + Â Â Â Â Â Â doh = ip_vs_dest_conn_overhead(dest);
> >> Â Â Â Â Â Â Â if ((loh * atomic_read(&dest->weight) >
> >> Â Â Â Â Â Â Â Â Â Âdoh * atomic_read(&least->weight))
> >> Â Â Â Â Â Â Â Â Â && (dest->flags & IP_VS_DEST_F_AVAILABLE)) {
> >> @@ -228,8 +226,7 @@ static inline struct ip_vs_dest *ip_vs_dest_set_max(struct ip_vs_dest_set *set)
> >> Â Â Â list_for_each_entry(e, &set->list, list) {
> >> Â Â Â Â Â Â Â most = e->dest;
> >> Â Â Â Â Â Â Â if (atomic_read(&most->weight) > 0) {
> >> - Â Â Â Â Â Â Â Â Â Â moh = atomic_read(&most->activeconns) * 50
> >> - Â Â Â Â Â Â Â Â Â Â Â Â Â Â + atomic_read(&most->inactconns);
> >> + Â Â Â Â Â Â Â Â Â Â moh = ip_vs_dest_conn_overhead(most);
> >> Â Â Â Â Â Â Â Â Â Â Â goto nextstage;
> >> Â Â Â Â Â Â Â }
> >> Â Â Â }
> >> @@ -239,8 +236,7 @@ static inline struct ip_vs_dest *ip_vs_dest_set_max(struct ip_vs_dest_set *set)
> >> Â Ânextstage:
> >> Â Â Â list_for_each_entry(e, &set->list, list) {
> >> Â Â Â Â Â Â Â dest = e->dest;
> >> - Â Â Â Â Â Â doh = atomic_read(&dest->activeconns) * 50
> >> - Â Â Â Â Â Â Â Â Â Â + atomic_read(&dest->inactconns);
> >> + Â Â Â Â Â Â doh = ip_vs_dest_conn_overhead(dest);
> >> Â Â Â Â Â Â Â /* moh/mw < doh/dw ==> moh*dw < doh*mw, where mw,dw>0 */
> >> Â Â Â Â Â Â Â if ((moh * atomic_read(&dest->weight) <
> >> Â Â Â Â Â Â Â Â Â Âdoh * atomic_read(&most->weight))
> >> @@ -563,12 +559,7 @@ __ip_vs_lblcr_schedule(struct ip_vs_service *svc)
> >> Â Â Â int loh, doh;
> >>
> >> Â Â Â /*
> >> - Â Â Â* We think the overhead of processing active connections is fifty
> >> - Â Â Â* times higher than that of inactive connections in average. (This
> >> - Â Â Â* fifty times might not be accurate, we will change it later.) We
> >> - Â Â Â* use the following formula to estimate the overhead:
> >> - Â Â Â* Â Â Â Â Â Â Â Âdest->activeconns*50 + dest->inactconns
> >> - Â Â Â* and the load:
> >> + Â Â Â* We use the following formula to estimate the load:
> >> Â Â Â Â* Â Â Â Â Â Â Â Â(dest overhead) / dest->weight
> >> Â Â Â Â*
> >> Â Â Â Â* Remember -- no floats in kernel mode!!!
> >> @@ -585,8 +576,7 @@ __ip_vs_lblcr_schedule(struct ip_vs_service *svc)
> >>
> >> Â Â Â Â Â Â Â if (atomic_read(&dest->weight) > 0) {
> >> Â Â Â Â Â Â Â Â Â Â Â least = dest;
> >> - Â Â Â Â Â Â Â Â Â Â loh = atomic_read(&least->activeconns) * 50
> >> - Â Â Â Â Â Â Â Â Â Â Â Â Â Â + atomic_read(&least->inactconns);
> >> + Â Â Â Â Â Â Â Â Â Â loh = ip_vs_dest_conn_overhead(least);
> >> Â Â Â Â Â Â Â Â Â Â Â goto nextstage;
> >> Â Â Â Â Â Â Â }
> >> Â Â Â }
> >> @@ -600,8 +590,7 @@ __ip_vs_lblcr_schedule(struct ip_vs_service *svc)
> >> Â Â Â Â Â Â Â if (dest->flags & IP_VS_DEST_F_OVERLOAD)
> >> Â Â Â Â Â Â Â Â Â Â Â continue;
> >>
> >> - Â Â Â Â Â Â doh = atomic_read(&dest->activeconns) * 50
> >> - Â Â Â Â Â Â Â Â Â Â + atomic_read(&dest->inactconns);
> >> + Â Â Â Â Â Â doh = ip_vs_dest_conn_overhead(dest);
> >> Â Â Â Â Â Â Â if (loh * atomic_read(&dest->weight) >
> >> Â Â Â Â Â Â Â Â Â doh * atomic_read(&least->weight)) {
> >> Â Â Â Â Â Â Â Â Â Â Â least = dest;
> >> diff --git a/net/netfilter/ipvs/ip_vs_lc.c b/net/netfilter/ipvs/ip_vs_lc.c
> >> index 4f69db1..160cb80 100644
> >> --- a/net/netfilter/ipvs/ip_vs_lc.c
> >> +++ b/net/netfilter/ipvs/ip_vs_lc.c
> >> @@ -22,22 +22,6 @@
> >>
> >> Â#include <net/ip_vs.h>
> >>
> >> -
> >> -static inline unsigned int
> >> -ip_vs_lc_dest_overhead(struct ip_vs_dest *dest)
> >> -{
> >> - Â Â /*
> >> - Â Â Â* We think the overhead of processing active connections is 256
> >> - Â Â Â* times higher than that of inactive connections in average. (This
> >> - Â Â Â* 256 times might not be accurate, we will change it later) We
> >> - Â Â Â* use the following formula to estimate the overhead now:
> >> - Â Â Â* Â Â Â Â Â Â Â Âdest->activeconns*256 + dest->inactconns
> >> - Â Â Â*/
> >> - Â Â return (atomic_read(&dest->activeconns) << 8) +
> >> - Â Â Â Â Â Â atomic_read(&dest->inactconns);
> >> -}
> >> -
> >> -
> >> Â/*
> >> Â * Â Least Connection scheduling
> >> Â */
> >> @@ -62,7 +46,7 @@ ip_vs_lc_schedule(struct ip_vs_service *svc, const struct sk_buff *skb)
> >> Â Â Â Â Â Â Â if ((dest->flags & IP_VS_DEST_F_OVERLOAD) ||
> >> Â Â Â Â Â Â Â Â Â atomic_read(&dest->weight) == 0)
> >> Â Â Â Â Â Â Â Â Â Â Â continue;
> >> - Â Â Â Â Â Â doh = ip_vs_lc_dest_overhead(dest);
> >> + Â Â Â Â Â Â doh = ip_vs_dest_conn_overhead(dest);
> >> Â Â Â Â Â Â Â if (!least || doh < loh) {
> >> Â Â Â Â Â Â Â Â Â Â Â least = dest;
> >> Â Â Â Â Â Â Â Â Â Â Â loh = doh;
> >> diff --git a/net/netfilter/ipvs/ip_vs_wlc.c b/net/netfilter/ipvs/ip_vs_wlc.c
> >> index bbddfdb..db751f5 100644
> >> --- a/net/netfilter/ipvs/ip_vs_wlc.c
> >> +++ b/net/netfilter/ipvs/ip_vs_wlc.c
> >> @@ -27,22 +27,6 @@
> >>
> >> Â#include <net/ip_vs.h>
> >>
> >> -
> >> -static inline unsigned int
> >> -ip_vs_wlc_dest_overhead(struct ip_vs_dest *dest)
> >> -{
> >> - Â Â /*
> >> - Â Â Â* We think the overhead of processing active connections is 256
> >> - Â Â Â* times higher than that of inactive connections in average. (This
> >> - Â Â Â* 256 times might not be accurate, we will change it later) We
> >> - Â Â Â* use the following formula to estimate the overhead now:
> >> - Â Â Â* Â Â Â Â Â Â Â Âdest->activeconns*256 + dest->inactconns
> >> - Â Â Â*/
> >> - Â Â return (atomic_read(&dest->activeconns) << 8) +
> >> - Â Â Â Â Â Â atomic_read(&dest->inactconns);
> >> -}
> >> -
> >> -
> >> Â/*
> >> Â * Â Weighted Least Connection scheduling
> >> Â */
> >> @@ -71,7 +55,7 @@ ip_vs_wlc_schedule(struct ip_vs_service *svc, const struct sk_buff *skb)
> >> Â Â Â Â Â Â Â if (!(dest->flags & IP_VS_DEST_F_OVERLOAD) &&
> >> Â Â Â Â Â Â Â Â Â atomic_read(&dest->weight) > 0) {
> >> Â Â Â Â Â Â Â Â Â Â Â least = dest;
> >> - Â Â Â Â Â Â Â Â Â Â loh = ip_vs_wlc_dest_overhead(least);
> >> + Â Â Â Â Â Â Â Â Â Â loh = ip_vs_dest_conn_overhead(least);
> >> Â Â Â Â Â Â Â Â Â Â Â goto nextstage;
> >> Â Â Â Â Â Â Â }
> >> Â Â Â }
> >> @@ -85,7 +69,7 @@ ip_vs_wlc_schedule(struct ip_vs_service *svc, const struct sk_buff *skb)
> >> Â Â Â list_for_each_entry_continue(dest, &svc->destinations, n_list) {
> >> Â Â Â Â Â Â Â if (dest->flags & IP_VS_DEST_F_OVERLOAD)
> >> Â Â Â Â Â Â Â Â Â Â Â continue;
> >> - Â Â Â Â Â Â doh = ip_vs_wlc_dest_overhead(dest);
> >> + Â Â Â Â Â Â doh = ip_vs_dest_conn_overhead(dest);
> >> Â Â Â Â Â Â Â if (loh * atomic_read(&dest->weight) >
> >> Â Â Â Â Â Â Â Â Â doh * atomic_read(&least->weight)) {
> >> Â Â Â Â Â Â Â Â Â Â Â least = dest;
> >>
> >
> 
--
To unsubscribe from this list: send the line "unsubscribe netfilter-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Netfitler Users]     [LARTC]     [Bugtraq]     [Yosemite Forum]

  Powered by Linux