elogind-255.5
Introdução ao elogind
elogind é o "logind" do projeto
systemd, extraído para ser um
processo de segundo plano independente. Ele se integra com
Linux-PAM-1.6.1 para rastrear todos(as)
os(as) usuários(as) logados(as) em um sistema, e se eles(as) estão
logados(as) graficamente, no console ou remotamente. Elogind expõe essas informações por meio da
interface padrão org.freedesktop.login1 do D-Bus e também por meio do sistema de arquivos
usando o esquema padrão /run/systemd
do "systemd".
Esse pacote é conhecido por construir e funcionar corretamente
usando uma plataforma LFS 12.2.
Informação do Pacote
Dependências do elogind
Recomendadas
dbus-1.14.10 (tempo de execução), Linux-PAM-1.6.1 (exigido para Xorg),
Polkit-125 (tempo de execução), docbook-xml-4.5, docbook-xsl-nons-1.79.2 e libxslt-1.1.42 (todos os três para construir
as páginas de manual)
Opcionais
lxml-5.3.0, zsh-5.9, Valgrind-3.23.0
(necessário para testes), audit-userspace,
bash-completion,
kexec
e SELinux
Observações de Editor(a): https://wiki.linuxfromscratch.org/blfs/wiki/Logind
Configuração do
Núcleo
Habilite as seguintes opções na configuração do núcleo e recompile
o núcleo se necessário:
File systems --->
[*] Inotify support for userspace [INOTIFY_USER]
Pseudo filesystems --->
[*] Tmpfs virtual memory file system support (former shm fs) [TMPFS]
[*] Tmpfs POSIX Access Control Lists [TMPFS_POSIX_ACL]
Além disso, alguns testes precisam da "API" criptográfica do espaço
do(a) usuário(a) do núcleo, a qual é habilitada com:
-*- Cryptographic API ---> [CRYPTO]
Crypto core or helper --->
<*/M> Userspace cryptographic algorithm configuration [CRYPTO_USER]
Userspace interface --->
<*/M> Hash algorithms [CRYPTO_USER_API_HASH]
Instalação do elogind
Instale o elogind executando os
seguintes comandos:
mkdir build &&
cd build &&
meson setup .. \
--prefix=/usr \
--buildtype=release \
-D man=auto \
-D docdir=/usr/share/doc/elogind-255.5 \
-D cgroup-controller=elogind \
-D dev-kvm-mode=0660 \
-D dbuspolicydir=/etc/dbus-1/system.d &&
ninja
Para testar os resultados, emita: ninja test. Uns poucos testes são
ignorados se não executados com privilégios de root
. Três testes, test-login
, dbus-docs-fresh
e check-version-history
, são conhecidos por
falharem.
Agora, como o(a) usuário(a) root
:
ninja install &&
ln -sfv libelogind.pc /usr/lib/pkgconfig/libsystemd.pc &&
ln -sfvn elogind /usr/include/systemd
Explicações do Comando
-D
docdir=/usr/share/doc/elogind-255.5
: Isso é necessário
para instalar a documentação em um diretório versionado.
-D
cgroup-controller=elogind
: Essa chave é necessária para
construir esse pacote quando o núcleo não for compilado com
CONFIG_CGROUPS
habilitada. Observe que
elogind precisa estritamente de um
núcleo com CONFIG_CGROUPS
habilitada em
tempo de execução, mas essa chave permitirá construir o pacote
primeiro.
-D
dbuspolicydir=/etc/dbus-1/system.d
: Essa chave
configura o local do diretório de políticas do D-Bus.
-D dev-kvm-mode=0660
: A
regra udev do LFS configura o modo de /dev/kvm
como 0660. Essa opção garante que as
regras udev do elogind sejam consistentes com a configuração do
LFS.
-D man=auto
: O valor padrão
dessa chave é false.
Configurá-lo como auto
permite construir e instalar as páginas de manual se as
dependências recomendadas estiverem instaladas.
-D html=auto
: O valor padrão dessa
chave é false. Configurá-la
como auto permite construir
e instalar a documentação HTML se as dependências recomendadas
estiverem instaladas.
-D default-kill-user-processes=false
:
Determina se os processos de um(a) usuário(a) deveriam ser
eliminados quando o(a) usuário(a) sai. O padrão é true, mas isso anula o uso tradicional
de screen ou
tmux. Isso também
pode ser mudado no arquivo de configuração (veja-se abaixo).
ln -s ...: Esses
comandos instalam links simbólicos, de modo que aqueles pacotes de
software consigam encontrar a biblioteca e os cabeçalhos
compatíveis com o "systemd".
Configurando o elogind
Arquivo de
Configuração
/etc/elogind/logind.conf
Informação de Configuração
O arquivo instalado /etc/elogind/logind.conf
contém todas as opções
possíveis com os padrões delas comentados. Você possivelmente
quera desabilitar a eliminação automática de processos do(a)
usuário(a) quando o(a) usuário(a) sai, executando como o(a)
usuário(a) root
:
sed -e '/\[Login\]/a KillUserProcesses=no' \
-i /etc/elogind/logind.conf
Cada usuário precisará registrar uma sessão de usuário(a) usando
Linux-PAM no login. O arquivo
/etc/pam.d/system-session
precisa
ser modificado e um novo arquivo precisa ser criado para a
finalidade de que o elogind funcione corretamente.
Execute os seguintes comandos como o(a) usuário(a) root
:
cat >> /etc/pam.d/system-session << "EOF" &&
# Começo da adição de "elogind"
session required pam_loginuid.so
session optional pam_elogind.so
# Fim da adição de "elogind"
EOF
cat > /etc/pam.d/elogind-user << "EOF"
# Começo /etc/pam.d/elogind-user
account required pam_access.so
account include system-account
session required pam_env.so
session required pam_limits.so
session required pam_unix.so
session required pam_loginuid.so
session optional pam_keyinit.so force revoke
session optional pam_elogind.so
auth required pam_deny.so
password required pam_deny.so
# Fim /etc/pam.d/elogind-user
EOF
Nota
Depois da conclusão do elogind, você deveria verificar se ele
funciona corretamente. Primeiro, certifique-se de que
dbus esteja executando. Pode
ser mais fácil fazer isso reinicializando o sistema. Depois de
se logar novamente, execute o comando loginctl. O resultado deveria
indicar que uma SESSÃO e um SEAT foram criados.
Conteúdo
Aplicativos Instalados:
busctl, elogind-inhibit e loginctl
Biblioteca Instalada:
libelogind.so
Diretórios Instalados:
/usr/lib/elogind, /etc/elogind,
/usr/include/elogind e /usr/share/doc/elogind-255.5
Descrições Curtas
busctl
|
é usado para introspectar e monitorar o barramento do
"D-Bus"
|
elogind-inhibit
|
é usado para executar um aplicativo com bloqueio de
inibidor de desligamento, suspensão ou inatividade
|
loginctl
|
é usado para introspectar e controlar o estado do
Gerenciador de Login do "elogind"
|
libelogind.so
|
é a principal biblioteca de utilitários do "elogind"
|