"dhcpcd" é uma implementação do cliente "DHCP" especificado na "RFC2131". Um cliente "DHCP" é útil para conectar seu computador a uma rede de intercomunicação que usa "DHCP" para atribuir endereços de rede de intercomunicação. O "dhcpcd" se esforça para ser um cliente "DHCP" completo, mas muito leve.
Esse pacote é conhecido por construir e funcionar adequadamente usando uma plataforma LFS 11.3.
Transferência (HTTP): https://roy.marples.name/downloads/dhcpcd/dhcpcd-9.4.1.tar.xz
Soma de verificação MD5 da transferência: 2b2f46648bc96979f96127f0e0e07d9b
Tamanho da transferência: 251 KB
Espaço em disco estimado exigido: 3,6 MB (com os testes)
Tempo de construção estimado: menos que 0,1 UPC (com os testes)
LLVM-15.0.7 (com "Clang"), ntp-4.2.8p15, chronyd e ypbind
Observações de Usuário(a): https://wiki.linuxfromscratch.org/blfs/wiki/dhcpcd
Lançamentos recentes do "dhcpcd" suportam opcionalmente a separação de privilégios. Como os benefícios práticos de segurança disso não são claros para um aplicativo como o "dhcpcd" e a configuração é mais complicada, o livro atualmente usa como padrão desativá-lo.
No entanto, se você quiser usar a separação de privilégios, [então]
etapas adicionais de instalação são necessárias para configurar o
ambiente adequado. Emita os seguintes comandos como o(a) usuário(a)
"root":
install -v -m700 -d /var/lib/dhcpcd &&
groupadd -g 52 dhcpcd &&
useradd -c 'Separação de privilégios do dhcpcd' \
-d /var/lib/dhcpcd \
-g dhcpcd \
-s /bin/false \
-u 52 dhcpcd &&
chown -v dhcpcd:dhcpcd /var/lib/dhcpcd
Corrija um erro de tempo de execução causado por uma mudança na "glibc-2.36":
sed '/Deny everything else/i SECCOMP_ALLOW(__NR_getrandom),' \ -i src/privsep-linux.c
Construa o "dhcpcd" sem separação de privilégios executando o seguinte comando:
./configure --prefix=/usr \
--sysconfdir=/etc \
--libexecdir=/usr/lib/dhcpcd \
--dbdir=/var/lib/dhcpcd \
--runstatedir=/run \
--disable-privsep &&
make
Construa o "dhcpcd" com separação de privilégios executando os seguintes comandos:
./configure --prefix=/usr \
--sysconfdir=/etc \
--libexecdir=/usr/lib/dhcpcd \
--dbdir=/var/lib/dhcpcd \
--runstatedir=/run \
--privsepuser=dhcpcd &&
make
Para testar os resultados, emita: make test.
Agora, como o(a) usuário(a) "root":
make install
--libexecdir=/usr/lib/dhcpcd:
Configura um local mais adequado para bibliotecas internas do
"dhcpcd".
--dbdir=/var/lib/dhcpcd: O
"/var/db" padrão não é compatível com
a "FHS"
--runstatedir=/run: O
"/var/run" padrão é um link simbólico
para "/run".
--with-hook=...: Opcionalmente, você
pode instalar mais ganchos, por exemplo, para instalar alguns
arquivos de configuração como "ntp.conf". O conjunto de ganchos está no
diretório "dhcpcd-hooks" na árvore de
construção.
--disable-privsep: Não use
a separação de privilégios, que é o padrão.
--privsepuser=dhcpcd: Use
esse(a) usuário(a) sem privilégios em uma configuração de separação
de privilégios.
--with-hook=...: Opcionalmente, você
pode instalar mais ganchos, por exemplo, para instalar alguns
arquivos de configuração como "ntp.conf". O conjunto de ganchos está no
diretório "dhcpcd-hooks" na árvore de
construção.
Para configurar o "dhcpcd", você precisa primeiro
instalar o conjunto sequencial de comandos de serviço de rede de
intercomunicação, "/usr/lib/services/dhcpcd" incluído no pacote
"blfs-bootscripts-20230101"
(como usuário "root"):
make install-service-dhcpcd
o conjunto
sequencial de comandos de serviço de rede de intercomunicação
"/usr/lib/services/dhcpcd"
contido nos conjuntos sequenciais de comandos de inicialização
até o "blfs-bootscripts-20191204" não é compatível com o
"dhcpcd" mais recente, pois o local do arquivo do "PID" mudou.
Para contornar isso, emita o seguinte comando:
sed -i "s;/run/dhcpcd-;/run/dhcpcd/;g" /lib/services/dhcpcd
O padrão para
o "dhcpcd" é o de
configurar o nome do dispositivo e o "MTU". Ele também
sobrescreve "/etc/resolv.conf " e
"/etc/ntp.conf". Essas
modificações nos arquivos do sistema são feitas por ganchos que
estão armazenados em "/usr/lib/dhcpcd/dhcpcd-hooks". Configure o
"dhcpcd"
removendo ou adicionando ganchos de/para esse diretório. A
execução de ganchos consegue ser desabilitada usando a opção de
linha de comando "--nohook"
("-C") ou pela opção "nohook" no arquivo "/etc/dhcpcd.conf".
Finalmente,
como o(a) usuário(a) "root", crie
o arquivo de configuração "/etc/sysconfig/ifconfig.eth0" usando os
seguintes comandos. Ajuste adequadamente para interfaces
adicionais:
cat > /etc/sysconfig/ifconfig.eth0 << "EOF"
ONBOOT="yes"
IFACE="eth0"
SERVICE="dhcpcd"
DHCP_START="-b -q -h ''<insira opções apropriadas de início aqui>"
DHCP_STOP="-k <insira opções apropriadas de término aqui>"
EOF
Para mais informações relativas aos valores apropriados
"DHCP_START" e "DHCP_STOP", examine a página de manual do
"dhcpcd".
Embora não
usual, é possível que você precise configurar o "dhcpcd" para usar um "IP" fixo. Aqui, nós
damos um exemplo. Como o(a) usuário(a) "root" crie o arquivo de configuração
"/etc/sysconfig/ifconfig.eth0"
usando os seguintes comandos. Ajuste adequadamente para
interfaces adicionais e para o "IP" e roteador reais que você
precisa:
cat > /etc/sysconfig/ifconfig.eth0 << "EOF"
ONBOOT="yes"
IFACE="eth0"
SERVICE="dhcpcd"
DHCP_START="-b -q -S ip_address=192.168.0.10/24 -S routers=192.168.0.1"
DHCP_STOP="-k"
EOF
Você consegue ou usar servidores "DNS" em "/etc/resolv.conf" oriundos de outro sistema,
teus servidores preferidos, ou apenas o arquivo de exemplo
"/etc/resolv.conf.head" abaixo,
como está:
cat > /etc/resolv.conf.head << "EOF"
# Servidores abertos "DNS"
nameserver 208.67.222.222
nameserver 208.67.220.220
EOF