¿Cuál es la mejor manera de obtener información sobre las unidades actualmente desmontadas?

38

Primero, la situación: tengo una computadora Linux con dos bahías de unidades eSATA que aceptan unidades SSD extraíbles. Estoy tratando de escribir una pequeña aplicación GUI que facilite al usuario montar / desmontar / formatear / hacer copias de seguridad / etc. las unidades que coloca en estas bahías.

Todo funciona principalmente. Sin embargo, un pequeño problema es que no sé cómo encontrar información sobre lo que hay en las unidades insertadas hasta que las unidades se han montado correctamente.

Entonces, por ejemplo, si el usuario inserta una unidad que no puedo montar (por ejemplo, porque no está formateada o está formateada con un sistema de archivos inesperado), todo lo que mi aplicación puede decir es "La unidad no se pudo montar".

Esto no es muy satisfactorio, porque si el disco no está formateado, el usuario probablemente querrá formatearlo ... pero si el disco contiene datos de un sistema de archivos no reconocido, el usuario probablemente NO querrá formatearlo ... o al menos, quiero poder advertirle que al hacerlo, borrará datos potencialmente valiosos.

Entonces mi pregunta es: ¿hay algún método para consultar alguna información básica (especialmente del tipo de sistema de archivos) desde una unidad que no requiere que la unidad ya esté montada? ¿O simplemente tengo que intentar montarlo con varios sistemas de archivos conocidos hasta que uno de los intentos de montaje tenga éxito y dar un vago mensaje de "cuidado" si ninguno de ellos lo hace?

En caso de que sea importante, las rutas que uso para montar las unidades en las bahías de unidades son:

/dev/disk/by-path/pci-0000:00:1f.2-scsi-2:0:0:0
/dev/disk/by-path/pci-0000:00:1f.2-scsi-1:0:0:0
Jeremy Friesner
fuente

Respuestas:

55

Si las unidades están desmontadas, hay varias cosas que puede hacer.

Puede usar un comando como fdisk -lo sfdisk -lpara enumerar las particiones. Solo el tipo de partición puede brindarle información útil si las particiones se configuraron correctamente.

# sfdisk -l

Disk /dev/sda: 4177 cylinders, 255 heads, 63 sectors/track
Units = cylinders of 8225280 bytes, blocks of 1024 bytes, counting from 0

   Device Boot Start     End   #cyls    #blocks   Id  System
/dev/sda1   *      0+     30      31-    248976   83  Linux
/dev/sda2         31    4176    4146   33302745   8e  Linux LVM
/dev/sda3          0       -       0          0    0  Empty
/dev/sda4          0       -       0          0    0  Empty

Si está presente en su sistema, puede usar el comando vol_idcontra una partición para devolver algunos detalles útiles (parte del paquete udev en Debian). Esto generalmente le dirá qué sistema de archivos se está utilizando realmente.

# vol_id /dev/sda1

ID_FS_USAGE=filesystem
ID_FS_TYPE=ext3
ID_FS_VERSION=1.0
ID_FS_UUID=32c44d53-9025-4d10-8f36-75c166547bd5
ID_FS_UUID_ENC=32c44d53-9025-4d10-8f36-75c166547bd5
ID_FS_LABEL=
ID_FS_LABEL_ENC=
ID_FS_LABEL_SAFE=

El comando lshw -class diskle dará algunos detalles sobre el tipo de unidad. Es posible que desee utilizar esto si tiene curiosidad sobre el número de serie real de la unidad.

# lshw -class disk

  *-disk
       description: ATA Disk
       product: VBOX HARDDISK
       physical id: 0.0.0
       bus info: scsi@0:0.0.0
       logical name: /dev/sda
       version: 1.0
       serial: VB169e93fb-d1e0fd97
       size: 32GiB (34GB)
       capabilities: partitioned partitioned:dos
       configuration: ansiversion=5 signature=000d39f8

Si está seguro de que hay un sistema de archivos en particular como ext2 / 3, puede usar la herramienta tune2fs específica del sistema de archivos para examinar más detalles.

# tune2fs -l /dev/sda1

