ip netns 命令用来管理 network namespace。它可以创建命名的 network namespace,然后通过名字来引用 network namespace,所以使用起来很方便。

ip netns 命令格式如下:

ip [ OPTIONS ] netns  { COMMAND | help }

可以通过 help 命令查看 ip netns 所有操作的帮助信息:

network namespace

network namespace 在逻辑上是网络堆栈的一个副本,它有自己的路由、防火墙规则和网络设备。

默认情况下,子进程继承其父进程的 network namespace。也就是说,如果不显式创建新的 network namespace,所有进程都从 init 进程继承相同的默认 network namespace。

根据约定,命名的 network namespace 是可以打开的 /var/run/netns/ 目录下的一个对象。比如有一个名称为 net1 的 network namespace 对象,则可以由打开 /var/run/netns/net1 对象产生的文件描述符引用 network namespace net1。通过引用该文件描述符,可以修改进程的 network namespace。

创建命名的 network namespace

ip netns add NAME 命令创建一个命名的 network namespace:

删除命名的 network namespace

ip [-all] netns del [ NAME ] 命令删除指定名称的 network namespace。如果指定了 -all 选项,则尝试删除所有的 network namespace。

注意,如果我们把网卡设置到了某个 network namespace 中,并在该 network namespace 中启动了进程:

$ sudo ip netns add net0
$ sudo ip link set dev eth0 netns net0
$ sudo ip netns exec net0 bash

在另一个 bash 进程中删除 network namespace net0:

$ sudo ip netns del net0

此时虽然可以删除 netowrk namespace,但是在进程退出之前,网卡一直会保持在你已经删除了的那个 network namespace 中。

查看进程的 network namespace

ip netns identify [PID] 命令用来查看进程的 network namespace。如果不指定 PID 就显示当前进程的 network namespace:

下面的命令指定了 PID:

查看 network namespace 中进程的 PID

ip netns pids NAME 命令用来查看指定的 network namespace 中的进程的 PID。这个命令其实就是去检查 /proc 下的所有进程,看进程的 network namespace 是不是指定的 network namespace:

在指定的 network namespace 中执行命令

ip [-all] netns exec [ NAME ] cmd 命令用来在指定的 network namespace 中执行命令。比如我们要看一下某个 network namespace 中有哪些网卡:

ip netns exec 后面跟着 namespace 的名字,比如这里的 neta,然后是要执行的命令,只要是合法的 shell 命令都能运行,比如上面的 ip addr 或者 bash。

更棒的是,执行的可以是任何命令,不只是和网络相关的(当然,和网络无关命令执行的结果和在外部执行没有区别)。比如下面例子中,执行 bash 命令之后,后面所有的命令都是在这个 network namespace 中执行的,好处是不用每次执行命令都要把 ip netns exec NAME 补全,缺点是你无法清楚知道自己当前所在的 shell,容易混淆:

通过 -all 参数我们可以同时在所有的 network namespace 执行命令:

输出中的 netns: 指示在某个 network namespace 中执行的结果。

监控对 network namespace 的操作

ip netns monitor 命令用来监控对 network namespace 的操作。比如我们删除一个 network namespace 时就会收到相应的通知:

理解 ip netns add 命令

我们通过下面的演示来理解 ip netns add 命令的本质。

查看默认 network namespace 的 ID:

$ readlink /proc/$$/ns/net

在 /var/run/netns 目录下创建一个用于绑定 network namespace 的文件,名为 mynet:

$ sudo mkdir -p /var/run/netns
$ sudo touch /var/run/netns/mynet


通过 unshare 命令创建新的 network namespace,并在新的 namespace 中启动新的 bash:

$ sudo unshare --net bash

查看新的 network namespace ID:

# readlink /proc/$$/ns/net


通过绑定挂载把当前 bash 进程的 network namespace 文件挂载到前面创建的 mynet 文件上:

# mount --bind /proc/$$/ns/net /var/run/netns/mynet
# ls -i /var/run/netns/mynet

通过 ls -i 命令可以看到文件 mynet 的 inode 号和 network namespace 的 ID 相同,说明绑定成功:

退出新创建的 bash,再检查一次 mynet 文件的 inode:

# exit
$ ls -I /var/run/netns/mynet


可以看出 mynet 文件的 inode 没有发生变化,说明我们使用了绑定挂载后,虽然新的 network namespace 中已经没有进程了,但这个新的 network namespace 还继续存在。

上面的一系列操作其实等同于执行了命令:sudo ip netns add mynet

下面的 nsenter 命令则等同于执行了命令: sudo ip netns exec mynet bash

$ sudo nsenter --net=/var/run/netns/mynet bash
# readlink /proc/$$/ns/net


通过 nsenter 命令新建了一个 bash 进程,并把它加入 mynet 所关联的 network namespace(net:[4026532616])。

