On Tue, Jul 21, 2020 at 4:20 AM jingrui <jingrui@xxxxxxxxxx> wrote: > > Cc: Johannes Weiner <hannes@xxxxxxxxxxx> ; Michal Hocko <mhocko@xxxxxxxxxx>; Vladimir Davydov <vdavydov.dev@xxxxxxxxx> > > Thanks. > > --- > PROBLEM: cgroup cost too much memory when transfer small files to tmpfs. > > keywords: cgroup PERCPU/memory cost too much. > > description: > > We send small files from node-A to node-B tmpfs /tmp directory using sftp. On > node-B the systemd configured with pam on like below. > > cat /etc/pam.d/password-auth | grep systemd > -session optional pam_systemd.so > > So when transfer a file, a systemd session is created, that means a cgroup is > created, then file saved at /tmp will associated with a cgroup object. After > file transferred, session and cgroup-dir will be removed, but the file in /tmp > still associated with the cgroup object. Is there a way for you to re-use the cgroup instead of creating and deleting cgroup for each individual file transfer session? > The PERCPU memory in cgroup/css object > cost a lot(about 0.5MB/per-cgroup-object) on 200/cpus machine. > > When lot of small files transferred to tmpfs, the cgroup/css object memory > cost become huge in this scenes to be used. > > systemd related issue: https://github.com/systemd/systemd/issues/16499 > > kernel version: 4.19+ > > Problem: > > 1. Do we have any idea to descrease cgroup memory cost in this case? > 2. When user remove cgroup directory, does it possible associated file memory to root cgroup? No, the memory remains associated with the cgroup and the cgroup becomes zombie on deletion. > 3. Can we provide an option that do not associate memory with cgroup in tmpfs? Only way, if you don't want to disable memcg, is to move the file receiver process to root cgroup.