Назад | Перейти на главную страницу

Как отключить systemd-networkd.service, чтобы connman.service мог включить DNS?

У меня установлен 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#