Re: [lxc-devel] [PATCH 2/2] daemon: remove pidfile when daemon container is stopped

2014-01-20 Thread Qiang Huang
On 2014/1/21 11:38, Stéphane Graber wrote:
> On Tue, Jan 21, 2014 at 11:33:42AM +0800, Qiang Huang wrote:
>> On 2014/1/21 11:20, Stéphane Graber wrote:
>>> On Tue, Jan 21, 2014 at 10:54:50AM +0800, Qiang Huang wrote:
 Hi Stéphane,

 I'm not sure I understand this.

 In my understanding, anything using the API to control an already
 running backgrounded container will use lxc_container_new to create
 a new lxc_container, it only share the original one's name and config
 and so on. After dealing, will call lxc_container_put to free this
 lxc_container, this *new* lxc_container doesn't contain the PID file
 information, so it's freeing won't remove PID file.
>>>
>>> Hmm, yeah, seems like you're right, I should have rechecked the patch
>>> rather than speak from the vague memory of what I saw when you initialy
>>> posted it.
>>>
>>>
>>> So, re-reading more carefully, I don't completely disagree with the
>>> approach, though I don't like having to extend lxc_container just for
>>> that...
>>
>> Without 1/2 patch, this patch won't work, I'll send new patches.
>> So would it be better if I put this into lxc_conf?
>>
>>>
>>> There's however one rather big problem, the PID file will contain the
>>> wrong PID. The PID being written is getpid() from the parent lxc-start,
>>> not the running, forked lxc-start process and that child PID is only
>>> known by the start() function in lxccontainer.c, so you can't create the
>>> PID file from lxc_start.c
>>
>> Yeah, I noticed that before, I thought that's exactly what we want,
>> because we can get the init pid of container from lxc_info command.
>>
>> If it's not, we can fix it incrementally. :)
> 
> No, what I meant is that the PID we are writing is that of a
> non-existing process, which makes the pid file entirely useless.
> 
> When you start a container, you have at least 3 processes:
>  1) The command the user start (lxc-start -d)
>  2) The backgrounded fork of that command after start() is done
>  3) The container init process
> 
> lxc-info and the API init_pid() function gives us (3), what we want to
> see in a pidfile is (2) and what we are currently writing is (1).
> 
> As (1) exits as soon as the container is started, it's completely
> useless as you can't use that to check whether LXC still has control
> over the container (i.e. is lxc-start still running in the background).
> 

Oh, that's right, in the daemon model the PID file stores wrong pid,
I'll think about it and fix it in the new patch.

Thanks Stéphane.


___
lxc-devel mailing list
lxc-devel@lists.linuxcontainers.org
http://lists.linuxcontainers.org/listinfo/lxc-devel


Re: [lxc-devel] [PATCH 2/2] daemon: remove pidfile when daemon container is stopped

2014-01-20 Thread Stéphane Graber
On Tue, Jan 21, 2014 at 11:33:42AM +0800, Qiang Huang wrote:
> On 2014/1/21 11:20, Stéphane Graber wrote:
> > On Tue, Jan 21, 2014 at 10:54:50AM +0800, Qiang Huang wrote:
> >> Hi Stéphane,
> >>
> >> I'm not sure I understand this.
> >>
> >> In my understanding, anything using the API to control an already
> >> running backgrounded container will use lxc_container_new to create
> >> a new lxc_container, it only share the original one's name and config
> >> and so on. After dealing, will call lxc_container_put to free this
> >> lxc_container, this *new* lxc_container doesn't contain the PID file
> >> information, so it's freeing won't remove PID file.
> > 
> > Hmm, yeah, seems like you're right, I should have rechecked the patch
> > rather than speak from the vague memory of what I saw when you initialy
> > posted it.
> > 
> > 
> > So, re-reading more carefully, I don't completely disagree with the
> > approach, though I don't like having to extend lxc_container just for
> > that...
> 
> Without 1/2 patch, this patch won't work, I'll send new patches.
> So would it be better if I put this into lxc_conf?
> 
> > 
> > There's however one rather big problem, the PID file will contain the
> > wrong PID. The PID being written is getpid() from the parent lxc-start,
> > not the running, forked lxc-start process and that child PID is only
> > known by the start() function in lxccontainer.c, so you can't create the
> > PID file from lxc_start.c
> 
> Yeah, I noticed that before, I thought that's exactly what we want,
> because we can get the init pid of container from lxc_info command.
> 
> If it's not, we can fix it incrementally. :)

