Difference between revisions of "Systemd (Português)"
(→Processos de curta duração não parecem registrar qualquer saída) |
(→Migração do SysVinit/initscripts: flagged for deletion. refer to Talk:Systemd#systemd_no_longer_supports_initscripts) |
||
(21 intermediate revisions by 2 users not shown) | |||
Line 25: | Line 25: | ||
De [http://freedesktop.org/wiki/Software/systemd project web page]: | De [http://freedesktop.org/wiki/Software/systemd project web page]: | ||
− | :''Systemd'' é um sistema e gerenciador de serviços para Linux, compatível com os scripts de inicializações SysV e LS. ''Systemd'' fornece recursos de paralelização agressivos, usa socket e ativação [[D-Bus]] para iniciar | + | :''Systemd'' é um sistema e gerenciador de serviços para Linux, compatível com os scripts de inicializações SysV e LS. ''Systemd'' fornece recursos de paralelização agressivos, usa socket e ativação [[D-Bus]] para iniciar serviços, oferece o início de daemons on-demand, mantém o registro de processos usando [[cgroups|grupos de controle]] Linux, suporte snapshotting e restauração do estado do sistema, preserva pontos de montagens e automontagens e implementa uma lógica de controle elaborado transacional baseada em dependência de serviço. |
− | {{Nota|1=Para uma explicação detalhada do porquê Arch | + | {{Nota|1=Para uma explicação detalhada do porquê Arch migrou para o ''systemd'', consulte [https://bbs.archlinux.org/viewtopic.php?pid=1149530#p1149530 esta mensagem do fórum internacional].}} |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
== Uso básico systemctl == | == Uso básico systemctl == | ||
− | O principal comando usado para introspecção e controle ''systemd'' é '''systemctl'''. Alguns de seus usos são examinando o estado do sistema e gerenciando | + | O principal comando usado para introspecção e controle ''systemd'' é '''systemctl'''. Alguns de seus usos são examinando o estado do sistema e gerenciando o sistema e serviços. Consulte {{ic|man 1 systemctl}} para mais detalhes. |
− | {{ | + | {{Dica |Você pode usar todos os comandos ''systemctl'' com o {{ic|-H ''user''@''host''}} que muda para controlar uma instância ''systemd'' em uma máquina remota. Isso usará [[SSH]] para conectar-se uma instância remota ''systemd''.}} |
− | {{Nota|''systemadm'' é a interface gráfica oficial para ''systemctl''. é | + | {{Nota|''systemadm'' é a interface gráfica oficial para ''systemctl''. é fornecida pelo pacote {{AUR|systemd-ui-git}} do [[AUR]].}} |
=== Analisando o estado do sistema === | === Analisando o estado do sistema === | ||
Line 93: | Line 61: | ||
Quando usa ''systemctl'', você geralmente tem que especificar o nome completo do arquivo unit, incluindo o sufixo, por exemplo ''sshd.socket''. No entanto, existem algumas formas curtas de especificar a unit nos seguintes comandos ''systemctl'': | Quando usa ''systemctl'', você geralmente tem que especificar o nome completo do arquivo unit, incluindo o sufixo, por exemplo ''sshd.socket''. No entanto, existem algumas formas curtas de especificar a unit nos seguintes comandos ''systemctl'': | ||
− | * Se você não especificar o sufixo, systemctl | + | * Se você não especificar o sufixo, systemctl assumirá ''.service''. Por exemplo, {{ic|netcfg}} e {{ic|netcfg.service}} são equivalentes. |
* Os pontos de montagem serão automaticamente convertidos para a unit ''.mount'' adequada. Por exemplo, especificando {{ic|/home}} equivale a {{ic|home.mount}}. | * Os pontos de montagem serão automaticamente convertidos para a unit ''.mount'' adequada. Por exemplo, especificando {{ic|/home}} equivale a {{ic|home.mount}}. | ||
* Similar aos pontos de montagem, dispositivos são automaticamente convertido para a unit ''.device'' adequada, portanto, especificando {{ic|/dev/sda2}} equivale a {{ic|dev-sda2.device}}. | * Similar aos pontos de montagem, dispositivos são automaticamente convertido para a unit ''.device'' adequada, portanto, especificando {{ic|/dev/sda2}} equivale a {{ic|dev-sda2.device}}. | ||
Line 128: | Line 96: | ||
# systemctl enable ''unit'' | # systemctl enable ''unit'' | ||
− | {{ | + | {{Nota |Serviços sem uma seção {{ic|[Install]}} são geralmente chamados por outros serviços automaticamente. Se você precisa instalá-los manualmente, use o seguinte comando, substituindo ''foo'' com o nome do serviço. |
# ln -s /usr/lib/systemd/system/''foo''.service /etc/systemd/system/graphical.target.wants/ | # ln -s /usr/lib/systemd/system/''foo''.service /etc/systemd/system/graphical.target.wants/ | ||
}} | }} | ||
Line 152: | Line 120: | ||
$ systemctl reboot | $ systemctl reboot | ||
− | Desliga e | + | Desliga e encerra o sistema: |
$ systemctl poweroff | $ systemctl poweroff | ||
Line 164: | Line 132: | ||
$ systemctl hibernate | $ systemctl hibernate | ||
− | Coloca o sistema | + | Coloca o sistema em modo de suspensão : |
$ systemctl hybrid-sleep | $ systemctl hybrid-sleep | ||
Line 170: | Line 138: | ||
== Executando Gerenciadores de Display no systemd == | == Executando Gerenciadores de Display no systemd == | ||
− | {{Merge|Display Manager|Temos artigo separado, esta seção deve ser | + | {{Merge|Display Manager|Temos artigo separado, esta seção deve ser mudada para lá para manter as coisas em um só lugar.}} |
Para habilitar a autenticação gráfica, execute o seu daemon de [[Display Manager]] preferido (ex. [[KDM]]). No momento, existem arquivos de serviço para [[GDM]], [[KDM]], [[SLiM]], [[XDM]], [[LXDM]], [[LightDM]], e {{AUR|SDDM}}. | Para habilitar a autenticação gráfica, execute o seu daemon de [[Display Manager]] preferido (ex. [[KDM]]). No momento, existem arquivos de serviço para [[GDM]], [[KDM]], [[SLiM]], [[XDM]], [[LXDM]], [[LightDM]], e {{AUR|SDDM}}. | ||
Line 196: | Line 164: | ||
=== Console virtual === | === Console virtual === | ||
− | {{Deletion|Não estritamente relacionados, tentando remover a seção [[#Native configuration]] inteiramente.|section=Duplication of content in Native configuration section}} | + | {{Deletion |Não estritamente relacionados, tentando remover a seção [[#Native configuration]] inteiramente.|section=Duplication of content in Native configuration section}} |
O console virtual (mapeamento de teclado, fonte do console e mapa do console) é configurado em {{ic|/etc/vconsole.conf}} ou utilizando a ferramenta ''localectl''. | O console virtual (mapeamento de teclado, fonte do console e mapa do console) é configurado em {{ic|/etc/vconsole.conf}} ou utilizando a ferramenta ''localectl''. | ||
Line 207: | Line 175: | ||
''systemd'' usará UTC para o relógio do hardware por padrão. | ''systemd'' usará UTC para o relógio do hardware por padrão. | ||
− | {{ | + | {{Dica |É aconselhável ter [[Network Time Protocol daemon]] correndo para manter a hora do sistema sincronizado com a hora da Internet e o relógio do hardware.}} |
==== Relógio do hardware em localtime ==== | ==== Relógio do hardware em localtime ==== | ||
− | Se quiser alterar o relógio de hardware para usar horário local ('''não recomendado''') | + | Se quiser alterar o relógio de hardware para usar horário local ('''não recomendado'''), faça: |
# timedatectl set-local-rtc true | # timedatectl set-local-rtc true | ||
Line 219: | Line 187: | ||
# timedatectl set-local-rtc false | # timedatectl set-local-rtc false | ||
− | + | Fique avisado que, se o relógio do hardware está definido para localtime, lidar com o horário de verão é uma confusão([http://www.cl.cam.ac.uk/~mgk25/mswish/ut-rtc.html há muito mais do que isso]). | |
− | Uma razão para permitir que o RTC esteja em hora local é permitir dual boot com o | + | Uma razão para permitir que o RTC esteja em hora local é permitir dual boot com o Windows ([http://blogs.msdn.com/b/oldnewthing/archive/2004/09/02/224672.aspx que usa localtime]). No entanto, o Windows é capaz de lidar com a RTC iniciando em UTC, com um simples [[Time#UTC in Windows|correção de registro]]. |
Para mais informação, consulte [[Time]]. | Para mais informação, consulte [[Time]]. | ||
=== Módulos do kernel === | === Módulos do kernel === | ||
− | {{Deletion|Não estritamente relacionados, tentando remover a | + | {{Deletion |Não estritamente relacionados, tentando remover a seção [[#Native configuration]] inteiramente.|section=Duplication of content in Native configuration section}} |
Consulte [[Kernel modules#Configuration]]. | Consulte [[Kernel modules#Configuration]]. | ||
Line 233: | Line 201: | ||
{{Merge|File Systems|Esta seção foi adicionada antes do systemd tornar-se o sistema de inicialização padrão. Removida após a fusão.|section=Duplication of content in Native configuration section}} | {{Merge|File Systems|Esta seção foi adicionada antes do systemd tornar-se o sistema de inicialização padrão. Removida após a fusão.|section=Duplication of content in Native configuration section}} | ||
− | A configuração padrão será automaticamente fsck e montará sistemas de arquivos antes de iniciar os serviços que eles precisam para serem montados. Por exemplo, systemd automaticamente garante que | + | A configuração padrão será automaticamente fsck e montará sistemas de arquivos antes de iniciar os serviços que eles precisam para serem montados. Por exemplo, systemd automaticamente garante que montagens de sistemas de arquivos remotos como [[NFS]] ou [[Samba]] são somente iniciados depois que a rede for configurada. Portanto, montagens de sistema de arquivos local e remoto especificadas em {{ic|/etc/fstab}}} devem funcionar. |
Consulte {{ic|man 5 systemd.mount}} por detalhes. | Consulte {{ic|man 5 systemd.mount}} por detalhes. | ||
Line 240: | Line 208: | ||
{{Merge|fstab|Esta seção foi adicionada antes do systemd tornar-se o sistema de inicialização padrão. Removida após a fusão.|section=Duplication of content in Native configuration section}} | {{Merge|fstab|Esta seção foi adicionada antes do systemd tornar-se o sistema de inicialização padrão. Removida após a fusão.|section=Duplication of content in Native configuration section}} | ||
− | Se você tem uma partição {{ic|/home}} grande, talvez seja melhor permitir | + | Se você tem uma partição {{ic|/home}} grande, talvez seja melhor permitir serviços que não dependem da {{ic|/home}} para iniciar enquanto {{ic|/home}} é verificada pelo ''fsck''. Isto pode ser feito adicionando as seguintes opções em {{ic|/etc/fstab}} na entrada de sua partição {{ic|/home}}: |
noauto,x-systemd.automount | noauto,x-systemd.automount | ||
− | Isso irá fsck e montar {{ic|/home}} | + | Isso irá fsck e montar {{ic|/home}} ao acessada pela primeira vez, e o kernel irá reter todos os acessos de arquivo para {{ic|/home}} até que esteja pronto. |
− | {{ | + | {{Nota |Isso vai fazer seu sistema de arquivo {{ic|/home}} tipo {{ic|autofs}}, seja ignorado pelo [[mlocate]] por padrão. A aceleração de automontagem {{ic|/home}} pode não ser mais do que um ou dois segundos, dependendo do seu sistema, de modo que este truque possa não valer a pena.}} |
− | O mesmo se aplica para montagens de sistemas de arquivos remotos. Se você quer que eles sejam montados apenas no acesso, você vai precisar usar o parâmetro {{ic|noauto,x-systemd.automount}}. Além disso, você pode usar a opção {{ic|1=x-systemd.device-timeout=#}} para especificar um limite no caso do recurso de rede não | + | O mesmo se aplica para montagens de sistemas de arquivos remotos. Se você quer que eles sejam montados apenas no acesso, você vai precisar usar o parâmetro {{ic|noauto,x-systemd.automount}}. Além disso, você pode usar a opção {{ic|1=x-systemd.device-timeout=#}} para especificar um limite no caso do recurso de rede não está disponível. |
− | Se você tem sistemas de arquivos criptografados com arquivo chaves, também pode adicionar o parâmetro {{ic|noauto}} para as entradas correspondentes em {{ic|/etc/crypttab}}. ''systemd'' | + | Se você tem sistemas de arquivos criptografados com arquivo chaves, também pode adicionar o parâmetro {{ic|noauto}} para as entradas correspondentes em {{ic|/etc/crypttab}}. Então ''systemd'' não vai abrir o dispositivo criptografado no boot, mas espera até que ele seja realmente acessado e então automaticamente o abre com o arquivo chave especificado antes de montá-lo. Isso pode economizar alguns segundos na inicialização, se você estiver usando um dispositivo RAID criptografado por exemplo, porque o systemd não tem que esperar para o dispositivo se tornar disponível. Por exemplo: |
{{hc|/etc/crypttab| | {{hc|/etc/crypttab| | ||
Line 257: | Line 225: | ||
==== LVM ==== | ==== LVM ==== | ||
{{Merge|LVM|Esta seção foi adicionada aqui antes do systemd tornar-se o sistema de inicialização padrão. Removida após a fusão.|section=Duplication of content in Native configuration section}} | {{Merge|LVM|Esta seção foi adicionada aqui antes do systemd tornar-se o sistema de inicialização padrão. Removida após a fusão.|section=Duplication of content in Native configuration section}} | ||
− | Se você não tiver volumes [[LVM]] ativados via o [[Mkinitcpio|initramfs]], [[Systemd#Using_units| | + | Se você não tiver volumes [[LVM]] ativados via o [[Mkinitcpio|initramfs]], [[Systemd#Using_units|habilite]] o serviço '''lvm-monitoring''', que é fornecido pelo pacote {{pkg|lvm2}}. |
=== Gerenciamento de energia ACPI === | === Gerenciamento de energia ACPI === | ||
Line 270: | Line 238: | ||
Cada arquivo de configuração é chamado no estilo {{ic|/etc/tmpfiles.d/''program''.conf}}. Isso também irá substituir todos os arquivos em {{ic|/usr/lib/tmpfiles.d/}} com o mesmo nome. | Cada arquivo de configuração é chamado no estilo {{ic|/etc/tmpfiles.d/''program''.conf}}. Isso também irá substituir todos os arquivos em {{ic|/usr/lib/tmpfiles.d/}} com o mesmo nome. | ||
− | tmpfiles normalmente são fornecidos em conjunto com arquivos de serviços para criar diretórios que deverão existir por certas daemons. Por exemplo | + | tmpfiles normalmente são fornecidos em conjunto com arquivos de serviços para criar diretórios que deverão existir por certas daemons. Por exemplo a daemon [[Samba]] espera que o diretório {{ic|/run/samba}} exista e tenha as permissões corretas. Assim, o pacote {{Pkg|samba}} vem com esta configuração: |
{{hc|/usr/lib/tmpfiles.d/samba.conf| | {{hc|/usr/lib/tmpfiles.d/samba.conf| | ||
Line 282: | Line 250: | ||
Consulte {{ic|man 5 tmpfiles.d}} para detalhes. | Consulte {{ic|man 5 tmpfiles.d}} para detalhes. | ||
− | {{ | + | {{Nota |Este método pode não funcionar para definir as opções em {{ic|/sys}} uma vez que o serviço ''systemd-tmpfiles-setup'' pode ser executado antes dos módulos de dispositivo apropriado for carregado. Neste caso, você pode verificar se o módulo tem um parâmetro para a opção que pretende definir com {{ic|modinfo ''module''}} e ajustar essa opção com um [[Modprobe.d#Configuration|arquivo de configuração em /etc/modprobe.d]]. Caso contrário, você terá que escrever uma [[Udev#About_udev_rules|regra udev]] para ajustar o atributo adequado logo que o dispositivo aparecer.}} |
== Escrevendo arquivos .service personalizados == | == Escrevendo arquivos .service personalizados == | ||
Line 292: | Line 260: | ||
=== Manuseando dependências === | === Manuseando dependências === | ||
− | Com ''systemd'', dependências podem ser resolvidas através da concepção de arquivos unit | + | Com ''systemd'', dependências podem ser resolvidas através da concepção de arquivos unit corretamente. O caso mais típico é a unit ''A'' requerer a unit ''B'' para ser executada antes da ''A'' ser iniciada. Nesse caso, adicione {{ic|1=Requires=''B''}} e {{ic|1=After=''B''}} para a seção {{ic|[Unit]}} de ''A''. Se a dependência for opcional, então adicione {{ic|1=Wants=''B''}} e {{ic|1=After=''B''}}. Nota que {{ic|1=Wants=}} e {{ic|1=Requires=}} não implicam {{ic|1=After=}}, significando que se {{ic|1=After=}} não for especificado, as duas units serão iniciada em paralelo. |
− | Dependências são normalmente colocadas em serviços e não em targets. Por exemplo, o ''network.target'' é puxado por qualquer serviço que configure as interfaces de rede, portanto, ordenando a sua unit personalizada depois é | + | Dependências são normalmente colocadas em serviços e não em targets. Por exemplo, o ''network.target'' é puxado por qualquer serviço que configure as interfaces de rede, portanto, ordenando a sua unit personalizada depois disso é o bastante desde que ''network.target'' é iniciado de qualquer maneira. |
=== Tipo === | === Tipo === | ||
Line 304: | Line 272: | ||
* {{ic|1=Type=oneshot}}: este é útil para os scripts que fazem um trabalho único e, em seguida, saem. Você pode querer definir {{ic|1=RemainAfterExit=yes}} também para que ''systemd'' ainda considere o serviço como ativo depois que o processo foi encerrado. | * {{ic|1=Type=oneshot}}: este é útil para os scripts que fazem um trabalho único e, em seguida, saem. Você pode querer definir {{ic|1=RemainAfterExit=yes}} também para que ''systemd'' ainda considere o serviço como ativo depois que o processo foi encerrado. | ||
* {{ic|1=Type=notify}}: idêntico ao {{ic|1=Type=simple}}, mas com a condição de que o servidor irá enviar um sinal para ''systemd'' quando estiver pronto. A implementação de referência para essa notificação é fornecido pelo ''libsystemd-daemon.so''. | * {{ic|1=Type=notify}}: idêntico ao {{ic|1=Type=simple}}, mas com a condição de que o servidor irá enviar um sinal para ''systemd'' quando estiver pronto. A implementação de referência para essa notificação é fornecido pelo ''libsystemd-daemon.so''. | ||
− | * {{ic|1=Type=dbus}}: o serviço é considerado pronto quando o especificado {{ic|BusName}} aparece | + | * {{ic|1=Type=dbus}}: o serviço é considerado pronto quando o especificado {{ic|BusName}} aparece no barramento do sistema do DBus. |
=== Edição de arquivos units referidos === | === Edição de arquivos units referidos === | ||
Line 315: | Line 283: | ||
After=''new dependency''}} | After=''new dependency''}} | ||
− | Em seguida, execute | + | Em seguida, execute os comandos para que as alterações tenham efeito: |
# systemctl daemon-reload | # systemctl daemon-reload | ||
Line 322: | Line 290: | ||
Alternativamente, você pode copiar o antigo arquivo unit de {{ic|/usr/lib/systemd/system/}} para {{ic|/etc/systemd/system/}} e fazer suas modificações lá. Um arquivo unit em {{ic|/etc/systemd/system/}} sempre sobrepõe a mesma unit em {{ic|/usr/lib/systemd/system/}}. Note que quando a unit original em {{ic|/usr/lib/}} é alterada devido a uma atualização de pacotes, essas alterações não serão aplicadas automaticamente ao seu arquivo unit personalizado em {{ic|/etc/}}. Além disso, você vai ter que reativar manualmente a unit com {{ic|systemctl reenable ''unit''}}. Portanto, é recomendável usar o método ''*.conf'' descrito anteriormente. | Alternativamente, você pode copiar o antigo arquivo unit de {{ic|/usr/lib/systemd/system/}} para {{ic|/etc/systemd/system/}} e fazer suas modificações lá. Um arquivo unit em {{ic|/etc/systemd/system/}} sempre sobrepõe a mesma unit em {{ic|/usr/lib/systemd/system/}}. Note que quando a unit original em {{ic|/usr/lib/}} é alterada devido a uma atualização de pacotes, essas alterações não serão aplicadas automaticamente ao seu arquivo unit personalizado em {{ic|/etc/}}. Além disso, você vai ter que reativar manualmente a unit com {{ic|systemctl reenable ''unit''}}. Portanto, é recomendável usar o método ''*.conf'' descrito anteriormente. | ||
− | {{ | + | {{Dica |Você pode usar '''systemd-delta''' para ver quais arquivos units foram sobrescritos e o que exatamente foi alterado.}} |
− | Como os arquivos units referidos serão atualizados | + | Como os arquivos units referidos serão atualizados ao longo do tempo, use ''systemd-delta'' para a manutenção do sistema. |
− | === Realce de sintaxe para units dentro Vim === | + | === Realce de sintaxe para units dentro do Vim === |
Realce de sintaxe para arquivos unit ''systemd'' dentro do [[Vim]] pode ser habilitado através da instalação do {{Pkg|vim-systemd}} dos [[Official Repositories|repositórios oficiais]]. | Realce de sintaxe para arquivos unit ''systemd'' dentro do [[Vim]] pode ser habilitado através da instalação do {{Pkg|vim-systemd}} dos [[Official Repositories|repositórios oficiais]]. | ||
Line 336: | Line 304: | ||
=== Obter targets atuais === | === Obter targets atuais === | ||
− | O comando deve ser no ''systemd'' em vez de | + | O comando deve ser no ''systemd'' em vez de executar {{ic|runlevel}}: |
$ systemctl list-units --type=target | $ systemctl list-units --type=target | ||
Line 342: | Line 310: | ||
=== Criar target personalizada === | === Criar target personalizada === | ||
− | Os níveis de execução que são atribuídas uma finalidade específica na instalação vanilla Fedora; 0, 1, 3, 5, e 6; tem um 1:1 | + | Os níveis de execução que são atribuídas uma finalidade específica na instalação vanilla Fedora; 0, 1, 3, 5, e 6; tem um mapeamento 1:1 com uma específica ''target'' ''systemd''. Infelizmente, não há nenhuma boa forma de fazer o mesmo com os níveis de execução definidos pelo usuário, como 2 e 4. Se você fizer uso deles é sugerido que você faça uma nova nomeação ''target'' ''systemd'' como {{ic|/etc/systemd/system/''your target''}} que tem um dos níveis de execução existentes como base (você pode examinar {{ic|/usr/lib/systemd/system/graphical.target}} como um exemplo), crie um diretório {{ic|/etc/systemd/system/''your target''.wants}}, e então symlink o adicional serviço de {{ic|/usr/lib/systemd/system/}} que você deseja ativar. |
=== Tabela de targets === | === Tabela de targets === | ||
Line 367: | Line 335: | ||
=== Alterar target atual === | === Alterar target atual === | ||
− | + | No ''systemd'' targets estão expostas via ''target units''. Você pode alterá-las assim: | |
# systemctl isolate graphical.target | # systemctl isolate graphical.target | ||
Line 375: | Line 343: | ||
=== Alterar target padrão para inicializar === | === Alterar target padrão para inicializar === | ||
− | A target padrão é ''default.target'', que tem alias por padrão para ''graphical.target'' (que corresponde ao antigo nível de execução 5).Para alterar o destino padrão na hora da inicialização, adicione um dos seguintes [[kernel parameters]] para seu | + | A target padrão é ''default.target'', que tem alias por padrão para ''graphical.target'' (que corresponde ao antigo nível de execução 5).Para alterar o destino padrão na hora da inicialização, adicione um dos seguintes [[kernel parameters|parâmetros kernel]] para o seu gerenciador de boot: |
− | {{ | + | {{Dica |A extensão ''.target'' pode ser deixada de fora.}} |
* {{ic|1=systemd.unit=multi-user.target}} (que corresponde ao antigo nível de execução 3), | * {{ic|1=systemd.unit=multi-user.target}} (que corresponde ao antigo nível de execução 3), | ||
Line 395: | Line 363: | ||
== Journal == | == Journal == | ||
− | ''systemd'' tem o seu próprio sistema de registro chamado de o journal e, portanto, a execução de | + | ''systemd'' tem o seu próprio sistema de registro chamado de o journal e, portanto, a execução de uma daemon syslog não é mais necessário. Para ler o registro, utilize: |
# journalctl | # journalctl | ||
− | Por padrão (quando {{ic|1=Storage=}} é definido para {{ic|auto}} em {{ic|/etc/systemd/journald.conf}}), o journal escreve para {{ic|/var/log/journal/}}. O diretório {{ic|/var/log/journal/}} faz parte do pacote ''systemd''. Se você ou algum programa | + | Por padrão (quando {{ic|1=Storage=}} é definido para {{ic|auto}} em {{ic|/etc/systemd/journald.conf}}), o journal escreve para {{ic|/var/log/journal/}}. O diretório {{ic|/var/log/journal/}} faz parte do pacote ''systemd''. Se você ou algum programa excluir esse diretório, systemd '''não''' irá recriá-lo automaticamente; no entanto, ele será recriado durante a próxima atualização do pacote systemd. Até então, os registros serão gravados em {{ic|/run/systemd/journal}}, e os registros se perderão na reinicialização. |
− | {{ | + | {{Dica |Se {{ic|/var/log/journal/}} reside em um sistema de arquivo [[btrfs]] você deve considerar a desativação [[Btrfs#Copy-On-Write_.28CoW.29|Copy-on-Write]] do diretório: |
# chattr +C /var/log/journal | # chattr +C /var/log/journal | ||
}} | }} | ||
Line 421: | Line 389: | ||
# journalctl --since=today | tac | sed -n '/-- Reboot --/{n;:r;/-- Reboot --/q;p;n;b r}' | tac | # journalctl --since=today | tac | sed -n '/-- Reboot --/{n;:r;/-- Reboot --/q;p;n;b r}' | tac | ||
− | desde que a inicialização anterior aconteceu hoje. Esteja ciente que, se houver muitas mensagens para o dia atual, a saída deste comando pode ser atrasada por | + | desde que a inicialização anterior aconteceu hoje. Esteja ciente que, se houver muitas mensagens para o dia atual, a saída deste comando pode ser atrasada por um tempo. |
− | {{ | + | {{Nota |Isso precisa ser corrigido uma vez que 206 regiões. {{ic|journalctl -b}} agora assume argumentos como {{ic|-0}} para a última inicialização ou uma ID de inicialização. Ex. {{ic|journalctl -b -3}} vai mostrar todas as mensagens da quarta para a última inicialização.}} |
Acompanhe as novas mensagens: | Acompanhe as novas mensagens: | ||
Line 428: | Line 396: | ||
# journalctl -f | # journalctl -f | ||
− | + | Mostra todas as mensagens por um executável específico: | |
# journalctl /usr/lib/systemd/systemd | # journalctl /usr/lib/systemd/systemd | ||
− | + | Mostra todas as mensagens através de um processo específico: | |
# journalctl _PID=1 | # journalctl _PID=1 | ||
− | + | Mostra todas as mensagens de uma unit específica: | |
# journalctl -u netcfg | # journalctl -u netcfg | ||
− | Consulte {{ic|man 1 journalctl}}, {{ic|man 7 systemd.journal-fields}}, ou | + | Consulte {{ic|man 1 journalctl}}, {{ic|man 7 systemd.journal-fields}}, ou [http://0pointer.de/blog/projects/journalctl.html mensagem do blog] de Lennert para detalhes. |
=== Tamanho limite do Journal === | === Tamanho limite do Journal === | ||
Line 452: | Line 420: | ||
=== Journald em conjunto com o syslog === | === Journald em conjunto com o syslog === | ||
− | Compatibilidade com implementações syslog clássico é fornecida através | + | Compatibilidade com implementações do syslog clássico é fornecida através da socket {{ic|/run/systemd/journal/syslog}}, para o qual todas as mensagens são encaminhadas. Para fazer funcionar a daemon syslog com o journal, tem de vincular a este socket em vez de {{ic|/dev/log}} ([http://lwn.net/Articles/474968/ official announcement]). O pacote {{Pkg|syslog-ng}} nos repositórios fornece automaticamente a configuração necessária. |
# systemctl enable syslog-ng | # systemctl enable syslog-ng | ||
Um bom tutorial ''journalctl'' está [http://0pointer.de/blog/projects/journalctl.html aqui]. | Um bom tutorial ''journalctl'' está [http://0pointer.de/blog/projects/journalctl.html aqui]. | ||
+ | |||
+ | == Migração do SysVinit/initscripts == | ||
+ | {{Deletion|Arch's initscripts has been officially unsupported since 2012-11-04[https://www.archlinux.org/news/end-of-initscripts-support/].}} | ||
+ | {{Nota| | ||
+ | * {{Pkg|systemd}} e {{Pkg|systemd-sysvcompat}} estão instalados por padrão na mídia de instalação mais recente [https://www.archlinux.org/news/systemd-is-now-the-default-on-new-installations/ 2012-10-13]. Esta seção é destinada a instalações do Arch Linux, que ainda dependem de ''sysvinit'' e ''initscripts''. | ||
+ | * Se você estiver executando Arch Linux dentro de um VPS, consulte [[Virtual Private Server#Moving your VPS from initscripts to systemd]]. | ||
+ | }} | ||
+ | |||
+ | === Considerações antes de mudar === | ||
+ | |||
+ | * Faça [http://freedesktop.org/wiki/Software/systemd/ algumas leituras] sobre ''systemd''. | ||
+ | * Note que systemd tem um sistema ''journal'' que substitue ''syslog'', embora os dois podem coexistir. Consulte [[#Journal]]. | ||
+ | * Embora o ''systemd'' possa subtituir algumas das funcionabilidades do ''cron'', ''acpid'', ou ''xinetd'', não há necessidade de deixar de usar as daemons tradicionais, a menos que você queira. | ||
+ | * Interativo ''initscripts'' não está trabalhando com ''systemd''. Em particular, ''netcfg-menu'' não pode ser usado no sistema de inicialização ({{Bug|31377}}). | ||
+ | |||
+ | === Procedimento de instalação === | ||
+ | |||
+ | # [[pacman|Instalar]] {{Pkg|systemd}} dos [[official repositories|repositórios oficiais]]. | ||
+ | # Acrescente ao seu [[kernel parameters|parâmetros kernel ]]: {{ic|1=init=/usr/lib/systemd/systemd}}. | ||
+ | # Uma vez concluído, você pode habilitar todos os serviços desejados, através do uso {{ic|systemctl enable ''service_name''}} (equivalente a inclusão na array {{ic|DAEMONS}}. Novos nomes podem ser encontrados em [[Daemons List|Lista de Daemons]]). | ||
+ | # Reinicie seu sistema e verifique se ''systemd'' está atualmente ativo emitindo o seguinte comando: {{ic|cat /proc/1/comm}}. Isso deve retornar a string {{ic|systemd}}. | ||
+ | # Verifique se o seu hostname está configurado corretamente com ''systemd'': {{ic|hostnamectl set-hostname ''myhostname''}} ou {{ic|/etc/hostname}}. | ||
+ | # Proceda para remover ''initscripts'' e ''sysvinit'' de seu sistema e instale {{Pkg|systemd-sysvcompat}}. | ||
+ | # Opcionalmente, remova o parâmetro {{ic|1=init=/usr/lib/systemd/systemd}}. Não é mais necessário desde que {{Pkg|systemd-sysvcompat}} fornece um symlink para ''systemd''. | ||
+ | |||
+ | === Informações complementares === | ||
+ | |||
+ | * Se você tem {{ic|quiet}} em seu parâmetro kernel, talvez queira removê-lo nos seus primeiros boots com systemd para auxiliar na identificação de eventuais problemas durante a inicialização. | ||
+ | |||
+ | * Não é necessário adicionar o usuário aos [[Groups|grupos]] ({{ic|sys}}, {{ic|disk}}, {{ic|lp}}, {{ic|network}}, {{ic|video}}, {{ic|audio}}, {{ic|optical}}, {{ic|storage}}, {{ic|scanner}}, {{ic|power}}, etc.) para a maioria dos casos de uso com systemd. Os grupos podem até causar algumas quebras de funcionalidades. Por exemplo, o grupo {{ic|audio}} vai quebrar a troca rápida de usuário e permite que os aplicativos bloqueiem programas. Cada registro PAM fornece uma sessão de logind, no qual para uma sessão local lhe dará permissões via [[Wikipedia:Access control list|POSIX ACLs]] em dispositivos audio/video, e permite certas operações como montagem de armazenamento removível via [[udisks]]. | ||
+ | |||
+ | * Veja o artigo [[Network Configuration|Configuração de Rede]] para saber como configurar targets de rede. | ||
== Solução de problemas == | == Solução de problemas == | ||
Line 462: | Line 462: | ||
=== Desligar/reiniciar demora um longo tempo=== | === Desligar/reiniciar demora um longo tempo=== | ||
− | Se o processo de encerramento tem um tempo muito longo (ou parece congelar) mais provavelmente um serviço que não encerra é o responsável. ''Systemd'' espera um tempo para cada serviço | + | Se o processo de encerramento tem um tempo muito longo (ou parece congelar) mais provavelmente um serviço que não encerra é o responsável. ''Systemd'' espera um tempo para cada serviço terminar antes de tentar matá-lo. Para descobrir se você foi afetado, consulte [http://freedesktop.org/wiki/Software/systemd/Debugging#Shutdown_Completes_Eventually this article]. |
=== Processos de curta duração não parecem registrar qualquer saída === | === Processos de curta duração não parecem registrar qualquer saída === | ||
Line 486: | Line 486: | ||
# /usr/lib/systemd/systemd-sysctl | # /usr/lib/systemd/systemd-sysctl | ||
− | Como antes, você também precisa "unlimit" | + | Como antes, você também precisa o tamanho "unlimit" dos arquivos de núcleo no shell: |
$ ulimit -c unlimited | $ ulimit -c unlimited | ||
− | Consulte [http://www.freedesktop.org/software/systemd/man/sysctl.d.html sysctl.d] e [https://www.kernel.org/doc/Documentation/sysctl/kernel.txt | + | Consulte [http://www.freedesktop.org/software/systemd/man/sysctl.d.html sysctl.d] e [https://www.kernel.org/doc/Documentation/sysctl/kernel.txt a documentação para /proc/sys/kernel] para mais informações. |
== Consulte também == | == Consulte também == |
Revision as of 22:27, 30 November 2013
zh-CN:Systemd zh-TW:Systemd Template:Article summary start Template:Article summary text Template:Article summary heading Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary end De project web page:
- Systemd é um sistema e gerenciador de serviços para Linux, compatível com os scripts de inicializações SysV e LS. Systemd fornece recursos de paralelização agressivos, usa socket e ativação D-Bus para iniciar serviços, oferece o início de daemons on-demand, mantém o registro de processos usando grupos de controle Linux, suporte snapshotting e restauração do estado do sistema, preserva pontos de montagens e automontagens e implementa uma lógica de controle elaborado transacional baseada em dependência de serviço.
Contents
Uso básico systemctl
O principal comando usado para introspecção e controle systemd é systemctl. Alguns de seus usos são examinando o estado do sistema e gerenciando o sistema e serviços. Consulte man 1 systemctl
para mais detalhes.
-H user@host
que muda para controlar uma instância systemd em uma máquina remota. Isso usará SSH para conectar-se uma instância remota systemd.Analisando o estado do sistema
Lista units executadas:
$ systemctl
ou:
$ systemctl list-units
Lista units que falharam::
$ systemctl --failed
Os arquivos units disponíveis podem ser vistos em /usr/lib/systemd/system/
e /etc/systemd/system/
(este último tem precedência). Você pode ver uma lista dos arquivos units instalados com:
$ systemctl list-unit-files
Usando units
As units podem ser, por exemplo, serviços (.service), pontos de montagem (.mount), dispositivos (.device) ou sockets (.socket).
Quando usa systemctl, você geralmente tem que especificar o nome completo do arquivo unit, incluindo o sufixo, por exemplo sshd.socket. No entanto, existem algumas formas curtas de especificar a unit nos seguintes comandos systemctl:
- Se você não especificar o sufixo, systemctl assumirá .service. Por exemplo,
netcfg
enetcfg.service
são equivalentes. - Os pontos de montagem serão automaticamente convertidos para a unit .mount adequada. Por exemplo, especificando
/home
equivale ahome.mount
. - Similar aos pontos de montagem, dispositivos são automaticamente convertido para a unit .device adequada, portanto, especificando
/dev/sda2
equivale adev-sda2.device
.
Consulte man systemd.unit
para detalhes.
Ativa uma unit imediatamente:
# systemctl start unit
Desativa uma unit imediatamente:
# systemctl stop unit
Reinicia uma unit:
# systemctl restart unit
Peça uma unit para recarregar sua configuração:
# systemctl reload unit
Mostra o estado de uma unit, inclusive se estiver em execução ou não:
$ systemctl status unit
Verifica se a unit já está habilitada ou não:
$ systemctl is-enabled unit
Habilita uma unit para ser iniciada na inicialização:
# systemctl enable unit
[Install]
são geralmente chamados por outros serviços automaticamente. Se você precisa instalá-los manualmente, use o seguinte comando, substituindo foo com o nome do serviço.
# ln -s /usr/lib/systemd/system/foo.service /etc/systemd/system/graphical.target.wants/
Desativa uma unit para não iniciar durante a inicialização:
# systemctl disable unit
Mostra a página de manual associado a uma unit (tem que ser suportado pelo arquivo da unit):
$ systemctl help unit
Recarrega o systemd, scaneando por units novas e modificadas:
# systemctl daemon-reload
O gerenciamento de energia
polkit é necessário para o gerenciamento de energia. Se você está numa sessão de usuário local systemd-logind e nenhuma outra sessão está ativa, os seguintes comandos funcionarão sem privilégios root. Se não (por exemplo, porque outro usuário está conectado em um tty), systemd irá automaticamente pedir a senha de root.
Desliga e reinicia o sistema:
$ systemctl reboot
Desliga e encerra o sistema:
$ systemctl poweroff
Suspende o sistema:
$ systemctl suspend
Coloca o sistema em modo de hibernação:
$ systemctl hibernate
Coloca o sistema em modo de suspensão :
$ systemctl hybrid-sleep
Executando Gerenciadores de Display no systemd
Para habilitar a autenticação gráfica, execute o seu daemon de Display Manager preferido (ex. KDM). No momento, existem arquivos de serviço para GDM, KDM, SLiM, XDM, LXDM, LightDM, e SDDMAUR.
# systemctl enable kdm
Isso deve funcionar. Se não, você pode ter que definir o default.target manualmente ou de uma velha instalação:
# ls -l /etc/systemd/system/default.target
/etc/systemd/system/default.target -> /usr/lib/systemd/system/graphical.target
Basta apagar o link simbólico e systemd usará seu default.target (ex. graphical.target).
# rm /etc/systemd/system/default.target
Usando systemd-logind
A fim de verificar o estado de sua sessão de usuário, você pode usar loginctl
. Todas ações PolicyKit como suspender o sistema ou montar unidades externas irão funcionar.
$ loginctl show-session $XDG_SESSION_ID
Configuração nativa
644
e propriedade root:root
.Console virtual
O console virtual (mapeamento de teclado, fonte do console e mapa do console) é configurado em /etc/vconsole.conf
ou utilizando a ferramenta localectl.
Para mais informação, consulte fontes do console e keymaps.
Relógio do hardware
systemd usará UTC para o relógio do hardware por padrão.
Relógio do hardware em localtime
Se quiser alterar o relógio de hardware para usar horário local (não recomendado), faça:
# timedatectl set-local-rtc true
Se quiser reverter para o relógio do hardware estando em UTC, faça:
# timedatectl set-local-rtc false
Fique avisado que, se o relógio do hardware está definido para localtime, lidar com o horário de verão é uma confusão(há muito mais do que isso).
Uma razão para permitir que o RTC esteja em hora local é permitir dual boot com o Windows (que usa localtime). No entanto, o Windows é capaz de lidar com a RTC iniciando em UTC, com um simples correção de registro.
Para mais informação, consulte Time.
Módulos do kernel
Consulte Kernel modules#Configuration.
Montagens de sistemas de arquivos
A configuração padrão será automaticamente fsck e montará sistemas de arquivos antes de iniciar os serviços que eles precisam para serem montados. Por exemplo, systemd automaticamente garante que montagens de sistemas de arquivos remotos como NFS ou Samba são somente iniciados depois que a rede for configurada. Portanto, montagens de sistema de arquivos local e remoto especificadas em /etc/fstab
} devem funcionar.
Consulte man 5 systemd.mount
por detalhes.
Automontagem
Se você tem uma partição /home
grande, talvez seja melhor permitir serviços que não dependem da /home
para iniciar enquanto /home
é verificada pelo fsck. Isto pode ser feito adicionando as seguintes opções em /etc/fstab
na entrada de sua partição /home
:
noauto,x-systemd.automount
Isso irá fsck e montar /home
ao acessada pela primeira vez, e o kernel irá reter todos os acessos de arquivo para /home
até que esteja pronto.
/home
tipo autofs
, seja ignorado pelo mlocate por padrão. A aceleração de automontagem /home
pode não ser mais do que um ou dois segundos, dependendo do seu sistema, de modo que este truque possa não valer a pena.O mesmo se aplica para montagens de sistemas de arquivos remotos. Se você quer que eles sejam montados apenas no acesso, você vai precisar usar o parâmetro noauto,x-systemd.automount
. Além disso, você pode usar a opção x-systemd.device-timeout=#
para especificar um limite no caso do recurso de rede não está disponível.
Se você tem sistemas de arquivos criptografados com arquivo chaves, também pode adicionar o parâmetro noauto
para as entradas correspondentes em /etc/crypttab
. Então systemd não vai abrir o dispositivo criptografado no boot, mas espera até que ele seja realmente acessado e então automaticamente o abre com o arquivo chave especificado antes de montá-lo. Isso pode economizar alguns segundos na inicialização, se você estiver usando um dispositivo RAID criptografado por exemplo, porque o systemd não tem que esperar para o dispositivo se tornar disponível. Por exemplo:
/etc/crypttab
data /dev/md0 /root/key noauto
LVM
Se você não tiver volumes LVM ativados via o initramfs, habilite o serviço lvm-monitoring, que é fornecido pelo pacote lvm2.
Gerenciamento de energia ACPI
Consulte Power Management.
Arquivos temporários
systemd-tmpfiles usa arquivos de configuração em /usr/lib/tmpfiles.d/
e /etc/tmpfiles.d/
para descrever a criação, limpeza e remoção de arquivos e diretórios voláteis e temporários que normalmente residem em diretórios como /run
ou /tmp
.
Cada arquivo de configuração é chamado no estilo /etc/tmpfiles.d/program.conf
. Isso também irá substituir todos os arquivos em /usr/lib/tmpfiles.d/
com o mesmo nome.
tmpfiles normalmente são fornecidos em conjunto com arquivos de serviços para criar diretórios que deverão existir por certas daemons. Por exemplo a daemon Samba espera que o diretório /run/samba
exista e tenha as permissões corretas. Assim, o pacote samba vem com esta configuração:
/usr/lib/tmpfiles.d/samba.conf
D /run/samba 0755 root root
tmpfiles também pode ser usado para escrever os valores em determinados arquivos na inicialização. Por exemplo, se você usa /etc/rc.local
para desativar ativação de dispositivos USB com echo USBE > /proc/acpi/wakeup
, você pode usar o seguinte tmpfile:
/etc/tmpfiles.d/disable-usb-wake.conf
w /proc/acpi/wakeup - - - - USBE
Consulte man 5 tmpfiles.d
para detalhes.
/sys
uma vez que o serviço systemd-tmpfiles-setup pode ser executado antes dos módulos de dispositivo apropriado for carregado. Neste caso, você pode verificar se o módulo tem um parâmetro para a opção que pretende definir com modinfo module
e ajustar essa opção com um arquivo de configuração em /etc/modprobe.d. Caso contrário, você terá que escrever uma regra udev para ajustar o atributo adequado logo que o dispositivo aparecer.Escrevendo arquivos .service personalizados
A sintaxe do systemd arquivos unit é inspirado pela Especificações de Entrada dos arquivos .desktop XDG Desktop, que são, por sua vez inspirado pelo .ini Microsoft Windows.
Consulte systemd/Services para mais exemplos.
Manuseando dependências
Com systemd, dependências podem ser resolvidas através da concepção de arquivos unit corretamente. O caso mais típico é a unit A requerer a unit B para ser executada antes da A ser iniciada. Nesse caso, adicione Requires=B
e After=B
para a seção [Unit]
de A. Se a dependência for opcional, então adicione Wants=B
e After=B
. Nota que Wants=
e Requires=
não implicam After=
, significando que se After=
não for especificado, as duas units serão iniciada em paralelo.
Dependências são normalmente colocadas em serviços e não em targets. Por exemplo, o network.target é puxado por qualquer serviço que configure as interfaces de rede, portanto, ordenando a sua unit personalizada depois disso é o bastante desde que network.target é iniciado de qualquer maneira.
Tipo
Há vários tipos diferentes de arranque a considerar quando se escreve um arquivo de serviço personalizado. Isso é definido com o parâmetro Type=
na seção [Service]
. Consulte man systemd.service
para uma explicação mais detalhada.
-
Type=simple
(padrão): systemd considera que o serviço seja iniciado imediatamente. O processo não tem fork. Não use este tipo se outros serviços carecem ser solicitados neste serviço, a menos que seja socket ativado. -
Type=forking
: systemd considera que o serviço iniciou uma vez que os processos forks e o pai sairam. Para daemons clássicos use este tipo, a menos que você saiba que ele não é necessário. Deve especificarPIDFile=
tão bem como systemd possa acompanhar o processo principal. -
Type=oneshot
: este é útil para os scripts que fazem um trabalho único e, em seguida, saem. Você pode querer definirRemainAfterExit=yes
também para que systemd ainda considere o serviço como ativo depois que o processo foi encerrado. -
Type=notify
: idêntico aoType=simple
, mas com a condição de que o servidor irá enviar um sinal para systemd quando estiver pronto. A implementação de referência para essa notificação é fornecido pelo libsystemd-daemon.so. -
Type=dbus
: o serviço é considerado pronto quando o especificadoBusName
aparece no barramento do sistema do DBus.
Edição de arquivos units referidos
Para editar um arquivo unit fornecido por um pacote, você pode criar um diretório chamado /etc/systemd/system/unit.d/
por exemplo /etc/systemd/system/httpd.service.d/
e coloque os arquivos *.conf lá para substituir ou adicionar novas opções. Systemd irá analisar esses arquivos *.conf e aplicá-los no topo da unit original. Por exemplo, se você simplesmente quiser adicionar uma dependência adicional para a unit, você pode criar o seguinte arquivo:
/etc/systemd/system/unit.d/customdependency.conf
[Unit] Requires=new dependency After=new dependency
Em seguida, execute os comandos para que as alterações tenham efeito:
# systemctl daemon-reload # systemctl restart unit
Alternativamente, você pode copiar o antigo arquivo unit de /usr/lib/systemd/system/
para /etc/systemd/system/
e fazer suas modificações lá. Um arquivo unit em /etc/systemd/system/
sempre sobrepõe a mesma unit em /usr/lib/systemd/system/
. Note que quando a unit original em /usr/lib/
é alterada devido a uma atualização de pacotes, essas alterações não serão aplicadas automaticamente ao seu arquivo unit personalizado em /etc/
. Além disso, você vai ter que reativar manualmente a unit com systemctl reenable unit
. Portanto, é recomendável usar o método *.conf descrito anteriormente.
Como os arquivos units referidos serão atualizados ao longo do tempo, use systemd-delta para a manutenção do sistema.
Realce de sintaxe para units dentro do Vim
Realce de sintaxe para arquivos unit systemd dentro do Vim pode ser habilitado através da instalação do vim-systemd dos repositórios oficiais.
Targets
Systemd usa targets que servem a um propósito semelhante, como níveis de execução, mas agem um pouco diferente. Cada target é nomeada em vez de numerada e destina-se a servir uma finalidade específica com a possibilidade de ter múltiplos ativos ao mesmo tempo. Algumas targets são implementadas por herdar todos os serviços da outra target e adicionando serviços adicionais a ela. Há targets systemd que imitam os níveis de execução SystemVinit comuns para que possa mudar targets usando o comando familiar telinit RUNLEVEL
.
Obter targets atuais
O comando deve ser no systemd em vez de executar runlevel
:
$ systemctl list-units --type=target
Criar target personalizada
Os níveis de execução que são atribuídas uma finalidade específica na instalação vanilla Fedora; 0, 1, 3, 5, e 6; tem um mapeamento 1:1 com uma específica target systemd. Infelizmente, não há nenhuma boa forma de fazer o mesmo com os níveis de execução definidos pelo usuário, como 2 e 4. Se você fizer uso deles é sugerido que você faça uma nova nomeação target systemd como /etc/systemd/system/your target
que tem um dos níveis de execução existentes como base (você pode examinar /usr/lib/systemd/system/graphical.target
como um exemplo), crie um diretório /etc/systemd/system/your target.wants
, e então symlink o adicional serviço de /usr/lib/systemd/system/
que você deseja ativar.
Tabela de targets
Modo de execução SysV | systemd Target | Notas |
---|---|---|
0 | runlevel0.target, poweroff.target | Interrrompe o sistema. |
1, s, único | runlevel1.target, rescue.target | Modo de usuário único. |
2, 4 | runlevel2.target, runlevel4.target, multi-user.target | Níveis de execução User-defined/Site-specific. Por padrão, idêntico ao 3. |
3 | runlevel3.target, multi-user.target | Multi-usuário, não-gráfico. Os usuários geralmente podem acessar através de múltiplos consoles ou via rede. |
5 | runlevel5.target, graphical.target | Multi-usuário, gráfico. Normalmente tem todos os serviços do nível de execução 3, mais um login gráfico. |
6 | runlevel6.target, reboot.target | Reiniciar |
emergência | emergency.target | Shell de emergência |
Alterar target atual
No systemd targets estão expostas via target units. Você pode alterá-las assim:
# systemctl isolate graphical.target
Isso só vai mudar a target atual, e não tem nenhum efeito na próxima inicialização. É equivalente aos comandos como telinit 3
ou telinit 5
no Sysvinit.
Alterar target padrão para inicializar
A target padrão é default.target, que tem alias por padrão para graphical.target (que corresponde ao antigo nível de execução 5).Para alterar o destino padrão na hora da inicialização, adicione um dos seguintes parâmetros kernel para o seu gerenciador de boot:
-
systemd.unit=multi-user.target
(que corresponde ao antigo nível de execução 3), -
systemd.unit=rescue.target
(que corresponde ao antigo nível de execução 1).
Alternativamente, você pode deixar o gerenciador de boot sozinho e alterar default.target. Pode ser feito usando o systemctl:
# systemctl enable multi-user.target
O efeito desse comando é emitido pelo systemctl; um symlink para a nova target padrão é feita em /etc/systemd/system/default.target
. Isso funciona se, e somente se:
[Install] Alias=default.target
está no arquivo de configuração da target. Atualmente, multi-user.target e graphical.target ambos têm isso.
Journal
systemd tem o seu próprio sistema de registro chamado de o journal e, portanto, a execução de uma daemon syslog não é mais necessário. Para ler o registro, utilize:
# journalctl
Por padrão (quando Storage=
é definido para auto
em /etc/systemd/journald.conf
), o journal escreve para /var/log/journal/
. O diretório /var/log/journal/
faz parte do pacote systemd. Se você ou algum programa excluir esse diretório, systemd não irá recriá-lo automaticamente; no entanto, ele será recriado durante a próxima atualização do pacote systemd. Até então, os registros serão gravados em /run/systemd/journal
, e os registros se perderão na reinicialização.
/var/log/journal/
reside em um sistema de arquivo btrfs você deve considerar a desativação Copy-on-Write do diretório:
# chattr +C /var/log/journal
Filtrando saída
journalctl permite filtrar a saída por campos específicos.
Exemplos:
Mostra todas as mensagens desta inicialização:
# journalctl -b
No entanto, muitas vezes alguém está interessado em mensagens não do atual, mas do boot anterior (por exemplo, se uma falha irrecuperável do sistema aconteceu). Atualmente, este recurso não está implementado, embora foi uma discussão em systemd-devel@lists.freedesktop.org (Setembro/Outubro 2012).
Como alternativa você pode usar no momento:
# journalctl --since=today | tac | sed -n '/-- Reboot --/{n;:r;/-- Reboot --/q;p;n;b r}' | tac
desde que a inicialização anterior aconteceu hoje. Esteja ciente que, se houver muitas mensagens para o dia atual, a saída deste comando pode ser atrasada por um tempo.
journalctl -b
agora assume argumentos como -0
para a última inicialização ou uma ID de inicialização. Ex. journalctl -b -3
vai mostrar todas as mensagens da quarta para a última inicialização.Acompanhe as novas mensagens:
# journalctl -f
Mostra todas as mensagens por um executável específico:
# journalctl /usr/lib/systemd/systemd
Mostra todas as mensagens através de um processo específico:
# journalctl _PID=1
Mostra todas as mensagens de uma unit específica:
# journalctl -u netcfg
Consulte man 1 journalctl
, man 7 systemd.journal-fields
, ou mensagem do blog de Lennert para detalhes.
Tamanho limite do Journal
Se o journal é persistente (não volátil), seu tamanho limite é definido para um valor padrão de 10% do tamanho do respectivo sistema de arquivos. Por exemplo, com o /var/log/journal
localizado em uma partição root de 50 GiB isso levaria a 5 GiB de dados do journal. O tamanho máximo do journal persistente pode ser controlado pelo SystemMaxUse
em /etc/systemd/journald.conf
, então para limitá-lo, por exemplo, a 50 MiB descomente e edite a linha correspondente a:
SystemMaxUse=50M
Consulte man journald.conf
para mais informações.
Journald em conjunto com o syslog
Compatibilidade com implementações do syslog clássico é fornecida através da socket /run/systemd/journal/syslog
, para o qual todas as mensagens são encaminhadas. Para fazer funcionar a daemon syslog com o journal, tem de vincular a este socket em vez de /dev/log
(official announcement). O pacote syslog-ng nos repositórios fornece automaticamente a configuração necessária.
# systemctl enable syslog-ng
Um bom tutorial journalctl está aqui.
Migração do SysVinit/initscripts
- systemd e systemd-sysvcompat estão instalados por padrão na mídia de instalação mais recente 2012-10-13. Esta seção é destinada a instalações do Arch Linux, que ainda dependem de sysvinit e initscripts.
- Se você estiver executando Arch Linux dentro de um VPS, consulte Virtual Private Server#Moving your VPS from initscripts to systemd.
Considerações antes de mudar
- Faça algumas leituras sobre systemd.
- Note que systemd tem um sistema journal que substitue syslog, embora os dois podem coexistir. Consulte #Journal.
- Embora o systemd possa subtituir algumas das funcionabilidades do cron, acpid, ou xinetd, não há necessidade de deixar de usar as daemons tradicionais, a menos que você queira.
- Interativo initscripts não está trabalhando com systemd. Em particular, netcfg-menu não pode ser usado no sistema de inicialização (FS#31377).
Procedimento de instalação
- Instalar systemd dos repositórios oficiais.
- Acrescente ao seu parâmetros kernel :
init=/usr/lib/systemd/systemd
. - Uma vez concluído, você pode habilitar todos os serviços desejados, através do uso
systemctl enable service_name
(equivalente a inclusão na arrayDAEMONS
. Novos nomes podem ser encontrados em Lista de Daemons). - Reinicie seu sistema e verifique se systemd está atualmente ativo emitindo o seguinte comando:
cat /proc/1/comm
. Isso deve retornar a stringsystemd
. - Verifique se o seu hostname está configurado corretamente com systemd:
hostnamectl set-hostname myhostname
ou/etc/hostname
. - Proceda para remover initscripts e sysvinit de seu sistema e instale systemd-sysvcompat.
- Opcionalmente, remova o parâmetro
init=/usr/lib/systemd/systemd
. Não é mais necessário desde que systemd-sysvcompat fornece um symlink para systemd.
Informações complementares
- Se você tem
quiet
em seu parâmetro kernel, talvez queira removê-lo nos seus primeiros boots com systemd para auxiliar na identificação de eventuais problemas durante a inicialização.
- Não é necessário adicionar o usuário aos grupos (
sys
,disk
,lp
,network
,video
,audio
,optical
,storage
,scanner
,power
, etc.) para a maioria dos casos de uso com systemd. Os grupos podem até causar algumas quebras de funcionalidades. Por exemplo, o grupoaudio
vai quebrar a troca rápida de usuário e permite que os aplicativos bloqueiem programas. Cada registro PAM fornece uma sessão de logind, no qual para uma sessão local lhe dará permissões via POSIX ACLs em dispositivos audio/video, e permite certas operações como montagem de armazenamento removível via udisks.
- Veja o artigo Configuração de Rede para saber como configurar targets de rede.
Solução de problemas
Desligar/reiniciar demora um longo tempo
Se o processo de encerramento tem um tempo muito longo (ou parece congelar) mais provavelmente um serviço que não encerra é o responsável. Systemd espera um tempo para cada serviço terminar antes de tentar matá-lo. Para descobrir se você foi afetado, consulte this article.
Processos de curta duração não parecem registrar qualquer saída
Se journalctl -u foounit
não mostra nenhuma saída para um serviço de curta duração, veja o PID em vez disso. Por exemplo, se systemd-modules-load.service
falha, e systemctl status systemd-modules-load
mostra que executou com PID 123, então você talvez possa ver uma saída no journal por esse PID, ou seja, journalctl -b _PID=123
. Campos de metadados para o journal como _SYSTEMD_UNIT e _COMM são coletados de forma assíncrona e invocam o diretório /proc
para o processo existente. A solução deste problema requer fixar o kernel para fornecer esses dados através de uma conexão de socket, semelhante ao SCM_CREDENTIALS.
Diagnosticar problemas de inicialização
Inicialização desses parâmetros na linha de comando do kernel:
systemd.log_level=debug systemd.log_target=kmsg log_buf_len=1M
Desativando despejos de memória de aplicativos journaling
Para voltar os arquivos normais de despejo de memória, edite o seguinte arquivo de forma que sobrescreva os ajustes de /lib/sysctl.d/
:
/etc/sysctl.d/49-coredump.conf
kernel.core_pattern = core kernel.core_uses_pid = 0
Então execute:
# /usr/lib/systemd/systemd-sysctl
Como antes, você também precisa o tamanho "unlimit" dos arquivos de núcleo no shell:
$ ulimit -c unlimited
Consulte sysctl.d e a documentação para /proc/sys/kernel para mais informações.
Consulte também
- Official web site
- Wikipedia article
- Manual pages
- systemd optimizations
- FAQ
- Tips and tricks
- systemd for Administrators (PDF)
- About systemd on Fedora Project
- How to debug systemd problems
- Two part introductory article in The H Open magazine.
- Lennart's blog story
- Status update
- Status update2
- Status update3
- Most recent summary
- Fedora's SysVinit to systemd cheatsheet