zoukankan      html  css  js  c++  java
  • nsenter命令简介

    nsenter命令简介

    nsenter命令是一个可以在指定进程的命令空间下运行指定程序的命令。它位于util-linux包中。

     

    用途

    一个最典型的用途就是进入容器的网络命令空间。相当多的容器为了轻量级,是不包含较为基础的命令的,比如说 ip address,ping,telnet,ss,tcpdump 等等命令,这就给调试容器网络带来相当大的困扰:只能通过 docker inspect ContainerID 命令获取到容器IP,以及无法测试和其他网络的连通性。这时就可以使用nsenter命令仅进入该容器的网络命名空间,使用宿主机的命令调试容器网络。此外,nsenter也可以进入 mnt, uts, ipc, pid, user 命令空间,以及指定根目录和工作目录。

     

    原理

    namespace

    namespace是Linux中一些进程的属性的作用域,使用命名空间,可以隔离不同的进程。

    Linux在不断的添加命名空间,目前有:

    • mount:挂载命名空间,使进程有一个独立的挂载文件系统,始于Linux 2.4.19
    • ipc:ipc命名空间,使进程有一个独立的ipc,包括消息队列,共享内存和信号量,始于Linux 2.6.19
    • uts:uts命名空间,使进程有一个独立的hostname和domainname,始于Linux 2.6.19
    • net:network命令空间,使进程有一个独立的网络栈,始于Linux 2.6.24
    • pid:pid命名空间,使进程有一个独立的pid空间,始于Linux 2.6.24
    • user:user命名空间,是进程有一个独立的user空间,始于Linux 2.6.23,结束于Linux 3.8
    • cgroup:cgroup命名空间,使进程有一个独立的cgroup控制组,始于Linux 4.6

    Linux的每个进程都具有命名空间,可以在/proc/PID/ns目录中看到命名空间的文件描述符。

    使用

    nsenter [options] [program [arguments]]
    
    options:
    -t, --target pid:指定被进入命名空间的目标进程的pid
    -m, --mount[=file]:进入mount命令空间。如果指定了file,则进入file的命令空间
    -u, --uts[=file]:进入uts命令空间。如果指定了file,则进入file的命令空间
    -i, --ipc[=file]:进入ipc命令空间。如果指定了file,则进入file的命令空间
    -n, --net[=file]:进入net命令空间。如果指定了file,则进入file的命令空间
    -p, --pid[=file]:进入pid命令空间。如果指定了file,则进入file的命令空间
    -U, --user[=file]:进入user命令空间。如果指定了file,则进入file的命令空间
    -G, --setgid gid:设置运行程序的gid
    -S, --setuid uid:设置运行程序的uid
    -r, --root[=directory]:设置根目录
    -w, --wd[=directory]:设置工作目录
    
    如果没有给出program,则默认执行$SHELL。

     

    示例:

    这里我随便运行了一个容器并查看容器pid

    [root@Wshile ~]# docker inspect -f {{.State.Pid}} 091f114de06e
    5645

    然后,使用nsenter命令进入该容器的网络命令空间:

    [root@Wshile ~]# nsenter -n -t5645
    [root@Wshile ~]# ip addr
    1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
        link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
        inet 127.0.0.1/8 scope host lo
           valid_lft forever preferred_lft forever
    18: eth0@if19: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default 
        link/ether 02:42:ac:11:00:02 brd ff:ff:ff:ff:ff:ff link-netnsid 0
        inet 172.17.0.2/16 brd 172.17.255.255 scope global eth0
           valid_lft forever preferred_lft forever

    进入成功。

    在Kubernetes中,在得到容器pid之前还需获取容器的ID,可以使用如下命令获取:

    [root@Wshile test]# kubectl get pod test -oyaml|grep containerID
      - containerID: docker://cf0873782d587dbca6aa32f49605229da3748600a9926e85b36916141597ec85
    加油,你们是最棒的!
  • 相关阅读:
    nyoj 329 循环小数【KMP】【求最小循环节长度+循环次数+循环体】
    转 :hdoj 4857 逃生【反向拓扑】
    hdoj 3342 Legal or Not【拓扑排序】
    hdoj 2094 产生冠军
    poj 1789 Truck History【最小生成树prime】
    转:【拓扑排序详解】+【模板】
    hdoj 1285 确定比赛名次【拓扑排序】
    poj 2031 Building a Space Station【最小生成树prime】【模板题】
    zzuoj 10408: C.最少换乘【最短路dijkstra】
    [LC] 232. Implement Queue using Stacks
  • 原文地址:https://www.cnblogs.com/Wshile/p/12596617.html
Copyright © 2011-2022 走看看