No se puede eliminar una instantánea btrfs

8

No puedo eliminar la instantánea btrfs "apt-snapshot-release-upgrade-saucy-2013-10-19_00: 52: 26". Aquí están los detalles:

root@cioco:~# btrfs subvolume list -s /
ID 261 gen 246 cgen 245 top level 5 otime 2013-10-19 00:52:26 path @apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26
root@cioco:~# btrfs subvolume list  /
ID 256 gen 334584 top level 5 path @
ID 258 gen 334134 top level 5 path @home
ID 261 gen 246 top level 5 path @apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26
ID 267 gen 334580 top level 256 path var/lib/lxc/mythtv/rootfs
ID 268 gen 334584 top level 256 path var/lib/lxc/jira/rootfs
ID 278 gen 279278 top level 256 path var/lib/lxc/michele/rootfs
root@cioco:~# grep btrfs /proc/self/mountinfo
20 1 0:16 /@ / rw,relatime - btrfs /dev/sda2 rw,compress=zlib,space_cache
39 20 0:16 /@home /home rw,relatime - btrfs /dev/sda2 rw,compress=zlib,space_cache

root@cioco:~# btrfs subvolume delete /@apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26
ERROR: error accessing '/@apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26' 

Sin embargo, puedo eliminar una instantánea creada por mí:

root@cioco:~# btrfs subvolume snapshot / root-snap
Create a snapshot of '/' in './root-snap'
root@cioco:~# btrfs subvolume list -s /
ID 261 gen 246 cgen 245 top level 5 otime 2013-10-19 00:52:26 path @apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26
ID 309 gen 334592 cgen 334592 top level 256 otime 2014-03-31 02:19:08 path root/root-snap
root@cioco:~# btrfs subvolume delete /root/root-snap
Delete subvolume '/root/root-snap'

EDITAR1: No hay nada registrado en el registro del kernel:

root@cioco:~# dmesg -c >/dev/null
root@cioco:~# btrfs subvolume delete /@apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26
ERROR: error accessing '/@apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26'
root@cioco:~# dmesg
root@cioco:~#

Pero strace da una pista:

root@cioco:~# strace btrfs subvolume delete /@apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26
...
stat("/@apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26", 0x7fffe88ebb60) = -1 ENOENT (No such file or directory)
write(2, "ERROR: error accessing '/@apt-sn"..., 82ERROR: error accessing '/@apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26'
) = 82

Edit2: he montado el volumen ...

root@cioco:~# mkdir /snapshot
root@cioco:~# mount /dev/sda2 /snapshot -o subvol=/@apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26
root@cioco:~# grep btrfs /proc/self/mountinfo
20 1 0:16 /@ / rw,relatime - btrfs /dev/sda2 rw,compress=zlib,space_cache
39 20 0:16 /@home /home rw,relatime - btrfs /dev/sda2 rw,compress=zlib,space_cache
61 20 0:16 /@apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26 /snapshot rw,relatime - btrfs /dev/sda2 rw,compress=zlib,space_cache
root@cioco:~# btrfs subvolume delete /snapshot/
Delete subvolume '//snapshot'
ERROR: cannot delete '//snapshot' - Invalid argument

root@cioco:~# strace btrfs subvolume delete /snapshot/
...
stat("/snapshot", {st_mode=S_IFDIR|0755, st_size=230, ...}) = 0
brk(0)                                  = 0x2206000
brk(0x2228000)                          = 0x2228000
lstat("/snapshot", {st_mode=S_IFDIR|0755, st_size=230, ...}) = 0
stat("/", {st_mode=S_IFDIR|0755, st_size=242, ...}) = 0
openat(AT_FDCWD, "/", O_RDONLY|O_NONBLOCK|O_DIRECTORY|O_CLOEXEC) = 3
fstat(1, {st_mode=S_IFCHR|0600, st_rdev=makedev(136, 23), ...}) = 0
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fd8ad2ae000
write(1, "Delete subvolume '//snapshot'\n", 30Delete subvolume '//snapshot'
) = 30
ioctl(3, BTRFS_IOC_SNAP_DESTROY, 0x7fff5f1e5878) = -1 EINVAL (Invalid argument)
close(3)                                = 0
write(2, "ERROR: cannot delete '//snapshot"..., 53ERROR: cannot delete '//snapshot' - Invalid argument
) = 53
...

root@cioco:~# dmesg
[3172764.459166] device label cioco-root devid 1 transid 336213 /dev/sda2

Edit3: Solución

root@cioco:~# mount /dev/sda2 /btrfs-root/
root@cioco:~# ls -l /btrfs-root/
total 0
drwxr-xr-x 1 root root 262 Apr  1 08:31 @
drwxr-xr-x 1 root root 230 Oct 16 22:53 @apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26
drwxr-xr-x 1 root root   6 Oct 16 22:13 @home
root@cioco:~# btrfs subvolume delete /btrfs-root/@apt-snapshot-release-upgrade-saucy-2013-10-19_00\:52\:26/
Delete subvolume '/btrfs-root/@apt-snapshot-release-upgrade-saucy-2013-10-19_00:52:26'
root@cioco:~# dmesg
[41113.537617] device label cioco-root devid 1 transid 337615 /dev/sda2

Cualquier ayuda sería apreciada.

Mircea Vutcovici
fuente
¿Se puede eliminar de una sesión en vivo? Quizás todavía está en uso. grepping /proc/self/mountinfono es suficiente, por ejemplo, se puede usar como un montaje de enlace o si se desmontó con umount -l(desmontaje diferido) y no sé si puede haber otros casos.
ignis
No está montado en absoluto. El sistema es mi servidor doméstico. Y creo que la instantánea se tomó después de la actualización de Ubuntu. Estoy ejecutando ahora Ubuntu 13.10 64bit
Mircea Vutcovici
¿Qué quieres decir con "sesión en vivo"?
Mircea Vutcovici
Me refiero a Live DVD o Live USB.
ignis
Por favor, publique la salida de dmesg | taildespués de que btrfs subvolume deletefalla.
ignis

Respuestas:

15

La instantánea existe en la raíz real del sistema de archivos, que no es lo que ha montado en /. Tiene el subvolumen / @ montado en /, por lo que no existe dicho archivo con ese nombre. Debe montar el volumen raíz real en alguna parte y usar esa ruta para hacer referencia a la instantánea.

O puede usar apt-btrfs-snapshot deleteen su lugar.

psusi
fuente
2
He tenido muchos problemas para montar y eliminar en el pasado, pero nunca he tenido problemas para ejecutarloapt-btrfs-snapshot delete
mchid
A diferencia de la gestión de instantáneas btrfs normal, apt-btrfs-snapshot se debe ejecutar desde un sistema en ejecución y no desde una partición montada.
mchid
3
@mchid, ¿qué? La gestión de instantáneas btrfs normales se ejecuta desde un sistema en ejecución ... apt-btrfs-snapshot es solo un script apto que ejecuta automáticamente la instantánea btrfs normal cada vez que tiene que instalar / actualizar / eliminar paquetes.
psusi
Mi problema es que estoy en una situación de disco lleno debido a las instantáneas, por lo tanto, no puedo instalar apt-btrfs-snapshot.
fccoelho
Tienes que arrancar desde un USB para eliminar cosas cuando te quedas sin espacio. Además, supongo que puede eliminar de un sistema en ejecución si monta el volumen en / mnt .
mchid