From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-11.6 required=3.0 tests=BAYES_00,DKIM_INVALID, DKIM_SIGNED,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id B898CC433DB for ; Tue, 2 Feb 2021 18:47:54 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 49B6B64E9C for ; Tue, 2 Feb 2021 18:47:54 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 49B6B64E9C Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=cmpxchg.org Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 998426B0005; Tue, 2 Feb 2021 13:47:53 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 903A66B0006; Tue, 2 Feb 2021 13:47:53 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 7310A6B006C; Tue, 2 Feb 2021 13:47:53 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0159.hostedemail.com [216.40.44.159]) by kanga.kvack.org (Postfix) with ESMTP id 4266C6B0005 for ; Tue, 2 Feb 2021 13:47:53 -0500 (EST) Received: from smtpin19.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay05.hostedemail.com (Postfix) with ESMTP id 08A90181AEF1A for ; Tue, 2 Feb 2021 18:47:53 +0000 (UTC) X-FDA: 77774212026.19.shape55_2000c25275cd Received: from filter.hostedemail.com (10.5.16.251.rfc1918.com [10.5.16.251]) by smtpin19.hostedemail.com (Postfix) with ESMTP id D5CA61AD1AD for ; Tue, 2 Feb 2021 18:47:52 +0000 (UTC) X-HE-Tag: shape55_2000c25275cd X-Filterd-Recvd-Size: 7649 Received: from mail-qv1-f47.google.com (mail-qv1-f47.google.com [209.85.219.47]) by imf43.hostedemail.com (Postfix) with ESMTP for ; Tue, 2 Feb 2021 18:47:52 +0000 (UTC) Received: by mail-qv1-f47.google.com with SMTP id ew18so10400384qvb.4 for ; Tue, 02 Feb 2021 10:47:51 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cmpxchg-org.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=SRGv31t5oIgSMdD5HuT0hX8f1ohrW2aTZf+6aUN4HlY=; b=S4Sk4WOq0qqgckH/82ebDu33VM/7hVX534DYaPgrG6/Myx34h8dabJwOJetTSnIe3L OSJGc8m9Sj7EQRFPSlOkILnQpxMhplWh3winKWHzICWTzCsNDSbj7VZZt0sT8P0o2Uos KNBrt5mJFPLzidD4x80yZ/JP+Go2nbxyyMxjTbWMM3dp3wvf0R+Cpq4+EUTuyxwVssM+ lt68u6vKUpO96sioBifhybUsb5OofpzoH402x6koOFOdw3ZNmNvV5fjwinzsSbi1cUDk iMZ6ZnCe9ga140oAAtH6HEXfo0jsIp4jl7qhDJRVWw4hSkbR82SOry+BF+pEGYXh+LPT c9BQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=SRGv31t5oIgSMdD5HuT0hX8f1ohrW2aTZf+6aUN4HlY=; b=M6ugEew3j9gcS5XO3auADkIS0MbvMn9DKe1GZ2qpk99Xqg1yJJ/toEiaFw2Wijpt41 mCRHsUs3zukXfdTfDnPbMEm9Q2ZImaUlQMjaaF+3AmCJdcWI5QEubXRDQ3aTbISWNLom uUqk/1FXTIbOr/9tBMYK8IrmmafDLve3w/6ksK7XWq7u+9iUPvBRkK5Q0A+Py3aC6YK4 OSXKfzkyc4ENPm0wNkiJ46ZDnk3NNjqog4WdeO3FgyVMHcaoeCB9nbjdN7zC59JMVle7 50G1A7wzbJUtfznyeIOghnQBl+ftOISfZI4rr+8Yc/ZEn/HthdK+wkEigoYW9tNzLpik siFg== X-Gm-Message-State: AOAM530BKnfNdVwHP2nTikmYUDRiJ1gt4HWjV+0ZmVPufLrV4b2ApaHF gMbMAas1iKhsc4BwUP5vDVEW9A== X-Google-Smtp-Source: ABdhPJwdzFmer39rWKh6F+cNpMXL7TqfcB6o13grTzCGvUy+YSnRpsADzH3nWfmZUsi+HhX9JEk+Dw== X-Received: by 2002:a0c:fe47:: with SMTP id u7mr22040673qvs.4.1612291671468; Tue, 02 Feb 2021 10:47:51 -0800 (PST) Received: from localhost (70.44.39.90.res-cmts.bus.ptd.net. [70.44.39.90]) by smtp.gmail.com with ESMTPSA id u6sm4944633qke.114.2021.02.02.10.47.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 02 Feb 2021 10:47:50 -0800 (PST) From: Johannes Weiner To: Andrew Morton , Tejun Heo Cc: Michal Hocko , Roman Gushchin , linux-mm@kvack.org, cgroups@vger.kernel.org, linux-kernel@vger.kernel.org, kernel-team@fb.com Subject: [PATCH 0/7]: mm: memcontrol: switch to rstat Date: Tue, 2 Feb 2021 13:47:39 -0500 Message-Id: <20210202184746.119084-1-hannes@cmpxchg.org> X-Mailer: git-send-email 2.30.0 MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: This series converts memcg stats tracking to the streamlined rstat infrastructure provided by the cgroup core code. rstat is already used by the CPU controller and the IO controller. This change is motivated by recent accuracy problems in memcg's custom stats code, as well as the benefits of sharing common infra with other controllers. The current memcg implementation does batched tree aggregation on the write side: local stat changes are cached in per-cpu counters, which are then propagated upward in batches when a threshold (32 pages) is exceeded. This is cheap, but the error introduced by the lazy upward propagation adds up: 32 pages times CPUs times cgroups in the subtree. We've had complaints from service owners that the stats do not reliably track and react to allocation behavior as expected, sometimes swallowing the results of entire test applications. The original memcg stat implementation used to do tree aggregation exclusively on the read side: local stats would only ever be tracked in per-cpu counters, and a memory.stat read would iterate the entire subtree and sum those counters up. This didn't keep up with the times: - Cgroup trees are much bigger now. We switched to lazily-freed cgroups, where deleted groups would hang around until their remaining page cache has been reclaimed. This can result in large subtrees that are expensive to walk, while most of the groups are idle and their statistics don't change much anymore. - Automated monitoring increased. With the proliferation of userspace oom killing, proactive reclaim, and higher-resolution logging of workload trends in general, top-level stat files are polled at least once a second in many deployments. - The lifetime of cgroups got shorter. Where most cgroup setups in the past would have a few large policy-oriented cgroups for everything running on the system, newer cgroup deployments tend to create one group per application - which gets deleted again as the processes exit. An aggregation scheme that doesn't retain child data inside the parents loses event history of the subtree. Rstat addresses all three of those concerns through intelligent, persistent read-side aggregation. As statistics change at the local level, rstat tracks - on a per-cpu basis - only those parts of a subtree that have changes pending and require aggregation. The actual aggregation occurs on the colder read side - which can now skip over (potentially large) numbers of recently idle cgroups. --- A kernel build test confirms that the cost is comparable. Two kernels are built simultaneously in a nested tree with several idle siblings: root - kernelbuild - one - two - three - four - build-a (defconfig, make = -j16) `- build-b (defconfig, make = -j16) `- idle-1 `- ... `- idle-9 During the builds, kernelbuild/memory.stat is read once a second. A perf diff shows that the changes in cycle distribution is minimal. Top 10 kernel symbols: 0.09% +0.08% [kernel.kallsyms] [k] __mod_= memcg_lruvec_state 0.00% +0.06% [kernel.kallsyms] [k] cgroup= _rstat_updated 0.08% -0.05% [kernel.kallsyms] [k] __mod_= memcg_state.part.0 0.16% -0.04% [kernel.kallsyms] [k] releas= e_pages 0.00% +0.03% [kernel.kallsyms] [k] __coun= t_memcg_events 0.01% +0.03% [kernel.kallsyms] [k] mem_cg= roup_charge_statistics.constprop.0 0.10% -0.02% [kernel.kallsyms] [k] get_me= m_cgroup_from_mm 0.05% -0.02% [kernel.kallsyms] [k] mem_cg= roup_update_lru_size 0.57% +0.01% [kernel.kallsyms] [k] asm_ex= c_page_fault --- And of course, the on-demand aggregated stats are now fully accurate again: $ grep -e nr_inactive_file /proc/vmstat | awk '{print($1,$2*4096)}'; \ grep -e inactive_file /sys/fs/cgroup/memory.stat vanilla: patched: nr_inactive_file 1574105088 nr_inactive_file 1027801088 inactive_file 1577410560 inactive_file 1027801088 --- block/blk-cgroup.c | 14 +- include/linux/memcontrol.h | 119 ++++++---------- kernel/cgroup/cgroup.c | 34 +++-- kernel/cgroup/rstat.c | 62 +++++---- mm/memcontrol.c | 320 +++++++++++++++++++++------------------= ---- 5 files changed, 266 insertions(+), 283 deletions(-) Based on v5.11-rc5-mm1.