tune2fs 1.41.3 (12-Oct-2008)
Filesystem volume name:   <none>
Last mounted on:          <not available>
Filesystem UUID:          8cbdf102-05c7-4ae4-96ea-681cf9b11914
Filesystem magic number:  0xEF53
Filesystem revision #:    1 (dynamic)
Filesystem features:      filetype sparse_super
Default mount options:    (none)
Filesystem state:         not clean
Errors behavior:          Continue
Filesystem OS type:       Linux
Inode count:              124496
Block count:              248976
Reserved block count:     12448
Free blocks:              212961
Free inodes:              124467
First block:              1
Block size:               1024
Fragment size:            1024
Blocks per group:         8192
Fragments per group:      8192
Inodes per group:         4016
Inode blocks per group:   502
Last mount time:          Thu Oct  7 15:34:42 2010
Last write time:          Thu Oct  7 15:34:42 2010
Mount count:              4
Maximum mount count:      30
Last checked:             Wed Sep 15 09:29:03 2010
Check interval:           0 (<none>)
Reserved blocks uid:      0 (user root)
Reserved blocks gid:      0 (group root)
First inode:              11
Inode size:           128

Otra herramienta útil es lsblk .

# lsblk 

NAME                MAJ:MIN RM   SIZE RO TYPE MOUNTPOINT
sda                   8:0    0    30G  0 disk 
└─sda1                8:1    0    30G  0 part 
  ├─vg1-root (dm-0) 254:0    0  23.3G  0 lvm  /
  └─vg1-swap (dm-1) 254:1    0   1.9G  0 lvm  [SWAP]
sr0                  11:0    1  1024M  0 rom  

Si se ha separado, puede ejecutar un comando como este

parted /dev/sda print all

Model: ATA VBOX HARDDISK (scsi)
Disk /dev/sda: 34.4GB
Sector size (logical/physical): 512B/512B
Partition Table: msdos

Number  Start   End     Size    Type     File system  Flags
 1      32.3kB  255MB   255MB   primary  ext2         boot 
 2      255MB   34.4GB  34.1GB  primary               lvm  

Model: Linux device-mapper (linear) (dm)
Disk /dev/mapper/vg1root: 32.6GB
Sector size (logical/physical): 512B/512B
Partition Table: loop

Number  Start  End     Size    File system  Flags
 1      0.00B  32.6GB  32.6GB  ext3              

De todos modos, le sugiero que eche un vistazo a la fuente de udev o separada .

Zoredache
fuente
12
'vol_id' ha sido renombrado como 'blkid', para cualquiera que se encuentre con esta gran respuesta.
Dave S.
lsblk -i -o kname,mountpoint,fstype,size,maj:min,name,state,rm,rota,ro,type,label,model,serial
sjas
maravillosa respuesta !!
Sufiyan Ghori
5

Otro comando útil es blkid: devuelve información similar vol_idpero también puede escanear todos los dispositivos en el sistema, en lugar de requerir que se pase un dispositivo.

Para forzar el blkidescaneo de todos los dispositivos en lugar de usar la información almacenada en caché, ejecute blkid -c /dev/null(necesita permiso de lectura en los dispositivos de bloque, por lo que generalmente deberá ejecutarlo como root)

James
fuente
Un usuario anónimo quería agregar: todo esto es útil, pero 'vol-id' ahora ha sido reemplazado completamente por 'blkid'; ni SuSE ni Debian tienen 'vol-id' en sus repositorios. Ejecute whereis blockiddesde la línea de comando (o man blockid), encontrará si está cargado. Ejecutar como root: blkid /dev/sdb1da (por ejemplo): también /dev/sdb1: SEC_TYPE="msdos" LABEL="DR-05" UUID="8031-5963" TYPE="vfat"vale la pena ver la página de manual.
Chris S
1

Aquí hay una sugerencia de IBM: SCSI: adición, eliminación y escaneo en caliente de dispositivos SCSI: escaneo de un dispositivo SCSI . Esto volverá a escanear esa dirección SCSI para dispositivos nuevos, y luego podrá leer la información en / var / log / messages. Algunas otras herramientas de disco también funcionarán, sin que monte la unidad.

echo 1 > /sys/bus/scsi/drivers/sd/<SCSI-ID>/block/device/rescan

De hecho, probé ayer algo ligeramente diferente y funcionó (sistema RHEL4):

cd /sys/bus/scsi/devices
echo > 0\:0\:0\:0/rescan
Stefan Lasiewski
fuente
0

Una descripción simple de todas las particiones encontradas por el núcleo da

cat /proc/partitions
Frank Breitling
fuente