From mboxrd@z Thu Jan 1 00:00:00 1970 From: Ulf Samuelsson Subject: Re: [PATCH] neighbour.c: Avoid GC directly after state change Date: Wed, 22 Apr 2015 09:42:04 +0200 Message-ID: <553750CC.8010003@ericsson.com> References: <1426107673-45049-1-git-send-email-netdev@emagii.com> <20150312.142621.1128728353472907283.davem@davemloft.net> <5527892D.4020608@ericsson.com> <552F45AA.6010906@miraclelinux.com> <5530BE40.1000504@ericsson.com> <55346580.6060801@miraclelinux.com> <5534F5B8.1030405@ericsson.com> <5535CB00.4060209@miraclelinux.com> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: 7bit Cc: To: YOSHIFUJI Hideaki , Return-path: Received: from sesbmg22.ericsson.net ([193.180.251.48]:60455 "EHLO sesbmg22.ericsson.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S965443AbbDVHmJ (ORCPT ); Wed, 22 Apr 2015 03:42:09 -0400 In-Reply-To: <5535CB00.4060209@miraclelinux.com> Sender: netdev-owner@vger.kernel.org List-ID: On 04/21/2015 05:58 AM, YOSHIFUJI Hideaki wrote: > Ulf Samuelsson wrote: >>> How many neighbors do you want to maintain? >>> I guess you have to increase the number of gc_thresh1. >> The current use cases have up to 2048 entries. >> This is expected to grow in the future. >> The 3.4 kernel used in the system today is limited to 1024, >> but that has been raised to about 10k. >> >> The gc_thresh1 test is not implemented in 3.4 but can be backported, >> but still not convinced it is a good idea. > Why? > A good solution makes sure that: * equipment which is connected NEVER IS garbage collected * equipment which is disconnected IS garbage collected. The threshold idea does not meet the criteria for a good solution. With this solution you keep unnecessary entries in the table. If you ever pass the limit, then equipment which should not be garbage collected may be. It relies on someone keeping track of traffic loss, so needs more maintenance by the SysOp. The ARP probes should be considered to be NECESSARY traffic to maintain a quality link. Obviously not everyone would want to make this trade-off. >> To complicate things, one requirement is that for some interfaces >> you always want to keep things alive, if connected, but >> for other interfaces you want things to be removed >> to conserve memory. >> Actually you would want to do this selection on a subnet level. > If you want to introduce per-interface parameter, I am okay with it. > >> Internal discussions resulted in a proposal to change the patch, >> so that you have a "keepalive" flag which is tested after >> it has been decided to exit the REACHABLE state. >> >> if the "keepalive" flag is set, you always go to DELAY state from REACHABLE. > No. > And why is it a bad idea to have a high quality connection? Best Regards, Ulf Samuelsson