lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:	Fri, 07 Jun 2013 17:13:55 +0200
From:	Piotr Nowojski <piotr.nowojski@...cean-global.com>
To:	Michal Hocko <mhocko@...e.cz>
CC:	linux-mm@...ck.org, LKML <linux-kernel@...r.kernel.org>
Subject: Re: OOM Killer and add_to_page_cache_locked

W dniu 06.06.2013 17:57, Michal Hocko pisze:
>   
>> >In our system we have hit some very annoying situation (bug?) with
>> >cgroups. I'm writing to you, because I have found your posts on
>> >mailing lists with similar topic. Maybe you could help us or point
>> >some direction where to look for/ask.
>> >
>> >We have system with ~15GB RAM (+2GB SWAP), and we are running ~10
>> >heavy IO processes. Each process is using constantly 200-210MB RAM
>> >(RSS) and a lot of page cache. All processes are in cgroup with
>> >following limits:
>> >
>> >/sys/fs/cgroup/taskell2 $ cat memory.limit_in_bytes
>> >memory.memsw.limit_in_bytes
>> >14183038976
>> >15601344512
> I assume that memory.use_hierarchy is 1, right?
System has been rebooted since last test, so I can not guarantee that it 
was set for 100%, but it should have been. Currently I'm rerunning this 
scenario that lead to the described problem with:

/sys/fs/cgroup/taskell2# cat memory.use_hierarchy ../memory.use_hierarchy
1
0

Where root cgroup, doesn't have any limits set.

/sys/fs/cgroup/taskell2# cat ../memory*limit*
9223372036854775807
9223372036854775807
9223372036854775807

>> >Each process is being started in separate cgroup, with
>> >memory_soft_limit set to 1GB.
>> >
>> >/sys/fs/cgroup/taskell2 $ ls | grep subtask
>> >subtask5462692
>> >subtask5462697
>> >subtask5462698
>> >subtask5462699
>> >subtask5462700
>> >subtask5462701
>> >subtask5462702
>> >subtask5462703
>> >subtask5462704
>> >
>> >/sys/fs/cgroup/taskell2 $ cat subtask5462704/memory.limit_in_bytes
>> >subtask5462704/memory.memsw.limit_in_bytes
>> >subtask5462704/memory.soft_limit_in_bytes
>> >9223372036854775807
>> >9223372036854775807
>> >1073741824
>> >
>> >Memory usage is following:
>> >
>> >free -g
>> >              total       used       free     shared    buffers cached
>> >Mem:            14         14          0          0 0         12
>> >-/+ buffers/cache:          1         13
>> >Swap:            1          0          1
>> >
>> >/sys/fs/cgroup/taskell2 $ cat memory.stat
>> >cache 13208932352
>> >rss 0
>> >hierarchical_memory_limit 14183038976
>> >hierarchical_memsw_limit 15601344512
>> >total_cache 13775765504
>> >total_rss 264949760
>> >total_swap 135974912
>> >
>> >In other words, most memory is used by page cache and everything IMO
>> >should work just fine, but it isn't. Every couple of minutes, one of
>> >the processes is being killed by OOM Killer, triggered from IO read
>> >and "add_to_page_cache" (full stack attached below). For me this is
>> >ridiculous behavior. Process is trying to put something into page
>> >cache, but there is no free memory (because everything is eaten by
>> >page_cache) thus triggering OOM Killer. Why? Most of this page cache
>> >is not even used - at least not heavily used. Is this a bug? Stupid
>> >feature? Or am I missing something? Our configuration:
> It sounds like a bug to me. If you had a small groups I would say that
> the memory reclaim is not able to free any memory because almost all
> the pages on the LRU are dirty and dirty pages throttling is not memcg
> aware but your groups contain a lot of pages and all of they shouldn't
> be dirty because the global dirty memory throttling should slow down
> writers and writeback should have already started.
>
> This has been fixed (or worked around to be more precise) by e62e384e
> (memcg: prevent OOM with too many dirty pages) in 3.6.
>
> Maybe you could try this patch and see if it helps. I would be sceptical
> but it is worth trying.
>
> The core thing to find out is why the hard limit reclaim is not able to
> free anything. Unfortunatelly we do not have memcg reclaim statistics so
> it would be a bit harder. I would start with the above patch first and
> then I can prepare some debugging patches for you.
I will try 3.6 (probably 3.7) kernel after weekend - unfortunately 
repeating whole scenario is taking 10-30 hours because of very slowly 
growing page cache.
>
> Also does 3.4 vanila (or the stable kernel) behave the same way? Is the
> current vanilla behaving the same way?
I don't know, we are using standard kernel that comes from Ubuntu.
>
> Finally, have you seen the issue for a longer time or it started showing
> up only now?
>
This system is very new. We have started testing scenario which 
triggered OOM something like one week ago and we have immediately hit 
this issue. Previously, with different scenarios and different memory 
usage by processes we didn't have this issue.

Piotr Nowojski
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