desativa o script init.d no systemd

10

Eu mudei o sistema init de sysvinit para systemd em uma instalação raspbian. A instalação inicializa bem, mas agora inicia o lightdm na inicialização. Eu não quero isso.

Percebi que lightdm.service está iniciado na inicialização. Parando o serviço com

systemctl stop lightdm.service

funciona bem.

systemctl disable lightdm.service deve desativá-lo, mas me dá

Failed to issue method call: No such file or directory

systemctl status lightdm.service me dá

lightdm.service - LSB: Light Display Manager
      Loaded: loaded (/etc/init.d/lightdm)
      Active: inactive (dead) since Thu, 03 Jul 2014 09:33:00 +0000; 22min ago
     Process: 762 ExecStop=/etc/init.d/lightdm stop (code=exited, status=0/SUCCESS)
     Process: 411 ExecStart=/etc/init.d/lightdm start (code=exited, status=0/SUCCESS)
      CGroup: name=systemd:/system/lightdm.service

Estou assumindo que o lightdm é iniciado a partir de um script init.d em vez de um script systemd, e systemctl disable não funciona se a origem for um script init.d. O que devo fazer para desativar o lightdm começando na inicialização?

edit: Mais informações

saída de $ ls -l /etc/systemd/system :

total 20
lrwxrwxrwx 1 root root   42 Jul  3 09:04 dbus-fi.epitest.hostap.WPASupplicant.service -> /lib/systemd/system/wpa_supplicant.service
lrwxrwxrwx 1 root root   37 Jul  3 13:03 default.target -> /lib/systemd/system/multi-user.target
drwxr-xr-x 2 root root 4096 Jul  3 09:00 getty.target.wants
drwxr-xr-x 2 root root 4096 Jul  3 09:04 graphical.target.wants
drwxr-xr-x 2 root root 4096 Oct 11  2013 local-fs.target.wants
drwxr-xr-x 2 root root 4096 Jul  3 09:04 multi-user.target.wants
drwxr-xr-x 2 root root 4096 Oct 11  2013 sysinit.target.wants
lrwxrwxrwx 1 root root   35 Mar 20  2013 syslog.service -> /lib/systemd/system/rsyslog.service

saída de systemctl --all -t target :

UNIT                LOAD   ACTIVE   SUB    JOB DESCRIPTION
all.target          error  inactive dead       all.target
basic.target        loaded active   active     Basic System
cryptsetup.target   loaded active   active     Encrypted Volumes
emergency.target    loaded inactive dead       Emergency Mode
final.target        loaded inactive dead       Final Step
getty.target        loaded active   active     Login Prompts
local-fs-pre.target loaded active   active     Local File Systems (Pre)
local-fs.target     loaded active   active     Local File Systems
multi-user.target   loaded active   active     Multi-User
network.target      loaded inactive dead       Network
nss-lookup.target   loaded inactive dead       Name Lookups
remote-fs.target    loaded active   active     Remote File Systems
rescue.target       loaded inactive dead       Rescue Mode
shutdown.target     loaded inactive dead       Shutdown
sockets.target      loaded active   active     Sockets
sound.target        loaded active   active     Sound Card
swap.target         loaded active   active     Swap
sysinit.target      loaded active   active     System Initialization
syslog.target       loaded active   active     Syslog
time-sync.target    loaded inactive dead       System Time Synchronized
umount.target       loaded inactive dead       Unmount All Filesystems

saída de ls -l /etc/systemd/system/multi-user.target.wants/ :

total 8
drwxr-xr-x 2 root root 4096 Jul  3 09:04 .
drwxr-xr-x 7 root root 4096 Jul  3 13:03 ..
lrwxrwxrwx 1 root root   36 Oct 11  2013 remote-fs.target -> /lib/systemd/system/remote-fs.target
lrwxrwxrwx 1 root root   33 Jul  3 09:04 rsync.service -> /lib/systemd/system/rsync.service
lrwxrwxrwx 1 root root   35 Mar 20  2013 rsyslog.service -> /lib/systemd/system/rsyslog.service
lrwxrwxrwx 1 root root   32 Jul  3 09:04 sudo.service -> /lib/systemd/system/sudo.service
lrwxrwxrwx 1 root root   42 Jul  3 09:04 wpa_supplicant.service -> /lib/systemd/system/wpa_supplicant.service
    
por Martijn 03.07.2014 / 12:01

3 respostas

5

Experimente (como root): -

systemctl disable graphical.target

Após a reinicialização, você deve estar no modo multi-user em oposição a graphical .

Se isso falhar, verifique qual é o seu destino padrão: -

ls -l /lib/systemd/system/default.target
# or, depending on your distro
ls -l /etc/systemd/system/default.target

Observe que a única diferença nos caminhos é o diretório de nível superior - /lib ou /etc .

O acima deve ser um link para multi-user.target . Se ele apontar para graphical.target , altere-o usando (como root): -

ln -sf /lib/systemd/system/multi-user.target /lib/systemd/system/default.target
# or
ln -sf /lib/systemd/system/multi-user.target /etc/systemd/system/default.target

dependendo de onde o link foi encontrado no comando ls -l anterior.

Reinicialize e esperamos que seu gerenciador de exibição não inicie.

Para ver quais destinos você tem, execute: -

systemctl --all -t target
    
por 03.07.2014 / 15:08
7

systemctl disable doesn't work if the source is an init.d script. What should I do instead to disable lightdm starting at boot?

Ironicamente, nenhuma das formas "oficiais" de fazer isso foi mencionada em nenhuma resposta até agora. Então, para completude, aqui estão elas:

Você "mascara" o serviço:

systemctl mask lightdm.service

Ou você cria um arquivo de unidade próprio como /etc/systemd/system/lightdm.service que, então, se torna um cidadão systemd de primeira classe adequado que pode ser ativado e desativado com os comandos enable e disable . Arquivos de unidade substituem init.d arquivos do mesmo nome de base. Você pode editar o lightdm.service que foi criado por Pessoas do Debian, se você quiser. ☺

Leitura adicional

por 05.10.2014 / 00:20
2

Você pode ativar e desativar scripts de inicialização com update-rc.d no Debian. Use update-rc.d lightdm disable .

A razão pela qual a desativação do graphical.target não funciona é que o lightdm não possui conhecimento de graphical.target. É um script de inicialização e inicia em todos os runlevels de múltiplos usuários (2-5).

    
por 16.07.2014 / 18:57