From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mx1.redhat.com ([209.132.183.28]:39422 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754181AbdHUNek (ORCPT ); Mon, 21 Aug 2017 09:34:40 -0400 Subject: Re: [PATCH v3 0/5] fs/dcache: Limit # of negative dentries To: "Wangkai (Kevin,C)" , Alexander Viro , Jonathan Corbet Cc: "linux-kernel@vger.kernel.org" , "linux-doc@vger.kernel.org" , "linux-fsdevel@vger.kernel.org" , "Paul E. McKenney" , Andrew Morton , Ingo Molnar , Miklos Szeredi , Matthew Wilcox , Larry Woodman , James Bottomley References: <1501266880-26288-1-git-send-email-longman@redhat.com> <1cdfb670-42ed-f8f6-aeab-c38ea0567651@redhat.com> <87B246BB5ED53A4C98E4F9A35839EDE1853965F7@nkgeml514-mbx.china.huawei.com> <1756a532-ed56-f2f8-0463-bd659923acd1@redhat.com> <87B246BB5ED53A4C98E4F9A35839EDE185397B0E@nkgeml514-mbx.china.huawei.com> <87B246BB5ED53A4C98E4F9A35839EDE185399B59@nkgeml514-mbx.china.huawei.com> <6de809d1-a255-a4c5-095a-00751090103b@redhat.com> <87B246BB5ED53A4C98E4F9A35839EDE185399FA8@nkgeml514-mbx.china.huawei.com> From: Waiman Long Message-ID: <0cd48ec2-fd71-7c3c-fcf4-82df9cacd1f6@redhat.com> Date: Mon, 21 Aug 2017 09:34:38 -0400 MIME-Version: 1.0 In-Reply-To: <87B246BB5ED53A4C98E4F9A35839EDE185399FA8@nkgeml514-mbx.china.huawei.com> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-fsdevel-owner@vger.kernel.org List-ID: On 08/20/2017 11:23 PM, Wangkai (Kevin,C) wrote: > > Yes, I have add some trace info for the dentry state changed, with dentry flag and reference count: > > File create: > [ 42.636675] dentry [xxxx_1234] 0xffff880230be8180 flag 0x0 ref 1 ev dentry alloc > File close: > [ 42.637421] dentry [xxxx_1234] 0xffff880230be8180 flag 0x4800c0 ref 0 ev dput called > > Unlink lookup: > [ 244.658086] dentry [xxxx_1234] 0xffff880230be8180 flag 0x4800c0 ref 1 ev d_lookup > Unlink d_delete: > [ 244.658254] dentry [xxxx_1234] 0xffff880230be8180 flag 0x800c0 ref 1 ev d_lockref ref 1 > Unlink dput: > [ 244.658438] dentry [xxxx_1234] 0xffff880230be8180 flag 0x800c0 ref 0 ev dput called > > The end, dentry's flag stay at 0x800c0, but this dentry was not freed, keeped by the dcache as unused, > After tens of thousands of the dentries slow down the dentry lookup performance, kernel memory usage > Keep high. > > Regards, > Kevin That is expected. The kernel does not get rid of negative dentries until the shrinker is called because of memory pressure. Negative dentries do help to improve file lookup performance. However, too much of negative dentries suppress the amount of free memory available for other use. That is why I send out my patch to limit the number of negative dentries outstanding. Cheers, Longman