Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754385AbbFSTwq (ORCPT ); Fri, 19 Jun 2015 15:52:46 -0400 Received: from mail-yh0-f46.google.com ([209.85.213.46]:33809 "EHLO mail-yh0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753660AbbFSTwc (ORCPT ); Fri, 19 Jun 2015 15:52:32 -0400 Date: Fri, 19 Jun 2015 15:52:26 -0400 From: Jeff Layton To: Trond Myklebust Cc: Steven Rostedt , Eric Dumazet , Anna Schumaker , Linux NFS Mailing List , Linux Network Devel Mailing List , LKML , Andrew Morton , Bruce James Fields Subject: Re: [REGRESSION] NFS is creating a hidden port (left over from xs_bind() ) Message-ID: <20150619155226.7c5d6637@synchrony.poochiereds.net> In-Reply-To: References: <20150611234929.7b48d314@gandalf.local.home> <1434120035.27504.77.camel@edumazet-glaptop2.roam.corp.google.com> <20150612113420.5c114183@gandalf.local.home> <20150612115038.44e20ccd@gandalf.local.home> <20150617230819.0a11e47a@grimm.local.home> <20150618154914.57424225@gandalf.local.home> <20150618185051.2b2828c3@tlielax.poochiereds.net> <20150618210843.4b09c31c@grimm.local.home> <20150618213702.33f64b20@synchrony.poochiereds.net> <20150619122553.43d2d86c@gandalf.local.home> <20150619131759.7b38d9de@gandalf.local.home> X-Mailer: Claws Mail 3.11.1 (GTK+ 2.24.28; x86_64-redhat-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2800 Lines: 73 On Fri, 19 Jun 2015 13:39:08 -0400 Trond Myklebust wrote: > On Fri, Jun 19, 2015 at 1:17 PM, Steven Rostedt wrote: > > On Fri, 19 Jun 2015 12:25:53 -0400 > > Steven Rostedt wrote: > > > > > >> I don't see that 55201 anywhere. But then again, I didn't look for it > >> before the port disappeared. I could reboot and look for it again. I > >> should have saved the full netstat -tapn as well :-/ > > > > Of course I didn't find it anywhere, that's the port on my wife's box > > that port 947 was connected to. > > > > Now I even went over to my wife's box and ran > > > > # rpcinfo -p localhost > > program vers proto port service > > 100000 4 tcp 111 portmapper > > 100000 3 tcp 111 portmapper > > 100000 2 tcp 111 portmapper > > 100000 4 udp 111 portmapper > > 100000 3 udp 111 portmapper > > 100000 2 udp 111 portmapper > > 100024 1 udp 34243 status > > 100024 1 tcp 34498 status > > > > which doesn't show anything. > > > > but something is listening to that port... > > > > # netstat -ntap |grep 55201 > > tcp 0 0 0.0.0.0:55201 0.0.0.0:* LISTEN > > > Hang on. This is on the client box while there is an active NFSv4 > mount? Then that's probably the NFSv4 callback channel listening for > delegation callbacks. > > Can you please try: > > echo "options nfs callback_tcpport=4048" > /etc/modprobe.d/nfs-local.conf > > and then either reboot the client or unload and then reload the nfs > modules before reattempting the mount. If this is indeed the callback > channel, then that will move your phantom listener to port 4048... > Right, it was a little unclear to me before, but it now seems clear that the callback socket that the server is opening to the client is the one squatting on the port. ...and that sort of makes sense, doesn't it? That rpc_clnt will stick around for the life of the client's lease, and the rpc_clnt binds to a particular port so that it can reconnect using the same one. Given that Stephen has done the legwork and figured out that reverting those commits fixes the issue, then I suspect that the real culprit is caf4ccd4e88cf2. The client is likely closing down the other end of the callback socket when it goes idle. Before that commit, we probably did an xs_close on it, but now we're doing a xs_tcp_shutdown and that leaves the port bound. I'm travelling this weekend and am not set up to reproduce it to confirm, but that does seem to be a plausible scenario. -- Jeff Layton -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in Please read the FAQ at http://www.tux.org/lkml/