Respostas:
systemd
as unidades não precisam obedecer aos arquivos /etc/default
. systemd
é facilmente configurável, mas requer que você conheça a sintaxe dos arquivos da unidade systemd.
Os pacotes enviam arquivos de unidade normalmente /lib/systemd/system/
. Estes não devem ser editados. Em vez disso, systemd
permite substituir esses arquivos criando arquivos apropriados no /etc/systemd/system/
.
Para um determinado serviço foo
, o pacote forneceria /lib/systemd/system/foo.service
. Você pode verificar seu status usando systemctl status foo
ou visualizar seus logs usando journalctl -u foo
. Para substituir algo na definição de foo
, faça:
sudo systemctl edit foo
Isso cria um diretório com o /etc/systemd/system
nome da unidade e um override.conf
arquivo nesse diretório ( /etc/systemd/system/foo.service.d/override.conf
). Você pode adicionar ou substituir configurações usando este arquivo (ou outros .conf
arquivos /etc/systemd/system/foo.service.d/
).
Veja o getty
serviço, por exemplo. Digamos que eu queira ter o logon TTY2 automático para meu usuário (isso não é aconselhável, mas apenas um exemplo). O TTY2 é executado pelo getty@tty2
serviço ( tty2
sendo uma instância do modelo /lib/systemd/system/getty@service
). Para fazer isso, eu tenho que modificar o getty@tty2
serviço.
$ systemctl cat getty@tty2
# /lib/systemd/system/getty@.service
# This file is part of systemd.
#
# systemd is free software; you can redistribute it and/or modify it
# under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation; either version 2.1 of the License, or
# (at your option) any later version.
[Unit]
Description=Getty on %I
Documentation=man:agetty(8) man:systemd-getty-generator(8)
Documentation=http://0pointer.de/blog/projects/serial-console.html
After=systemd-user-sessions.service plymouth-quit-wait.service
After=rc-local.service
# If additional gettys are spawned during boot then we should make
# sure that this is synchronized before getty.target, even though
# getty.target didn't actually pull it in.
Before=getty.target
IgnoreOnIsolate=yes
# On systems without virtual consoles, don't start any getty. Note
# that serial gettys are covered by serial-getty@.service, not this
# unit.
ConditionPathExists=/dev/tty0
[Service]
# the VT is cleared by TTYVTDisallocate
ExecStart=-/sbin/agetty --noclear %I $TERM
Type=idle
Restart=always
RestartSec=0
UtmpIdentifier=%I
TTYPath=/dev/%I
TTYReset=yes
TTYVHangup=yes
TTYVTDisallocate=yes
KillMode=process
IgnoreSIGPIPE=no
SendSIGHUP=yes
# Unset locale for the console getty since the console has problems
# displaying some internationalized messages.
Environment=LANG= LANGUAGE= LC_CTYPE= LC_NUMERIC= LC_TIME= LC_COLLATE= LC_MONETARY= LC_MESSAGES= LC_PAPER= LC_NAME= LC_ADDRESS= LC_TELEPHONE= LC_MEASUREMENT= LC_IDENTIFICATION=
[Install]
WantedBy=getty.target
DefaultInstance=tty1
Em particular, eu tenho que mudar a ExecStart
linha, que atualmente é:
$ systemctl cat getty@tty2 | grep Exec
ExecStart=-/sbin/agetty --noclear %I $TERM
Para substituir isso, faça:
sudo systemctl edit getty@tty2
E adicione:
[Service]
ExecStart=
ExecStart=-/sbin/agetty -a muru --noclear %I $TERM
Observe que:
ExecStart
antes de defini-lo novamente, já que é um cenário aditivo, semelhante a After
, Environment
(como um todo, não per-variável) e EnvironmentFile
, e oposição a substituição de configurações de como RestartSec
ou Type
. ExecStart
pode ter várias entradas apenas para Type=oneshot
serviços.ExecStart
está na [Service]
seção, então minha substituição também deve ser incluída ExecStart
na [Service]
seção. Muitas vezes, ver o arquivo de serviço real usando systemctl cat
indica o que você precisa substituir e em qual seção ele está.Geralmente, se você editar um arquivo de unidade systemd, para que ele entre em vigor, será necessário executar:
sudo systemctl daemon-reload
No entanto, systemctl edit
isso é feito automaticamente por você.
Agora:
$ systemctl cat getty@tty2 | grep Exec
ExecStart=-/sbin/agetty --noclear %I $TERM
ExecStart=
ExecStart=-/sbin/agetty -a muru --noclear %I $TERM
$ systemctl show getty@tty2 | grep ExecS
ExecStart={ path=/sbin/agetty ; argv[]=/sbin/agetty -a muru --noclear %I $TERM ; ... }
E se eu fizer:
sudo systemctl restart getty@tty2
e pressione CtrlAltF2, pronto! Vou entrar na minha conta nesse TTY.
Como eu disse antes, getty@tty2
é uma instância de um modelo. Então, e se eu quisesse substituir todas as instâncias desse modelo? Isso pode ser feito editando o próprio modelo (removendo o identificador da instância - neste caso tty2
):
systemctl edit getty@
Um caso de uso comum de /etc/default
arquivos é definir variáveis de ambiente. Geralmente, /etc/default
é um script de shell, então você pode usar construções de linguagem de shell nele. Com systemd
, no entanto, este não é o caso. Você pode especificar variáveis de ambiente de duas maneiras:
Digamos que você configurou as variáveis de ambiente em um arquivo:
$ cat /path/to/some/file
FOO=bar
Em seguida, você pode adicionar à substituição:
[Service]
EnvironmentFile=/path/to/some/file
Em particular, se o seu /etc/default/grub
contiver apenas atribuições e nenhuma sintaxe do shell, você poderá usá-lo como o EnvironmentFile
.
Environment
entradasO procedimento acima também pode ser realizado usando a seguinte substituição:
[Service]
Environment=FOO=bar
No entanto, isso pode ser complicado com várias variáveis, espaços etc. Veja uma das minhas outras respostas para um exemplo de uma instância desse tipo.
Por meio desse mecanismo, fica muito fácil substituir systemd
unidades e desfazer essas alterações (simplesmente removendo o arquivo de substituição). Essas não são as únicas configurações que podem ser modificadas.
Os seguintes links seriam úteis:
systemd
systemd
páginas de manual , em particular, as páginas de manual systemd.unit
esystemd.service
systemd.service(5)
manual, seção sobre ExecStart
: "A menos que Type = oneshot, seja necessário exatamente um comando. Quando Type = oneshot é usado, zero ou mais comandos podem ser especificados. Comandos podem ser especificados fornecendo várias linhas de comando na mesma diretiva ou, alternativamente, esta diretiva pode ser especificada mais de uma vez com o mesmo efeito. Se a sequência vazia for atribuída a esta opção, a lista de comandos a ser iniciada será redefinida, as atribuições anteriores dessa opção não terão efeito. "
sudo rm
substituir o arquivo e systemctl daemon-reload
, em seguida , systemctl edit
substituir todos os itens da substituição por comentários. Os comentários nos arquivos de serviço começam com #
.
systemctl revert foo
ExecStart=
entrada com um espaço em branco, você não pode colocar um comentário depois da seguinte forma:ExecStart= # Empty line to clear previous entries.
Isso será tomado como outraExecStart=
entrada e adicionado à lista. PS. Não pude comentar a resposta de muru por causa de minha baixa reputação.