在利用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
不知道是什么原因,为什么在脚本里执行成功了却没有效果,知道的人可以一起探讨一下。