Linux namespace定位

1、lsns命令查看系统中namespace

[root@localhost hotspot]# lsns
        NS TYPE  NPROCS   PID USER   COMMAND
4026531836 pid      324     1 root   /usr/lib/systemd/systemd --switched-root --system --deserialize 22
4026531837 user     326     1 root   /usr/lib/systemd/systemd --switched-root --system --deserialize 22
4026531838 uts      322     1 root   /usr/lib/systemd/systemd --switched-root --system --deserialize 22
4026531839 ipc      322     1 root   /usr/lib/systemd/systemd --switched-root --system --deserialize 22
4026531840 mnt      312     1 root   /usr/lib/systemd/systemd --switched-root --system --deserialize 22
类型说明备注
NSnamespace identifier (inode number)namespace本质体现在文件上
TYPEkind of namespacenamespace类型,目前支持pid、user、utc、net、mount、ipc以及cgroup
NPROCSnumber of processes in the namespace当在当前namespace中有多少进程
PIDlowest PID in the namespace进程id
USERusername of the PID用户
COMMANDcommand line of the PID进程启动参数

2、nsenter命令进入namespace

 

3、docker容器net namespace

我们可以通过ip netns创建net namespace,例如:ip netns add net0, 该命令执行完毕后会在/var/run/netns目录下创建以net0的一个文件,后续操作均是操作这个文件。但是docker创建的net namesapce 无法直接通过ip netns进行管理,注意这里是无法直接。那么我们应该怎么管理呢? docker 创建的net namesapce文件保存在了/var/run/docker/netns中,这个目录中所有文件都是net namespace,其中default文件指向的命名空间是物理主机net namesapce,换句话说如果我们在启动容器时指定的网路模式为--net=host,就是通过default文件。那么具体如何操作呢?其实很简单。

我们通过ln -s 创建软连接文件,然后将/var/run/docker/netns中文件,软链接到/var/run/netns下即可。例如:

[root@localhost ~]# ln -s  /var/run/docker/netns/ecce4955191c /var/run/netns/
[root@localhost ~]# ip netns exec ecce4955191c /bin/sh
sh-4.2# ifconfig -a
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 172.17.0.2  netmask 255.255.0.0  broadcast 172.17.255.255
        ether 02:42:ac:11:00:02  txqueuelen 0  (Ethernet)
        RX packets 161  bytes 32161 (31.4 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

sh-4.2# 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值