Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753236AbbLICnw (ORCPT ); Tue, 8 Dec 2015 21:43:52 -0500 Received: from cn.fujitsu.com ([59.151.112.132]:35669 "EHLO heian.cn.fujitsu.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1751598AbbLICnu (ORCPT ); Tue, 8 Dec 2015 21:43:50 -0500 X-IronPort-AV: E=Sophos;i="5.20,346,1444665600"; d="scan'208";a="1353449" Message-ID: <56679399.6080306@cn.fujitsu.com> Date: Wed, 9 Dec 2015 10:36:09 +0800 From: Dongsheng Yang User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101 Thunderbird/24.1.0 MIME-Version: 1.0 To: Shayan Pooya , , , Richard Weinberger , , "Eric W. Biederman" Subject: Re: piping core dump to a program escapes container References: <56679161.303@cn.fujitsu.com> In-Reply-To: <56679161.303@cn.fujitsu.com> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.167.226.66] X-yoursite-MailScanner-Information: Please contact the ISP for more information X-yoursite-MailScanner-ID: 1DD6D4189105.A7AFA X-yoursite-MailScanner: Found to be clean X-yoursite-MailScanner-From: yangds.fnst@cn.fujitsu.com Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2828 Lines: 73 On 12/09/2015 10:26 AM, Dongsheng Yang wrote: > On 10/25/2015 05:54 AM, Shayan Pooya wrote: >> I noticed the following core_pattern behavior in my linux box while >> running docker containers. I am not sure if it is bug, but it is >> inconsistent and not documented. >> >> If the core_pattern is set on the host, the containers will observe >> and use the pattern for dumping cores (there is no per cgroup >> core_pattern). According to core(5) for setting core_pattern one can: >> >> 1. echo "/tmp/cores/core.%e.%p" > /proc/sys/kernel/core_pattern >> 2. echo "|/bin/custom_core /tmp/cores/ %e %p " > >> /proc/sys/kernel/core_pattern >> >> The former pattern evaluates the /tmp/cores path in the container's >> filesystem namespace. Which means, the host does not see a core file >> in /tmp/cores. >> >> However, the latter evaluates the /bin/custom_core path in the global >> filesystem namespace. Moreover, if /bin/core decides to write the core >> to a path (/tmp/cores in this case as shown by the arg to >> custom_core), the path will be evaluated in the global filesystem >> namespace as well. >> >> The latter behaviour is counter-intuitive and error-prone as the >> container can fill up the core-file directory which it does not have >> direct access to (which means the core is also not accessible for >> debugging if someone only has access to the container). > > Hi Shayan, > We found the same problem with what you described here. > Is there any document for this behaviour? I want to know is > that intentional or as you said a 'bug'. Maybe that's intentional > to provide a way for admin to collect core dumps from all containers as > Richard said. I am interested in it too. > > Anyone can help here? In addition, is that a good idea to make core_pattern to be seperated in different namespace? Yang > > Yang >> >> Currently, I work around this issue by detecting that the process is >> crashing from a container (by comparing the namespace pid to the >> global pid) and refuse to dump the core if it is from a container. >> >> Tested on Ubuntu (kernel 3.16) and Fedora (kernel 4.1). >> -- >> To unsubscribe from this list: send the line "unsubscribe cgroups" in >> the body of a message to majordomo@vger.kernel.org >> More majordomo info at http://vger.kernel.org/majordomo-info.html >> > > > > -- > To unsubscribe from this list: send the line "unsubscribe linux-kernel" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html > Please read the FAQ at http://www.tux.org/lkml/ > . > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/