ブートが遅いのはなぜですか?

ブートが遅いのはなぜですか?

私はFedora 23、MATEバージョンを使用しています。コンピュータの起動速度が非常に遅く感じます。どのようにスピードアップできますか?

詳細https://i.stack.imgur.com/vpJEG.jpg

$ systemd-analyze 
Startup finished in 16.571s (firmware) + 2.605s (loader) + 824ms (kernel) + 1.997s (initrd) + 48.466s (userspace) = 1min 10.464s

$ systemd-analyze blame
         31.448s mlocate-updatedb.service
         18.211s akmods.service
         16.019s firewalld.service
          9.127s systemd-journald.service
          7.709s accounts-daemon.service
          7.368s dev-sdd3.device
          7.037s systemd-udev-settle.service
          5.219s abrtd.service
          4.854s chronyd.service
          4.629s ModemManager.service
          4.081s livesys.service
          3.958s unbound-anchor.service
          3.920s systemd-logind.service
          3.823s rsyslog.service
          3.781s gssproxy.service
          3.780s akmods-shutdown.service
          3.698s avahi-daemon.service
          3.651s mcelog.service
          3.636s rtkit-daemon.service
          2.735s polkit.service
          2.163s systemd-udevd.service
          2.150s lvm2-monitor.service
          1.569s proc-fs-nfsd.mount

$ systemd-analyze critical-chain 
The time after the unit is active or started is printed after the "@" character.
The time the unit takes to start is printed after the "+" character.

graphical.target @35.395s
└─lightdm.service @34.563s +830ms
  └─systemd-user-sessions.service @34.146s +129ms
    └─remote-fs.target @34.143s
      └─remote-fs-pre.target @34.143s
        └─iscsi-shutdown.service @34.128s
          └─network.target @34.019s
            └─NetworkManager.service @33.009s +1.009s
              └─firewalld.service @16.979s +16.019s
                └─polkit.service @17.870s +2.735s
                  └─basic.target @12.883s
                    └─sockets.target @12.864s
                      └─dbus.socket @12.844s
                        └─sysinit.target @12.704s
                          └─sys-fs-fuse-connections.mount @48.351s +3ms
                            └─system.slice
                              └─-.slice

答え1

これは既知の問題であり、次のトピックで説明されています。レッドハットバーグジラ:

systemdにはcronのランダム遅延機能が不足しており、私たちに打撃を与えます。機能要求があるのを見ました。しかし、それまでは、updatebを実行する前に手動でランダムスリープモードを設定することが解決策のようです。。今updatebを実行するには、cronを使用する方法に戻るか、updatebを実行する前にランダムまたは特定のスリープモードを実行することをお勧めします。例: sleep 1h

解決策:

sed 's/daily/weekly/' /usr/lib/systemd/system/mlocate-updatedb.timer >/etc/systemd/system/mlocate-updatedb.timer

今月曜日の遅い開始に耐えることができます。

答え2

次の回避策をお勧めします。 mlocate-updatedb.service 起動を数分 (たとえば 10 分) 遅らせ、システムの起動時に実行する必要がある場合は、一定時間後に起動するようにします。

これはこれを行い、mlocateパッケージが更新されても交換されません。

mkdir /etc/systemd/system/mlocate-updatedb.service.d
cat <<EOF > /etc/systemd/system/mlocate-updatedb.service.d/mlocate-updatedb.conf
[Service]
ExecStart=
ExecStart=/bin/sleep 10m
ExecStart=/usr/libexec/mlocate-run-updatedb
EOF

これの利点は、遅い起動を防ぐことです(まだテストしていませんが、これを実行する必要があり、ロケーションデータベースを毎日更新します)。

systemd-222-14.fc23.x86_64(以上)を含むFedora 23の場合: systemdタイマーには、この問題に対する解決策を提供するように見えるRandomizedDelaySecという新しいオプションがあります。したがって、次の行を追加することも効果があります。RandomizedDelaySec = 30m

(遅延は依然として無作為であるため、時には非常に小さく、開始速度が遅くなる可能性があります。)

修正する:アップデートがFedoraテストストアにプッシュされました。これにより、サービスの種類がから変更されたように見えますoneshot。これにより、systemdは続行する前にシャットダウンを待たなくsimpleなります。updatedbこれはある程度問題を解決します。ただし、IOが多すぎると起動プロセスが遅くなる可能性があるため、起動中に実行されないようにsleeporを使用することをお勧めします。RandomizedDelaySec

関連情報