Quais são os serviços de loop dev iniciados na inicialização?

12

Após a inicialização, executei systemd-analyze blamee aqui estão os resultados:

     21.596s systemd-journal-flush.service
     18.658s dev-sda8.device
     15.099s dev-loop33.device
     15.034s dev-loop19.device
     15.012s dev-loop34.device
     14.989s dev-loop21.device
     14.877s dev-loop15.device
     14.866s dev-loop26.device
     14.773s dev-loop27.device
     14.684s dev-loop30.device
     14.677s dev-loop32.device
     14.649s dev-loop35.device
     14.590s dev-loop25.device
     14.267s dev-loop23.device
     14.192s dev-loop24.device
     14.156s dev-loop29.device
     14.133s dev-loop16.device
     14.065s dev-loop31.device
     14.059s dev-loop28.device
     13.821s dev-loop20.device
     13.531s dev-loop22.device
     13.495s dev-loop14.device
     13.364s dev-loop18.device

O que são esses serviços dev-loopxx.device( xxdenota números) e por que eles estão demorando tanto? Eles estão relacionados à montagem de encaixes? Posso reduzir o tempo de inicialização desativando-os? Estou executando o Ubuntu 18.04 ao lado do Windows 10.

Apoorv Potnis
fonte
Os meus levam 14ms no máximo. Além disso, tenho apenas 5 deles.
18718 Jos Jos
@ Jos Isso significa que existem alguns erros no meu sistema?
Apoorv Potnis
Não, isso não significa que existem erros. Isso significa que você tem mais software instalado a partir de contêineres. Cada dispositivo de loop é uma instalação instantânea.
Rinzwind 16/07/19
@Rinzwind Então, se eu desinstalar esses snaps e instalar as versões não snap desses aplicativos, minha inicialização será mais rápida?
Apoorv Potnis
1
Sim, ele removerá um loop por instalação (e também revisões antigas, se houver).
Rinzwind 16/07/19

Respostas:

17

Você pode determinar a lista de todos os snaps instalados snap list, para a relação entre o ponto de montagem e o nome do snap que você pode usar systemctl status, mounte losetup.

Por exemplo, no meu Ubuntu MATE 18.04 LTS, tenho os seguintes snaps instalados:

$ snap list
Name                 Version           Rev   Tracking  Developer      Notes
core                 16-2.33.1         4917  stable    canonical      core
software-boutique    18.04.0-5b99b84   31    stable/…  flexiondotorg  classic
ubuntu-mate-welcome  17.10.23-e4f4c4c  169   stable/…  flexiondotorg  classic

Eles criam dispositivos de loop da seguinte maneira:

$ systemd-analyze blame | grep dev-loop
          4.303s dev-loop4.device
          4.267s dev-loop2.device
          4.193s dev-loop0.device
          4.146s dev-loop3.device
           111ms dev-loop5.device

Os pontos de montagem são os seguintes:

$ mount | grep snapd
/var/lib/snapd/snaps/core_4830.snap on /snap/core/4830 type squashfs (ro,nodev,relatime,x-gdu.hide)
/var/lib/snapd/snaps/ubuntu-mate-welcome_169.snap on /snap/ubuntu-mate-welcome/169 type squashfs (ro,nodev,relatime,x-gdu.hide)
/var/lib/snapd/snaps/software-boutique_31.snap on /snap/software-boutique/31 type squashfs (ro,nodev,relatime,x-gdu.hide)
/var/lib/snapd/snaps/core_4650.snap on /snap/core/4650 type squashfs (ro,nodev,relatime,x-gdu.hide)
/var/lib/snapd/snaps/core_4917.snap on /snap/core/4917 type squashfs (ro,nodev,relatime,x-gdu.hide)

Vamos olhar mais perto de dev-loop4.device:

$ systemctl status dev-loop4.device
● dev-loop4.device - /dev/loop4
   Follow: unit currently follows state of sys-devices-virtual-block-loop4.device
   Loaded: loaded
   Active: active (plugged) since Tue 2018-07-17 13:05:41 MSK; 4min 44s ago
   Device: /sys/devices/virtual/block/loop4

A pasta /sys/devices/virtual/block/loop4contém um arquivo muito útil loop/backing_file, podemos ler seu conteúdo:

$ cat /sys/devices/virtual/block/loop4/loop/backing_file 
/var/lib/snapd/snaps/core_4650.snap

Então, acabamos de determinar que /dev/loop4é criado por corepressão.


Mas a maneira mais fácil é usar losetup(consulte man losetup):

$ losetup 
NAME       SIZELIMIT OFFSET AUTOCLEAR RO BACK-FILE                                         DIO LOG-SEC
/dev/loop4         0      0         1  1 /var/lib/snapd/snaps/core_4650.snap                 0     512
/dev/loop2         0      0         1  1 /var/lib/snapd/snaps/ubuntu-mate-welcome_169.snap   0     512
/dev/loop0         0      0         1  1 /var/lib/snapd/snaps/core_4830.snap                 0     512
/dev/loop5         0      0         1  1 /var/lib/snapd/snaps/core_4917.snap                 0     512
/dev/loop3         0      0         1  1 /var/lib/snapd/snaps/software-boutique_31.snap      0     512

Espero que isso ajude a entender melhor os pontos de montagem do Snaps.

Conclusão: ao usar o Snaps para ter um software atualizado, acabamos pagando por ele com maior tráfego de rede, mais uso de disco e menor tempo de inicialização. Se você não deseja usar Snaps, remova-os com sudo apt-get purge snapd.

N0rbert
fonte
A essa altura, o snap melhorou muito, por isso pode não haver um tempo de inicialização tão
ruim para