从上面的示例可以看出,创建命名的 network namespace 其实就是创建一个文件,然后通过绑定挂载的方式将新创建的 network namespace 文件(/proc/$$/ns/net)和该文件绑定,就算该 network namespace 里的所有进程都退出了,内核还是会保留该 network namespace,以后我们还可以通过这个绑定的文件来加入该 network namespace。

原文链接:https://www.cnblogs.com/sparkdev/p/9253409.html

ip netns 命令使用相关推荐

  1. ip netns命令详解

    原文链接:https://www.cpweb.top/343 一.命令介绍   ip netns 命令是用来管理 网络命名空间 的,网络命名空间可以实现 网络隔离.每个网络命名空间都提供了一个完全独立 ...

  2. linux unshare 命令,Linux ip netns 命令

    /var/run/netns/ 目录下的一个对象.比如有一个名称为 net1 的 network namespace 对象,则可以由打开 /var/run/netns/net1 对象产生的文件描述符引 ...

  3. ip netns 命令(备忘)

    Linux Network Namespace Linux Network Namespace 是实现容器化的基础 ip netns 是基于 Linux Network Namespace 的一个实用 ...

  4. ip netns的使用及network namespace 简介

    network namespace 是实现网络虚拟化的重要功能,它能创建多个隔离的网络空间,它们有独自的网络栈信息.不管是虚拟机还是容器,运行的时候仿佛自己就在独立的网络中.这篇文章介绍 networ ...

  5. Centos6.5不支持ip nets命令

    为什么80%的码农都做不了架构师?>>>    Centos6.5的内核已经支持network namespace, 但安装的iproute版本过低,不支持ip nets 命令.升级 ...

  6. Centos 7最小化系统安装设置IP(ifconfig命令)

    我们最小化安装Centos 7的Linux发行版之后,使用ifconfig命令提示找不到,接下来我就用我的亲身经历告诉大家,希望可以帮助一些新手朋友. 1.最小话安装之后使用ifconfig命令提示如 ...

  7. Linux 中ifconfig和ip addr命令查看不到ip解决方法

    Linux 中ifconfig和ip addr命令查看不到ip解决方法 参考文章: (1)Linux 中ifconfig和ip addr命令查看不到ip解决方法 (2)https://www.cnbl ...

  8. linux之ip route命令

    1.基础知识 1.1 路由 (Routing) 1.1.1 路由策略 (使用 ip rule 命令操作路由策略数据库) 基于策略的路由比传统路由在功能上更强大,使用更灵活,它使网络管理员不仅能够根据目 ...

  9. linux之路由知识之ip route 命令中的疑惑

    1.基础知识 1.1 路由 (Routing) 1.1.1 路由策略 (使用 ip rule 命令操作路由策略数据库) 基于策略的路由比传统路由在功能上更强大,使用更灵活,它使网络管理员不仅能够根据目 ...

最新文章

  1. ubuntu配置android开发环境和编译源码遇到的一些问题
  2. java 小坑_关于Java子父类关系的小坑
  3. sql 注入 相关函数
  4. Java序列化简单例子
  5. java 布隆过滤器_什么是布隆过滤器(Bloom Filter)?
  6. 我也确实很向往深圳这种拼搏的精神
  7. Spring MVC+Mybatis 多数据源配置
  8. Etl之HiveSql调优(left join where的位置)
  9. 计算机科学中的递归算法是把问题,递归运算法
  10. Qt程序启动画面QSplashScreen类
  11. ISE_FIFO_IP核接口测试(二)
  12. EF框架step by step(9)—Code First Fluent API
  13. 学生管理系统实训报告
  14. Kali dig命令
  15. nurbs曲线拟合程序_一种基于NURBS的空间自由曲线拟合方法与流程
  16. 2022-04- 聂卫平围棋道场-小汪小喵学围棋
  17. windows ubuntu 双系统 蓝屏Technical information: ***stop:0x0000007B(0x80786B58,0xC0000034,0x00000000,0x00
  18. 在线课程开放平台API分析及脚本制作(一)
  19. flying-saucer生成PDF
  20. 平方度用计算机打出来,角度计算器-角度计算器

热门文章

  1. python 程序流程控制结构-python之流程控制语句
  2. python就业方向有哪些-Python的就业方向有哪些?薪资都是多少?
  3. python对笔记本电脑的要求-学Python买什么笔记本电脑?
  4. python编程课程上课有用吗-Python培训网络课堂|Python编程软件有哪些功能?
  5. php和python对比-python与java、php、go的优势对比
  6. python程序设计报告-20191206 实验二《Python程序设计》实验报告
  7. 有道精品课python-有道精品课-Python小咖养成计划
  8. es中发现结点的角色
  9. 时间与字符串之间的转换
  10. map中批量图层的加载和展示