У меня установлен Linux Automotive Grade (Halibut 8.0.0) на плате Qualcomm.
Это встроенная система без диспетчера пакетов, без инструментов для сборки и без работающего DNS, но я могу нормально подключить Ethernet.
sa8155:~# ifconfig eth0 up
sa8155:~# udhcpc
udhcpc: started, v1.29.3
udhcpc: sending discover
udhcpc: sending select for 10.0.0.112
udhcpc: lease of 10.0.0.112 obtained, lease time 604800
/etc/udhcpc.d/50default: Adding DNS 75.75.75.75
/etc/udhcpc.d/50default: Adding DNS 75.75.76.76
Обратите внимание, что DHCP сообщает, что серверы имен извлекаются правильно.
И я могу пинговать серверы имен:
sa8155:~# ping 75.75.75.75
PING 75.75.75.75 (75.75.75.75): 56 data bytes
64 bytes from 75.75.75.75: seq=0 ttl=58 time=8.973 ms
64 bytes from 75.75.75.75: seq=1 ttl=58 time=19.634 ms
64 bytes from 75.75.75.75: seq=2 ttl=58 time=11.391 ms
Однако я не могу использовать DNS для разрешения каких-либо имен.
sa8155:~# nslookup debian.org
nslookup: write to '127.0.0.1': Connection refused
;; connection timed out; no servers could be reached
Я заметил, что /etc/resolv.conf пуст, кроме этого комментария:
sa8155:~# cat /etc/resolv.conf
# Generated by Connection Manager
Я пробовал вручную редактировать /etc/resolv.conf вот так:
sa8155:~# cat /etc/resolv.conf
# Generated by Connection Manager
search example.com local.test
nameserver 75.75.75.75
nameserver 75.75.76.76
Но это, похоже, полностью отключает интерфейс Ethernet.
Я попытался вручную добавить пару одного хоста и IP-адреса в / etc / hosts, но не смог отредактировать этот файл, хотя являюсь пользователем root.
sa8155:~# ls -alF /etc/ | grep host
-rw-r--r-- 1 root root 26 Nov 13 2019 host.conf
-rw-r--r-- 1 root root 111912 Nov 13 2019 hostapd.conf
-rw-r--r-- 1 root root 7 Nov 13 2019 hostname
-rw-r--r-- 1 root root 237 Nov 13 2019 hosts
-rw-r--r-- 1 root root 0 Nov 13 2019 hosts.allow
-rw-r--r-- 1 root root 0 Nov 13 2019 hosts.deny
sa8155:~# chmod 766 /etc/hosts
chmod: changing permissions of `/etc/hosts': Read-only file system
Поэтому я попытался использовать ConnMan для добавления записей DNS.
Однако службы connmanctl не возвращают ожидаемый список.
sa8155:~# connmanctl services
Error: The name net.connman was not provided by any .service files
sa8155:~#
Я изначально разместил этот вопрос Вот и один респондент предположил, что systemd-networkd может конкурировать с connman.
Я убедился, что обе службы работают:
sa8155:~# systemctl --type=service | grep network
systemd-networkd.service loaded active running Network Service
sa8155:~# systemctl --type=service | grep conn
connman.service
Однако я понимаю, что файлы конфигурации для systemd-networkd находятся здесь:
/etc/systemd/network
И этот каталог для меня пуст.
Также было высказано предположение, что /etc/nsswitch.conf может быть настроен неправильно.
Вот как выглядит мой:
sa8155:/etc/systemd/network# cat /etc/nsswitch.conf
# /etc/nsswitch.conf
#
# Example configuration of GNU Name Service Switch functionality.
# If you have the `glibc-doc' and `info' packages installed, try:
# `info libc "Name Service Switch"' for information about this file.
passwd: compat
group: compat
shadow: compat
hosts: localuser files myhostname mdns4_minimal [NOTFOUND=return] dns
networks: files
protocols: db files
services: db files
ethers: db files
rpc: db files
netgroup: nis
sa8155:/etc/systemd/network#