AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 792795
Accepted
Seamus
Seamus
Asked: 2025-03-21 15:33:03 +0800 CST2025-03-21 15:33:03 +0800 CST 2025-03-21 15:33:03 +0800 CST

Debian 设置 systemd networking.service 和 NetworkManager.service

  • 772

我的系统只有一个接口:通过 wifi。NetworkManagerwlan0是默认接口。但是,系统启用了几个“网络服务”。以下是与“网络”相关的已启用服务的列表(默认):

$ systemctl list-unit-files --state=enabled

ModemManager.service               enabled enabled
networking.service                 enabled enabled
NetworkManager-dispatcher.service  enabled enabled
NetworkManager-wait-online.service enabled enabled
NetworkManager.service             enabled enabled

wpa_supplicant.service             enabled enabled  # underlined??

我想尝试一下networking.service,所以我添加了所需的条目/etc/network/interfaces以使其工作,并禁用了NetworkManager.service。重新启动后,“网络”即可运行(这意味着我可以做我需要做的所有事情:通过连接到主机SSH,进行apt更新等)。

接下来,我想尝试重新启用NetworkManager.service和禁用networking.service。我注释掉了我对所做的所有添加/etc/network/interfaces,然后禁用networking.service并重新启动。重新启动后,我无法通过 SSH 重新连接到主机。

然后我将主机连接到控制台,重新启用networking.service并重新启动。网络已恢复(这意味着我可以通过 SSH 连接到主机,执行apt等)。

我进行了搜索,但未能找到与我的 Debian“书虫”系统有关的这个问题的答案:

如果我禁用networking.service,但保持NetworkManager.service启用状态,为什么会“破坏”网络?

编辑...

向所有人道歉 - 我搞砸了!在@grawity下方评论中,我意识到我的问题是由NetworkManager几个月前创建的配置引起的,但networking.service自从那以后我一直在使用配置,所以它被我遗忘了。

所以 - 这里的所有答案都是正确的,而我的问题是这里唯一不正确的帖子。

再次向大家致歉。

debian
  • 3 3 个回答
  • 78 Views

3 个回答

  • Voted
  1. Best Answer
    grawity
    2025-03-21T17:24:23+08:002025-03-21T17:24:23+08:00

    它们确实是独立的工具。networking.service是 Debian 自己的ifupdown软件,它的功能与 NetworkManager 相同 - 但根据不同的配置文件。旧版本的 NetworkManager 曾经能够导入您的 /etc/network/interfaces,但我相信该功能在某个时候被删除了,主要是 NM 希望使用其自己完全独立的连接配置文件。

    因此,如果您已在 /etc/network/interfaces 中定义了以太网或 Wi-Fi 设置,那么这仅适用于 ifupdown,其他工具不会关心它。如果您想改用 NetworkManager,则需要通过nmcli或nmtui或配置相同的以太网nm-connection-editor。

    注意:NetworkManager 可能使用与 ifupdown 相同的 dhclient,但它也可能使用内部 DHCP 客户端。内部 DHCP 客户端默认会发送与 dhclient 不同类型的“客户端标识符”——/etc/machine-id 与 MAC 地址——因此默认会获得与 dhclient 不同的 IP 地址租约。

    • 2
  2. ctx
    2025-03-21T18:31:41+08:002025-03-21T18:31:41+08:00

    混淆可能来自于使用旧工具和针对 GUI(桌面环境)优化的工具。

    如果你不需要 GUI,我建议使用systemd-networkd:

    https://www.debian.org/doc/manuals/debian-reference/ch05.en.html#_the_modern_network_configuration_without_gui

    https://wiki.debian.org/SystemdNetworkd

    https://wiki.debian.org/WiFi/HowToUse#Using_systemd_and_wpa_supplicant

    • 1
  3. ReflectYourCharacter
    2025-03-21T19:19:25+08:002025-03-21T19:19:25+08:00

    您可以同时使用networking.service和NetworkManager,例如networking.service管理eth0和NetworkManager管理WiFi (这是我的设置)。

    或者,您可以单独使用每项服务。

    两者不能同时管理同一个接口,因为这会导致冲突,例如一个服务覆盖另一个服务的设置,和/或导致网络连接问题。

    如果networking.service是disabled,NetworkManager则不会自动从文件中接管接口,/etc/network/interfaces除非正确配置以管理这些接口。

    如果networking.service正在管理接口但被禁用,则可能导致网络连接中断,因为NetworkManager除非配置设置为管理,否则不会自动接管管理。

    通过nmcli device status,您可以看到哪些接口由 NetworkManager 管理。

    例子:

    DEVICE     TYPE      STATE      CONNECTION
    eth0       ethernet  unmanaged  --
    wlp3s0     wifi      managed    my_wifi
    

    如果某个接口的状态为managed,则表示NetworkManager管理该接口。

    如果状态为unmanaged,则表示NetworkManager不管理此接口,它由另一个服务管理(例如networking.service)或未由任何服务主动管理。

    另外,看看文件/etc/NetworkManager/NetworkManager.conf

    在NetworkManager配置中,有一个managed参数,指定是否NetworkManager要管理文件中配置的网络接口/etc/network/interfaces。

    managed=true表示NetworkManager允许管理这些接口。

    managed=false意味着NetworkManager不允许管理这些接口,它们由另一个服务(如)管理networking.service,这里的错误值/设置可能会导致冲突。

    • NetworkManager.conf — NetworkManager 配置文件

    • 网络管理器.conf | Ubuntu

    • 如何设置要管理的网络设备?

    • /etc/NetworkManager 下文件的解释?

    要解决冲突,请确保只有一个服务在管理给定接口。要么配置NetworkManager为管理所有接口(通过managed=true从中设置和删除接口/etc/network/interfaces),要么使用 networking.service表示interfaces在中定义/etc/network/interfaces(在managed=false中/etc/NetworkManager/NetworkManager.conf)。

    • 1

相关问题

  • GRUB 配置以识别同一 Linux 发行版的不同桌面环境(安装)

  • astyle 不会更改源文件格式

  • 接收有关全新 Debian 的电子邮件

  • Debian Stretch:libgs_plugin_systemd-updates.so 中的 gnome-software 段错误

  • 如何在拼音输入法中输入ü?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve