O que faz com que / dev / disk / by-label seja preenchido?

12

Tenho notado que as distribuições Linux normalmente têm um diretório / dev / disk / by-label, mas nem sempre é esse o caso (por exemplo, o CirrOS A imagem de teste do Linux não tem uma).

O que é necessário em um sistema Linux para que o diretório / dev / disk / by-label seja devidamente preenchido?

    
por Lorin Hochstein 21.11.2012 / 13:03

2 respostas

8

Na maioria dos sistemas Linux modernos, praticamente tudo sob /dev é colocado lá pelo udev.

Na minha máquina Debian, /dev/disk/by-label vem de vários arquivos em /lib/udev/rules.d Por exemplo, aqui está uma regra de 60-persistent-storage.rules :

ENV{ID_FS_LABEL_ENC}=="?*",     ENV{ID_FS_USAGE}=="filesystem|other", \
        SYMLINK+="disk/by-label/$env{ID_FS_LABEL_ENC}"

Algumas linhas anteriores são de onde vem ID_FS_LABEL_ENC :

# probe filesystem metadata of disks
KERNEL!="sr*", IMPORT{program}="/sbin/blkid -o udev -p $tempnode"

Você pode executar blkid para ver os dados passando para o udev:

root@Zia:~# /sbin/blkid -o udev -p /dev/sda2
ID_FS_SEC_TYPE=msdos
ID_FS_LABEL=xfer1
ID_FS_LABEL_ENC=xfer1
ID_FS_UUID=B140-C934
ID_FS_UUID_ENC=B140-C934
ID_FS_VERSION=FAT16
ID_FS_TYPE=vfat
ID_FS_USAGE=filesystem
ID_PART_ENTRY_SCHEME=dos
ID_PART_ENTRY_TYPE=0xc
ID_PART_ENTRY_NUMBER=2
ID_PART_ENTRY_OFFSET=257040
ID_PART_ENTRY_SIZE=257040
ID_PART_ENTRY_DISK=8:0

E, de fato:

root@Zia:~# ls -l /dev/disk/by-label/xfer1 
lrwxrwxrwx 1 root root 10 Nov 19 10:02 /dev/disk/by-label/xfer1 -> ../../sda2

Você pode colocar arquivos de regras adicionais em /etc/udev/rules.d/ se quiser criar nomes adicionais para dispositivos, alterar permissões etc. Por exemplo, temos um que preenche e define as permissões em /dev/disk/for-asm .

    
por 21.11.2012 / 17:54
0

udisks-daemon provavelmente está fazendo isso (embora HAL ou DBUS também possam). Você pode assistir isso acontecer se você estiver tão inclinado. Abra um termanal e execute:

udisks --monitor-detail

e, em seguida, conecte uma unidade. Você terá algo como:

job-changed: /org/freedesktop/UDisks/devices/sdb1
  job underway:                FilesystemMount, initiated by uid 1000
changed:     /org/freedesktop/UDisks/devices/sdb1
Showing information for /org/freedesktop/UDisks/devices/sdb1
  native-path:                 /sys/devices/pci0000:00/0000:00:1a.7/usb1/1-4/1-4:1.0/host3/target3:0:0/3:0:0:0/block/sdb/sdb1
  device:                      8:17
  device-file:                 /dev/sdb1
    presentation:              /dev/sdb1
    by-id:                     /dev/disk/by-id/usb-SanDisk_Cruzer_20054858820EEB607D7D-0:0-part1
    by-id:                     /dev/disk/by-uuid/D033-D063
    by-path:                   /dev/disk/by-path/pci-0000:00:1a.7-usb-0:4:1.0-scsi-0:0:0:0-part1
  detected at:                 Wed 21 Nov 2012 07:45:47 AM EST
  system internal:             0
  removable:                   0
  has media:                   1 (detected at Wed 21 Nov 2012 07:45:47 AM EST)
    detects change:            0
    detection by polling:      0
    detection inhibitable:     0
    detection inhibited:       0
  is read only:                0
  is mounted:                  1
  mount paths:             /media/CRUZER
  mounted by uid:              1000
  presentation hide:           0
  presentation nopolicy:       0
  presentation name:           
  presentation icon:           
  size:                        8000094208
  block size:                  512
  job underway:                no
  usage:                       filesystem
  type:                        vfat
  version:                     FAT32
  uuid:                        D033-D063
  label:                       CRUZER
  partition:
    part of:                   /org/freedesktop/UDisks/devices/sdb
    scheme:                    mbr
    number:                    1
    type:                      0x0b
    flags:                    
    offset:                    16384
    alignment offset:          0
    size:                      8000094208
    label:                     
    uuid:                      
    
por 21.11.2012 / 13:45