No, what I meant is that the PID we are writing is that of a
non-existing process, which makes the pid file entirely useless.

When you start a container, you have at least 3 processes:
 1) The command the user start (lxc-start -d)
 2) The backgrounded fork of that command after start() is done
 3) The container init process

lxc-info and the API init_pid() function gives us (3), what we want to
see in a pidfile is (2) and what we are currently writing is (1).

As (1) exits as soon as the container is started, it's completely
useless as you can't use that to check whether LXC still has control
over the container (i.e. is lxc-start still running in the background).

-- 
Stéphane Graber
Ubuntu developer
http://www.ubuntu.com


signature.asc
Description: Digital signature
___
lxc-devel mailing list
lxc-devel@lists.linuxcontainers.org
http://lists.linuxcontainers.org/listinfo/lxc-devel


Re: [lxc-devel] [PATCH 2/2] daemon: remove pidfile when daemon container is stopped

2014-01-20 Thread Qiang Huang
On 2014/1/21 11:20, Stéphane Graber wrote:
> On Tue, Jan 21, 2014 at 10:54:50AM +0800, Qiang Huang wrote:
>> Hi Stéphane,
>>
>> I'm not sure I understand this.
>>
>> In my understanding, anything using the API to control an already
>> running backgrounded container will use lxc_container_new to create
>> a new lxc_container, it only share the original one's name and config
>> and so on. After dealing, will call lxc_container_put to free this
>> lxc_container, this *new* lxc_container doesn't contain the PID file
>> information, so it's freeing won't remove PID file.
> 
> Hmm, yeah, seems like you're right, I should have rechecked the patch
> rather than speak from the vague memory of what I saw when you initialy
> posted it.
> 
> 
> So, re-reading more carefully, I don't completely disagree with the
> approach, though I don't like having to extend lxc_container just for
> that...

Without 1/2 patch, this patch won't work, I'll send new patches.
So would it be better if I put this into lxc_conf?

> 
> There's however one rather big problem, the PID file will contain the
> wrong PID. The PID being written is getpid() from the parent lxc-start,
> not the running, forked lxc-start process and that child PID is only
> known by the start() function in lxccontainer.c, so you can't create the
> PID file from lxc_start.c

Yeah, I noticed that before, I thought that's exactly what we want,
because we can get the init pid of container from lxc_info command.

If it's not, we can fix it incrementally. :)

> 


___
lxc-devel mailing list
lxc-devel@lists.linuxcontainers.org
http://lists.linuxcontainers.org/listinfo/lxc-devel


Re: [lxc-devel] [PATCH 2/2] daemon: remove pidfile when daemon container is stopped

2014-01-20 Thread Stéphane Graber
On Tue, Jan 21, 2014 at 10:54:50AM +0800, Qiang Huang wrote:
> Hi Stéphane,
> 
> On 2014/1/21 0:07, Stéphane Graber wrote:
> > On Mon, Jan 20, 2014 at 03:22:31PM +0800, Qiang Huang wrote:
> >> On 2014/1/19 8:57, Stéphane Graber wrote:
> >>> On Sat, Jan 18, 2014 at 03:00:00PM +0800, Qiang Huang wrote:
>  This is for bug: https://github.com/lxc/lxc/issues/89
> 
>  When start container with daemon model, the daemon process's
>  father will return back to main in start time, and pidfile
>  is removed then, that's not right.
>  So we store pidfile to lxc_container, and remove it when
>  lxc_container_free.
> >>>
> >>> That one looks wrong to me, removing the pid file on lxc_container_free
> >>> is wrong. We want the pidfile removed when the background lxc-start
> >>> exits, not whenever a random API client flushes the container from
> >>> memory.
> >>>
> >>> With your patch, doing something like:
> >>>  - lxc-start -n p1 -d -p /tmp/pid
> >>>  - python3
> >>>  import lxc
> >>>  p1 = lxc.Container("p1")
> >>>  p1 = None
> >>
> >> I'm sorry I'm not family with python, can you explain how this would
> >> happen in real world? Thanks.
> > 
> > In the real world, anything using the API to control an already running
> > backgrounded container with a PID file and that does lxc_container_put
> > once it's done dealing with the container object will cause the PID file
> > to be removed.
> 
> I'm not sure I understand this.
> 
> In my understanding, anything using the API to control an already
> running backgrounded container will use lxc_container_new to create
> a new lxc_container, it only share the original one's name and config
> and so on. After dealing, will call lxc_container_put to free this
> lxc_container, this *new* lxc_container doesn't contain the PID file
> information, so it's freeing won't remove PID file.

