On Fri, Apr 03, 2015 at 03:03:53PM -0500, Mike Christie wrote: > On 04/02/2015 12:41 AM, Mel Gorman wrote: > > On Thu, Apr 02, 2015 at 02:40:19AM +0300, Ilya Dryomov wrote: > >> > On Thu, Apr 2, 2015 at 2:03 AM, Mel Gorman <mgorman@xxxxxxx> wrote: > >>> > > On Wed, Apr 01, 2015 at 08:19:20PM +0300, Ilya Dryomov wrote: > >>>> > >> Following nbd and iscsi, commit 89baaa570ab0 ("libceph: use memalloc > >>>> > >> flags for net IO") set SOCK_MEMALLOC and PF_MEMALLOC flags for rbd and > >>>> > >> cephfs. However it turned out to not play nice with loopback scenario, > >>>> > >> leading to lockups with a full socket send-q and empty recv-q. > >>>> > >> > >>>> > >> While we always advised against colocating kernel client and ceph > >>>> > >> servers on the same box, a few people are doing it and it's also useful > >>>> > >> for light development testing, so rather than reverting make sure to > >>>> > >> not set those flags in the loopback case. > >>>> > >> > >>> > > > >>> > > This does not clarify why the non-loopback case needs access to pfmemalloc > >>> > > reserves. Granted, I've spent zero time on this but it's really unclear > >>> > > what problem was originally tried to be solved and why dirty page limiting > >>> > > was insufficient. Swap over NFS was always a very special case minimally > >>> > > because it's immune to dirty page throttling. > >> > > >> > I don't think there was any particular problem tried to be solved, > > Then please go back and look at why dirty page limiting is insufficient > > for ceph. > > > > The problem I was trying to solve is just the basic one where block > drivers have in the past been required to be able to make forward > progress on a write. With iscsi under heavy IO and memory use loads, we > will see memory allocation failures from the network layer followed by > hard system lock ups. Why was it unable to discard clean file pages or swap anonymous pages to local disk to ensure forward progress? Are you swapping over ISCSI that requires network transmits? If so, then you may need to do something similar to swap-over-NFS when the network is involved. Enabling pfmemalloc reserves for all communications is not the answer as it's trading one set of problems for another -- specifically emergency reserves will be used in cases where emergency reserves are not required with the risk of the machine locking up. > The block layer and its drivers like scsi does not > make any distinction between swap and non swap disks to handle this > problem. Can they be identified like swap-over-NFS is? If not, why not? > It will always just work when the network is not involved. Your other option is to fail to add swap if writing to it requires network buffers. The configuration is a hand-grenade and better to mark it as unsupported until such time as it is properly handled. > I > thought we did not special case swap, because there were cases where > there may not be swappable pages, and the mm layer then needs to write > out pages to other non-swap disks to be able to free up memory. > > In the block layer and scsi drivers like qla2xxx forward progress is > easier to handle. They just use bio, request, scsi_cmnd, scatterlist, > etc mempools and internally preallocate some resources they need. For > iscsi and other block drivers that use the network, it is more difficult > as you of course know, and when I did the iscsi and rbd/ceph patches I > had thought we were supposed to be using the memalloc related flags to > handle this problem for both swap and non swap cases. I might have > misunderstood you way back when I did those patches originally. > Only the swap case should use emergency reserves like this. File-backed cases should discard clean file pages and depend on the dirty page limiting to ensure enough clean pages are free. There is a corner case where anonymous memory uses 100-dirty_ratio of memory and all other memory is dirty so it is still necessary to have a local swap device to avoid this specific case. > For dirty page limiting, I thought the problem is that it is difficult > to get right and at the same time not affect performance for some > workloads. There can be stalls as a result of this. Digging into the reserves until the machine locks up does not avoid them. At best, it simply moves when the stall occurs because the allocation is fine but other users must wait on kswapd to make progress or direct reclaim to restore the emergency reserves. > For non-net block drivers, we do not have to configure it > just to handle this problem. It just works, and so I thought we have > been trying to solve this problem in a similar way as the rest of the > block layer by having some memory reserves. > That reserve is not the allocator emergency reserves. > Also on a related note, I thought I heard at LSF that that forward > progress requirement for non swap writes was going away. Is that true > and is it something that is going to happen in the near future or was it > more of a wish list item. At best, that was a wish-list item. There was some discussion stating it would be nice if reserves would be guaranteed to exist on a per-subsystem basis to guarantee forward progress but there is no commitment to actually implement it. Even if it did exist, then it would not be consumed via __GFP_MEMALLOC. -- Mel Gorman SUSE Labs -- To unsubscribe from this list: send the line "unsubscribe ceph-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html