On Wed, 2008-07-16 at 14:26 -0500, Serge E. Hallyn wrote:
> Quoting [EMAIL PROTECTED] ([EMAIL PROTECTED]):
> > 
> > cryo does not (cannot ?) recreate files if the application created
> 
> I think that's for the best.
> 
> Don't you?

        I agree. I think drawing the line for process checkpoint/restart before
preserving the contents of mounted filesystems is very reasonable since
mounted filesystem(s) can already be preserved with your choice of
tool(s). I think it also gives us more options as far as using
checkpointed images for error recovery; if we take the concept of
checkpoint too far we may limit ourselves to merely reproducing errors
rather than also giving ourselves a means to recover from errors.

Cheers,
        -Matt Helsley

> -serge
> 
> > a file before checkpoint and the file does not exist at the time
> > of restart.
> > 
> > Note that the 'flags' field in '/proc/$pid/fdinfo/$fd' will not
> > have the O_CREAT (or O_TRUNC, O_EXCL, O_NOCTTY) flags. These
> > are cleared in __dentry_open()).
> > 
> > At the time of restart, is there a way for cryo to know that the
> > file must be created ?
> > 
> > To reproduce:
> >     - run following program, 
> >     - checkpoint after the first printf
> >     - rm /tmp/foo1
> >     - restart       # fails to open file during restart
> > 
> > ---
> > #include <stdio.h>
> > #include <unistd.h>
> > #include <errno.h>
> > #include <sys/fcntl.h>
> > 
> > main()
> > {
> >     int fd;
> >     int i;
> >     char *buf = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
> > 
> >     fd = open("/tmp/foo1", O_RDWR|O_CREAT|O_TRUNC, 0666);
> > 
> >     if (fd < 0) {
> >             perror("open");
> >             exit(1);
> >     }
> >     printf("%d: Opened '/tmp/foo1', fd %d\n", getpid(), fd);
> >     
> >     for (i = 0; i < strlen(buf); i++) {
> >             if (write(fd, &buf[i], 1) < 0) {
> >                     printf("Error %d writing %c to file, i %d\n",
> >                                     errno, buf[i], i);
> >                     exit(1);
> >             }
> >             printf("%d: i %d, wrote %c\n", getpid(), i, buf[i]);
> >             sleep(2);
> >     }
> > }
> > _______________________________________________
> > Containers mailing list
> > [EMAIL PROTECTED]
> > https://lists.linux-foundation.org/mailman/listinfo/containers
> _______________________________________________
> Containers mailing list
> [EMAIL PROTECTED]
> https://lists.linux-foundation.org/mailman/listinfo/containers

_______________________________________________
Containers mailing list
[EMAIL PROTECTED]
https://lists.linux-foundation.org/mailman/listinfo/containers

_______________________________________________
Devel mailing list
[email protected]
https://openvz.org/mailman/listinfo/devel

Reply via email to