Hmm, yeah, seems like you're right, I should have rechecked the patch
rather than speak from the vague memory of what I saw when you initialy
posted it.


So, re-reading more carefully, I don't completely disagree with the
approach, though I don't like having to extend lxc_container just for
that...

There's however one rather big problem, the PID file will contain the
wrong PID. The PID being written is getpid() from the parent lxc-start,
not the running, forked lxc-start process and that child PID is only
known by the start() function in lxccontainer.c, so you can't create the
PID file from lxc_start.c

> 
> Anyway, my patch is based on one theory:
> A running container will have an lxc_container to hold it's information,
> which is created from start, the struct lxc_container lasts for all of
> container's life cycle.
> 
> If it's wrong, my question is:
> How could it be reasonable for a container running without an lxc_container?
> 
> > 
> > Actually, even calling lxc-list should cause the PID file to be removed
> > as lxc-list calls list_containers which calls list_defined_containers
> > which in turns iterate through all containers, get their struct and then
> > lxc_container_put them.
> > 
> >>
> >>>
> >>> Or the equivalent with any binding, or directly in C, will destroy the
> >>> pid file even though the container is clearly still running.
> >>
> >> I thought when the backgroud lxc-start exits, it's time for container
> >> to free, because there are no other place to do lxc_contaier_get to
> >> hold the container from freeing.
> >>
> >> I must missed something :( , so waiting for your more details.
> >>
> >>
> > 
> 
> 

-- 
Stéphane Graber
Ubuntu developer
http://www.ubuntu.com


signature.asc
Description: Digital signature
___
lxc-devel mailing list
lxc-devel@lists.linuxcontainers.org
http://lists.linuxcontainers.org/listinfo/lxc-devel


Re: [lxc-devel] [PATCH 2/2] daemon: remove pidfile when daemon container is stopped

2014-01-20 Thread Qiang Huang
Hi Stéphane,

On 2014/1/21 0:07, Stéphane Graber wrote:
> On Mon, Jan 20, 2014 at 03:22:31PM +0800, Qiang Huang wrote:
>> On 2014/1/19 8:57, Stéphane Graber wrote:
>>> On Sat, Jan 18, 2014 at 03:00:00PM +0800, Qiang Huang wrote:
 This is for bug: https://github.com/lxc/lxc/issues/89

 When start container with daemon model, the daemon process's
 father will return back to main in start time, and pidfile
 is removed then, that's not right.
 So we store pidfile to lxc_container, and remove it when
 lxc_container_free.
>>>
>>> That one looks wrong to me, removing the pid file on lxc_container_free
>>> is wrong. We want the pidfile removed when the background lxc-start
>>> exits, not whenever a random API client flushes the container from
>>> memory.
>>>
>>> With your patch, doing something like:
>>>  - lxc-start -n p1 -d -p /tmp/pid
>>>  - python3
>>>  import lxc
>>>  p1 = lxc.Container("p1")
>>>  p1 = None
>>
>> I'm sorry I'm not family with python, can you explain how this would
>> happen in real world? Thanks.
> 
> In the real world, anything using the API to control an already running
> backgrounded container with a PID file and that does lxc_container_put
> once it's done dealing with the container object will cause the PID file
> to be removed.

I'm not sure I understand this.

In my understanding, anything using the API to control an already
running backgrounded container will use lxc_container_new to create
a new lxc_container, it only share the original one's name and config
and so on. After dealing, will call lxc_container_put to free this
lxc_container, this *new* lxc_container doesn't contain the PID file
information, so it's freeing won't remove PID file.

Anyway, my patch is based on one theory:
A running container will have an lxc_container to hold it's information,
which is created from start, the struct lxc_container lasts for all of
container's life cycle.

If it's wrong, my question is:
How could it be reasonable for a container running without an lxc_container?

> 
> Actually, even calling lxc-list should cause the PID file to be removed
> as lxc-list calls list_containers which calls list_defined_containers
> which in turns iterate through all containers, get their struct and then
> lxc_container_put them.
> 
>>
>>>
>>> Or the equivalent with any binding, or directly in C, will destroy the
>>> pid file even though the container is clearly still running.
>>
>> I thought when the backgroud lxc-start exits, it's time for container
>> to free, because there are no other place to do lxc_contaier_get to
>> hold the container from freeing.
>>
>> I must missed something :( , so waiting for your more details.
>>
>>
> 


___
lxc-devel mailing list
lxc-devel@lists.linuxcontainers.org
http://lists.linuxcontainers.org/listinfo/lxc-devel


Re: [lxc-devel] [PATCH 2/2] daemon: remove pidfile when daemon container is stopped

2014-01-20 Thread Stéphane Graber
On Mon, Jan 20, 2014 at 03:22:31PM +0800, Qiang Huang wrote:
> On 2014/1/19 8:57, Stéphane Graber wrote:
> > On Sat, Jan 18, 2014 at 03:00:00PM +0800, Qiang Huang wrote:
> >> This is for bug: https://github.com/lxc/lxc/issues/89
> >>
> >> When start container with daemon model, the daemon process's
> >> father will return back to main in start time, and pidfile
> >> is removed then, that's not right.
> >> So we store pidfile to lxc_container, and remove it when
> >> lxc_container_free.
> > 
> > That one looks wrong to me, removing the pid file on lxc_container_free
> > is wrong. We want the pidfile removed when the background lxc-start
> > exits, not whenever a random API client flushes the container from
> > memory.
> > 
> > With your patch, doing something like:
> >  - lxc-start -n p1 -d -p /tmp/pid
> >  - python3
> >  import lxc
> >  p1 = lxc.Container("p1")
> >  p1 = None
> 
> I'm sorry I'm not family with python, can you explain how this would
> happen in real world? Thanks.

In the real world, anything using the API to control an already running
backgrounded container with a PID file and that does lxc_container_put
once it's done dealing with the container object will cause the PID file
to be removed.

Actually, even calling lxc-list should cause the PID file to be removed
as lxc-list calls list_containers which calls list_defined_containers
which in turns iterate through all containers, get their struct and then
lxc_container_put them.

> 
> > 
> > Or the equivalent with any binding, or directly in C, will destroy the
> > pid file even though the container is clearly still running.
> 
> I thought when the backgroud lxc-start exits, it's time for container
> to free, because there are no other place to do lxc_contaier_get to
> hold the container from freeing.
> 
> I must missed something :( , so waiting for your more details.
> 
> 

-- 
Stéphane Graber
Ubuntu developer
http://www.ubuntu.com


signature.asc
Description: Digital signature
___
lxc-devel mailing list
lxc-devel@lists.linuxcontainers.org
http://lists.linuxcontainers.org/listinfo/lxc-devel


Re: [lxc-devel] [PATCH 2/2] daemon: remove pidfile when daemon container is stopped

2014-01-19 Thread Qiang Huang
On 2014/1/19 8:57, Stéphane Graber wrote:
> On Sat, Jan 18, 2014 at 03:00:00PM +0800, Qiang Huang wrote:
>> This is for bug: https://github.com/lxc/lxc/issues/89
>>
>> When start container with daemon model, the daemon process's
>> father will return back to main in start time, and pidfile
>> is removed then, that's not right.
>> So we store pidfile to lxc_container, and remove it when
>> lxc_container_free.
> 
> That one looks wrong to me, removing the pid file on lxc_container_free
> is wrong. We want the pidfile removed when the background lxc-start
> exits, not whenever a random API client flushes the container from
> memory.
> 
> With your patch, doing something like:
>  - lxc-start -n p1 -d -p /tmp/pid
>  - python3
>  import lxc
>  p1 = lxc.Container("p1")
>  p1 = None

I'm sorry I'm not family with python, can you explain how this would
happen in real world? Thanks.

> 
> Or the equivalent with any binding, or directly in C, will destroy the
> pid file even though the container is clearly still running.

I thought when the backgroud lxc-start exits, it's time for container
to free, because there are no other place to do lxc_contaier_get to
hold the container from freeing.

I must missed something :( , so waiting for your more details.


___
lxc-devel mailing list
lxc-devel@lists.linuxcontainers.org
http://lists.linuxcontainers.org/listinfo/lxc-devel


Re: [lxc-devel] [PATCH 2/2] daemon: remove pidfile when daemon container is stopped

2014-01-18 Thread Stéphane Graber
On Sat, Jan 18, 2014 at 03:00:00PM +0800, Qiang Huang wrote:
> This is for bug: https://github.com/lxc/lxc/issues/89
> 
> When start container with daemon model, the daemon process's
> father will return back to main in start time, and pidfile
> is removed then, that's not right.
> So we store pidfile to lxc_container, and remove it when
> lxc_container_free.

That one looks wrong to me, removing the pid file on lxc_container_free
is wrong. We want the pidfile removed when the background lxc-start
exits, not whenever a random API client flushes the container from
memory.

With your patch, doing something like:
 - lxc-start -n p1 -d -p /tmp/pid
 - python3
 import lxc
 p1 = lxc.Container("p1")
 p1 = None

Or the equivalent with any binding, or directly in C, will destroy the
pid file even though the container is clearly still running.

> 
> Signed-off-by: Qiang Huang 
> ---
>  src/lxc/lxc_start.c| 9 +
>  src/lxc/lxccontainer.c | 6 ++
>  src/lxc/lxccontainer.h | 6 ++
>  3 files changed, 17 insertions(+), 4 deletions(-)
> 
> diff --git a/src/lxc/lxc_start.c b/src/lxc/lxc_start.c
> index d5379da..fd2dc6e 100644
> --- a/src/lxc/lxc_start.c
> +++ b/src/lxc/lxc_start.c
> @@ -302,6 +302,11 @@ int main(int argc, char *argv[])
>   }
> 
>   if (my_args.pidfile != NULL) {
> + if (ensure_path(&c->pidfile, my_args.pidfile) < 0) {
> + ERROR("failed to ensure pidfile '%s'", my_args.pidfile);
> + goto out;
> + }
> +
>   pid_fp = fopen(my_args.pidfile, "w");
>   if (pid_fp == NULL) {
>   SYSERROR("failed to create pidfile '%s' for '%s'",
> @@ -342,10 +347,6 @@ int main(int argc, char *argv[])
>   c->want_close_all_fds(c, true);
> 
>   err = c->start(c, 0, args) ? 0 : -1;
> -
> - if (my_args.pidfile)
> - unlink(my_args.pidfile);
> -
>  out:
>   lxc_container_put(c);
>   if (pid_fp)
> diff --git a/src/lxc/lxccontainer.c b/src/lxc/lxccontainer.c
> index ddea0d7..d742781 100644
> --- a/src/lxc/lxccontainer.c
> +++ b/src/lxc/lxccontainer.c
> @@ -231,6 +231,11 @@ static void lxc_container_free(struct lxc_container *c)
>   free(c->config_path);
>   c->config_path = NULL;
>   }
> + if (c->pidfile) {
> + unlink(c->pidfile);
> + free(c->pidfile);
> + c->pidfile = NULL;
> + }
>   free(c);
>  }
> 
> @@ -3051,6 +3056,7 @@ struct lxc_container *lxc_container_new(const char 
> *name, const char *configpath
>   lxcapi_clear_config(c);
>   }
>   c->daemonize = true;
> + c->pidfile = NULL;
> 
>   // assign the member functions
>   c->is_defined = lxcapi_is_defined;
> diff --git a/src/lxc/lxccontainer.h b/src/lxc/lxccontainer.h
> index 921e47d..a860648 100644
> --- a/src/lxc/lxccontainer.h
> +++ b/src/lxc/lxccontainer.h
> @@ -68,6 +68,12 @@ struct lxc_container {
> 
>   /*!
>* \private
> +  * File to store pid.
> +  */
> + char *pidfile;
> +
> + /*!
> +  * \private
>* Container semaphore lock.
>*/
>   struct lxc_lock *slock;
> -- 
> 1.8.3
> 

-- 
Stéphane Graber
Ubuntu developer
http://www.ubuntu.com


signature.asc
Description: Digital signature
___
lxc-devel mailing list
lxc-devel@lists.linuxcontainers.org
http://lists.linuxcontainers.org/listinfo/lxc-devel


[lxc-devel] [PATCH 2/2] daemon: remove pidfile when daemon container is stopped

2014-01-17 Thread Qiang Huang
This is for bug: https://github.com/lxc/lxc/issues/89

When start container with daemon model, the daemon process's
father will return back to main in start time, and pidfile
is removed then, that's not right.
So we store pidfile to lxc_container, and remove it when
lxc_container_free.

Signed-off-by: Qiang Huang 
---
 src/lxc/lxc_start.c| 9 +
 src/lxc/lxccontainer.c | 6 ++
 src/lxc/lxccontainer.h | 6 ++
 3 files changed, 17 insertions(+), 4 deletions(-)

diff --git a/src/lxc/lxc_start.c b/src/lxc/lxc_start.c
index d5379da..fd2dc6e 100644
--- a/src/lxc/lxc_start.c
+++ b/src/lxc/lxc_start.c
@@ -302,6 +302,11 @@ int main(int argc, char *argv[])
}

if (my_args.pidfile != NULL) {
+   if (ensure_path(&c->pidfile, my_args.pidfile) < 0) {
+   ERROR("failed to ensure pidfile '%s'", my_args.pidfile);
+   goto out;
+   }
+
pid_fp = fopen(my_args.pidfile, "w");
if (pid_fp == NULL) {
SYSERROR("failed to create pidfile '%s' for '%s'",
@@ -342,10 +347,6 @@ int main(int argc, char *argv[])
c->want_close_all_fds(c, true);

err = c->start(c, 0, args) ? 0 : -1;
-
-   if (my_args.pidfile)
-   unlink(my_args.pidfile);
-
 out:
lxc_container_put(c);
if (pid_fp)
diff --git a/src/lxc/lxccontainer.c b/src/lxc/lxccontainer.c
index ddea0d7..d742781 100644
--- a/src/lxc/lxccontainer.c
+++ b/src/lxc/lxccontainer.c
@@ -231,6 +231,11 @@ static void lxc_container_free(struct lxc_container *c)
free(c->config_path);
c->config_path = NULL;
}
+   if (c->pidfile) {
+   unlink(c->pidfile);
+   free(c->pidfile);
+   c->pidfile = NULL;
+   }
free(c);
 }

@@ -3051,6 +3056,7 @@ struct lxc_container *lxc_container_new(const char *name, 
const char *configpath
lxcapi_clear_config(c);
}
c->daemonize = true;
+   c->pidfile = NULL;

// assign the member functions
c->is_defined = lxcapi_is_defined;
diff --git a/src/lxc/lxccontainer.h b/src/lxc/lxccontainer.h
index 921e47d..a860648 100644
--- a/src/lxc/lxccontainer.h
+++ b/src/lxc/lxccontainer.h
@@ -68,6 +68,12 @@ struct lxc_container {

/*!
 * \private
+* File to store pid.
+*/
+   char *pidfile;
+
+   /*!
+* \private
 * Container semaphore lock.
 */
struct lxc_lock *slock;
-- 
1.8.3

___
lxc-devel mailing list
lxc-devel@lists.linuxcontainers.org
http://lists.linuxcontainers.org/listinfo/lxc-devel