From owner-freebsd-hackers@FreeBSD.ORG Fri Jan 28 22:37:20 2011 Return-Path: Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id A74C5106564A; Fri, 28 Jan 2011 22:37:20 +0000 (UTC) (envelope-from gleb.kurtsou@gmail.com) Received: from mail-ew0-f54.google.com (mail-ew0-f54.google.com [209.85.215.54]) by mx1.freebsd.org (Postfix) with ESMTP id 0EC098FC13; Fri, 28 Jan 2011 22:37:19 +0000 (UTC) Received: by ewy24 with SMTP id 24so1840957ewy.13 for ; Fri, 28 Jan 2011 14:37:19 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:date:from:to:cc:subject:message-id:references :mime-version:content-type:content-disposition:in-reply-to :user-agent; bh=sCzvsduS9hHCAaP/zcFkCUp23gL43Z7xx+NFf+c89iY=; b=AfEWCiYBoMnFx/3LQFVJHd/ixeTkWQhI1Yagi9sZF+J5IFD+ZiMbGucXP1xEhaLDrv nb6AqnzJqNNLNaGXPtYcPIkFCCw2+Z6I4XTA8kA30dh1ovttG0Cl5AOCOl2s5PDBf/cP pcFnHMJOKAiZapfrPBR3ywwGvZQBhX3UkAbl4= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=date:from:to:cc:subject:message-id:references:mime-version :content-type:content-disposition:in-reply-to:user-agent; b=Prz5IFemvnUXES3bH654t/U7JvolFosBAW5BbHj/Ai+e2TjwT4ytuqTL4HaVzdiNvo F+q+ew1ZKn0pOXffewG7gmJ1QpFW0PAFJrZUPECmLEbBRrHHYVhGX/Ip4RCu0vQKaEUO QI1X24Tkoh6o3dEiMYixlcaduytQMI45wZsGU= Received: by 10.213.21.211 with SMTP id k19mr5536413ebb.66.1296254237254; Fri, 28 Jan 2011 14:37:17 -0800 (PST) Received: from localhost (lan-78-157-92-5.vln.skynet.lt [78.157.92.5]) by mx.google.com with ESMTPS id t5sm14195326eeh.20.2011.01.28.14.37.16 (version=SSLv3 cipher=RC4-MD5); Fri, 28 Jan 2011 14:37:16 -0800 (PST) Date: Sat, 29 Jan 2011 00:37:03 +0200 From: Gleb Kurtsou To: Ivan Voras Message-ID: <20110128223703.GA91590@tops.skynet.lt> References: <20110128152505.GP75125@dan.emsphone.com> <20110128211834.GA84881@tops.skynet.lt> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.21 (2010-09-15) Cc: freebsd-hackers@freebsd.org, Dan Nelson Subject: Re: Namecache lock contention? X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 28 Jan 2011 22:37:20 -0000 On (28/01/2011 22:59), Ivan Voras wrote: > On 28 January 2011 22:18, Gleb Kurtsou wrote: > > > You could try replacing rwlock with plain mutex to check if there are > > priority propagation issues among readers/writers. > > How would that manifest? (i.e. how would it be detectable) Benchmark. If there are prio propagation issues mutex version should be faster than original locking. Let me know if you need help with patch. > > SX locks should also > > work but would likely to be a considerable performance regression. > > With mutexes I'd lose all shared (read) acquisitions so I doubt sx > locks would do much more harm :) Yeah, but sxlocks are more heavy weight. The question is what actual readers/writers ratio in your test is, e.g. all namecache entries for a dir may be purged on rename. > > Finding out home much activity is there outside of storage/a/b/file > > (sessions storage) could also be helpful. > > Here's more information: > > * The session storage (i.e. mostly file creates / writes in this > particular workload) is on a separate file system than the core of the > application (which only does reads) Changing namecache lock to become per-file system would hardly improve situation in general. > * The dtrace output I've send is from around thirty seconds of > operation, so around 2000 PHP runs. (PHP in this case is FastCGI, so > the processes are persistent instead of constantly respawning). In > these 2000 runs there have been around 20,000 rw-block events in > cache_lookup - which is strange. Are there rename, rmdir calls? - these purge namecache. If cache is empty, VOP_LOOKUP acquires write lock to populate the cache. > * Here's another dtrace output without rwlock mutex inlining, showing > a different picture than what I've earlier thought: most rw-blocks > events are in wlock! http://ivoras.net/stuff/rw-block-noinline.txt -- > there are also some blocks without a rwlock function in the trace; I > don't understand how rwlock inlining is implemented, maybe the readers > are always inlined? Add options RWLOCK_NOINLINE, recompiling with -O0 might also be good idea. > > Next step - find out how to make dtrace print files for which this happens.