[CRIU]tty: Can't open 9 (index 0): Bad file descriptor" occurred in the restoring step

在利用CRIU来dump LXC时会出现类似如下的错误:

 (00.266862) 1: Error (tty.c:614): tty: Can't open 9 (index 0): Bad file descriptor 

出现这个问题的原因是index为0 的一个终端可能正在被使用,解决方法是挂载/dev/pts时使用newinstance 选项,这个在linux内核源代码里的有关devpts的文档有详细说明,newinstance就是为了linux container而存在的,这样linux container中的tty实例就不会和host或其他的container共享。这个有点类似于namespace的功能,不能instance中的index相互独立。具体做法是在container运行之前删掉/dev/ptm:

rm /path_to_ct/dev/ptmx

然后在container中的/etc/fstab 文件中追加如下语句: 

devpts /dev/pts devpts rw,newinstance,ptmxmode=0666 0 0 


然后进入ssh进入container中执行如下操作:

rm /dev/ptmx 
ln -s /dev/pts/ptmx /dev/ptmx 

另外 CRIU只能操作container中的特定的文件系统,在执行dump操作时,那些不支持的文件系统要手动umount掉,目前ubuntu 容器中需要umount掉的文件系统有如下: 

umount /sys/fs/fuse/connections/ 
umount /sys/kernel/debug/ 
umount /sys/kernel/security/
umount /sys/fs/pstore/

原来准备将以上命令放于一个脚本中执行,虽然执行成功,但是还会出现上述错误,看来只能在命令行一条条的执行了:

sudo rm /dev/ptmx 
sudo ln -s /dev/pts/ptmx /dev/ptmx 

不知道是什么原因,为什么在脚本里执行成功了却没有效果,知道的人可以一起探讨一下。



你可能感兴趣的:([CRIU]tty: Can't open 9 (index 0): Bad file descriptor" occurred in the restoring step)