• 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
    加油,你们是最棒的!
  • 相关阅读:
    django项目的setting、views(视图文件)、urls(新增子路由)和templates文件
    django问题之2:'set' object is not reversible
    django问题之1:ModuleNotFoundError: No module named 'views'
    搭建django环境和简单的开发post、get接口(转载)
    python中的装饰器原理和作用(转载)
    博客园特效(爱心效果、烟花效果、鼠标吸附粒子/斜杆)
    正则表达式的笔记
    第三方支付的测试点【杭州多测师】【杭州多测师_王sir】
    Python题目【杭州多测师】【杭州多测师_王sir】
    查看Nginx是否启动
  • 原文地址:https://www.cnblogs.com/Wshile/p/12596617.html
Copyright © 2020-2023  润新知