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 / 问题 / 443898
Accepted
Ben S.
Ben S.
Asked: 2018-05-16 02:51:52 +0800 CST2018-05-16 02:51:52 +0800 CST 2018-05-16 02:51:52 +0800 CST

每个网络命名空间中的单独 DNS 配置

  • 772

我已经在我的 Linux 系统(内核版本 3.10)上设置了几个网络命名空间,现在我想配置每个网络命名空间以拥有自己的 DNS 设置。

我resolv.conf在每个/etc/netns/[namespace]目录中创建了文件,现在我想让我的系统按以下方式工作:

在 bash 命令行中,每当我nsenter --net=/run/netns/[namespace name]使用/etc/netns/[namespace name]/resolv.conf.

如果我像这样运行我的命令:

 "ip netns exec [namespace name] [command]"

然后应用命名空间的 DNS 设置。

但是,当运行没有“ip netns exec”的命令时,DNS 设置取自/etc/resolv.conf,即使运行“netns get cur”表示上下文设置为所需的网络命名空间。

我尝试mount --bind /etc/netns/[namespace name]/resolv.conf /etc/resolv.conf在适当的网络命名空间的上下文中执行此操作,但这会将挂载应用到整个系统中,而不是仅在该网络命名空间的上下文中。

我怀疑使用挂载命名空间可能会有所帮助,所以我尝试阅读挂载命名空间的手册页,但是在我致力于它的短时间内无法从中做出任何事情。

有没有一种简单而优雅的方式来实现这个目标?

任何有关解决方案的帮助/指导将不胜感激!

dns namespace
  • 3 3 个回答
  • 6551 Views

3 个回答

  • Voted
  1. igal
    2018-05-16T04:00:27+08:002018-05-16T04:00:27+08:00

    解决方案

    您可以使用ip netns execwithbash而不是 using nsenter,即:

    ip netns exec [namespace name] bash
    

    这将允许您进入交互式 shell 会话,其中特定于命名空间的网络配置文件会自动绑定安装到其默认(全局)位置(不影响其他会话)。

    解释

    以下内容来自ip netns手册页:

    对于知道网络命名空间的应用程序,约定是首先在 **/etc/netns/**NAME/ 中查找全局网络配置文件,然后在/etc / 中查找。例如,如果您想要一个不同版本的/etc/resolv.conf用于隔离您的 vpn 的网络命名空间,您可以将其命名为/etc/netns/myvpn/resolv.conf。

    ip netns exec通过创建挂载命名空间并将所有每个网络命名空间的配置文件绑定挂载到它们在 /etc 中的传统位置来自动处理此配置、网络命名空间未知应用程序的文件约定。

    特别注意网络名称空间感知应用程序和网络名称空间不感知应用程序之间的区别。

    另一方面,手册页似乎没有提到这种区别(特别是我搜索了字符串“aware”、“resolv”、“.conf”和“/etc”,但没有找到任何结果)nsenter。这似乎表明该nsenter实用程序不会对不知道命名空间的应用程序执行相同类型的自动处理。

    附加评论

    除了Network Namespaces之外,您可能还想查看User Namespaces和Mount Namespaces。如果您希望在 DNS 之外进一步隔离,您可能还需要考虑容器化,例如LXC Containers、Docker,甚至是完整的 VM。

    • 7
  2. Best Answer
    A.B
    2018-05-16T04:48:36+08:002018-05-16T04:48:36+08:00

    看看ip netns exec test ...你的情况在做什么,使用strace.

    摘抄:

    # strace  -f ip netns exec test sleep 1 2>&1|egrep '/etc/|clone|mount|unshare'|egrep -vw '/etc/ld.so|access'
    unshare(CLONE_NEWNS)                    = 0
    mount("", "/", 0x55f2f4c2584f, MS_REC|MS_SLAVE, NULL) = 0
    umount2("/sys", MNT_DETACH)             = 0
    mount("test", "/sys", "sysfs", 0, NULL) = 0
    open("/etc/netns/test", O_RDONLY|O_NONBLOCK|O_DIRECTORY|O_CLOEXEC) = 5
    mount("/etc/netns/test/resolv.conf", "/etc/resolv.conf", 0x55f2f4c2584f, MS_BIND, NULL) = 0
    

    所以要重现(部分,例如/sys这里没有处理)ip netns exec test ...正在做什么:

    ~# ip netns id
    
    ~# head -1 /etc/resolv.conf 
    # Generated by NetworkManager
    

    ~# nsenter --net=/var/run/netns/test unshare --mount sh -c 'mount --bind /etc/netns/test/resolv.conf /etc/resolv.conf; exec bash'

    ~# ip netns id
    test
    ~# head -1 /etc/resolv.conf 
    # For namespace test
    ~#
    

    所以这是对的。nsenter单独是不够的。unshare必须使用,更改为新创建的挂载命名空间(基于前一个的副本)并更改它,而不仅仅是逐字使用现有的命名空间,因为还没有适合的现有命名空间。这就是在做与 tell 同名的系统调用的原因strace。

    • 6
  3. DericS
    2021-06-09T12:38:02+08:002021-06-09T12:38:02+08:00

    前两个答案提供了很好的信息和答案,但我会尝试从稍微不同的角度来回答。

    网络命名空间为您提供放置网络接口、网络路由路由和规则以及网络过滤器条目的位置。

    挂载命名空间为您提供了放置文件的地方。这些文件可能与网络相关,并且可能旨在用于特定的网络命名空间,但最终它们只是文件。

    创建新的网络命名空间(例如使用“ ip netns add newnetns”)不会自动为您提供新的挂载命名空间。

    如果您使用“ ip netns exec newnetns somecomand”命令,那么您将使用新的网络命名空间(您之前创建的 newnetns)创建一个新进程(somecommand),并且您还将获得一个为此进程创建的新挂载命名空间。您还将获得某些文件绑定挂载到新的挂载命名空间(例如,/etc/netns/newnetns/resolv.conf到/etc/resolv.conf)。现在使用“ ip netns exec”时,这些文件通常与网络相关,例如 resolv.conf。但是,即使这些文件与网络相关并且您可能创建它们以与新的网络命名空间一起使用,它们也不属于您的新网络命名空间。当您的进程(某个命令)终止时,为其创建的挂载命名空间也将消失(除非您通过其他方式将另一个进程附加到同一个挂载命名空间),但网络命名空间将保留。

    当您使用该nsenter命令时,它会将您的命令放入您选择的网络命名空间中,但nsenter不会像“ ip netns exec”那样创建新的挂载命名空间。

    值得注意的是,“ ip netns add newnetns”创建了一个基本上为空的新网络命名空间。您必须将接口或路由添加到该新的网络命名空间。“ ip netns exec” 将一个进程放入该网络命名空间,创建一个新的挂载命名空间,它基本上是主挂载命名空间的副本(很可能显示您的主文件系统),只添加了几个绑定挂载。

    另外值得注意的是,ip-netns手册页提到了它将代表不知道网络名称空间的应用程序使用的文件约定。这可能会给人一种印象,即有一大堆使用文件约定的网络感知应用程序/etc/netns/nsname/... 据我所知,情况并非如此。我想不出任何其他使用文件的应用程序/etc/netns/nsname/...,但也许有。

    • 2

相关问题

  • Nginx - 创建链接到另一个(本地)网站的子域

  • 什么是根域?[关闭]

  • 如何使用不同的 DNS 服务器将主机名解析为 ip?

  • bind9反向解决问题

  • 如何验证我使用 9.9.9.9 作为 DNS?

Sidebar

Stats

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

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

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

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

    • 5 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • 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
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +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
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +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