Docker基础: Linux内核命名空间之(4)uts namespace

作为开源Container技术代表的Docker,它跟Linux内核的Namespace和Cgroup两大特性密不可分。物有本末,事有终始。知所先后,则近道矣。理解Linux的这两大特性将有助于我们更深入的理解Docker。
在本文中我们将会使用unshare命令来演示Linux内核的uts Namespace是如何动作的。

Namespace的历史

Namespace并不是Linux才推出的东西,早在很久之前,Unix上就有类似的东西,而HPUX和Solaris商用的Conatiner更是以前就有推出。而在Linux的2.6之后的版本Namespace就逐步的被加了进来。

Linux Namespace的6大类型

项番类型功能说明
No.1MNT Namespace提供磁盘挂载点和文件系统的隔离能力
No.2IPC Namespace提供进程间通信的隔离能力
No.3Net Namespace提供网络隔离能力
No.4UTS Namespace提供主机名隔离能力
No.5PID Namespace提供进程隔离能力
No.6User Namespace提供用户隔离能力

Ubuntu版本

root@ubuntu:~# uname -a
Linux ubuntu 4.4.0-31-generic #50-Ubuntu SMP Wed Jul 13 00:07:12 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux
root@ubuntu:~#

事前确认

确认当前进程PID

root@ubuntu:~# echo $$
32968
root@ubuntu:~#

确认当前进程的各个namespace

root@ubuntu:~# ls -l /proc/$$/ns
total 0
lrwxrwxrwx 1 root root 0 Sep 15 10:23 cgroup -> cgroup:[4026531835]
lrwxrwxrwx 1 root root 0 Sep 15 10:23 ipc -> ipc:[4026531839]
lrwxrwxrwx 1 root root 0 Sep 15 10:23 mnt -> mnt:[4026531840]
lrwxrwxrwx 1 root root 0 Sep 15 10:23 net -> net:[4026531957]
lrwxrwxrwx 1 root root 0 Sep 15 10:23 pid -> pid:[4026531836]
lrwxrwxrwx 1 root root 0 Sep 15 10:23 user -> user:[4026531837]
lrwxrwxrwx 1 root root 0 Sep 15 10:23 uts -> uts:[4026531838]
root@ubuntu:~#

内容说明

项番内容说明
No.1linux会在/proc下创建所对应的进程相关的信息,ns则为Namespace的信息
No.2$$为当前进程PID,/proc/$$/ns下的Namespace的个数回随着Linux内核的高低不同显示的个数不同,因为Linux所支持的Namespace不是一次到位的
No.3uts:[4026531838],不同的Namespace都有不同的编号,比如32968的uts的namespace的编号就是4026531838
No.4关于Cgroup会单独在后面进行说明

事前确认

确认到当前hostname

root@ubuntu:~# echo $$
32968
root@ubuntu:~# hostname
ubuntu
root@ubuntu:~#

使用unshare隔离uts namespace

root@ubuntu:~# echo $$
32968
root@ubuntu:~# unshare --uts /bin/bash
root@ubuntu:~#

好像没有任何变化,其实这个已经不是刚才我们的32968进程了,而是一个新的进程,通过确认$$就能确认

root@ubuntu:~# echo $$
34046
root@ubuntu:~#

再来确认一下,34046和32968两个进程的关系,我们能清楚地看到这是父子关系的两个进程,虽然都是bash

admin01@ubuntu:~$ ps -ef |grep 32968 |grep -v grep
root      32968  32967  0 10:16 pts/0    00:00:00 -su
root      34046  32968  0 14:20 pts/0    00:00:00 /bin/bash
admin01@ubuntu:~$ pstree 32968
bashqqqbash
admin01@ubuntu:~$

确认

在被隔离了net namespace的bash中确认hostname

root@ubuntu:~# echo $$
34046
root@ubuntu:~# hostname
ubuntu
root@ubuntu:~#

修改hostname

root@ubuntu:~# echo $$
34046
root@ubuntu:~# hostname liumiaocn
root@ubuntu:~# hostname
liumiaocn
root@ubuntu:~#

另起一个终端确认hostname是否被修改

admin01@ubuntu:~$ echo $$
33414
admin01@ubuntu:~$ hostname
ubuntu
admin01@ubuntu:~$

未被修改,所以hostname被修正的范围仅限于新做出的uts namespace中

新uts Namespace编号

/proc/$$/ns下面会列出当前的namespace信息,我们来看看一下这个使用unshare隔离了uts namespace的信息

root@ubuntu:~# echo $$
34046
root@ubuntu:~# ll /proc/$$/ns
total 0
dr-x--x--x 2 root root 0 Sep 15 14:21 ./
dr-xr-xr-x 9 root root 0 Sep 15 14:21 ../
lrwxrwxrwx 1 root root 0 Sep 15 14:25 cgroup -> cgroup:[4026531835]
lrwxrwxrwx 1 root root 0 Sep 15 14:21 ipc -> ipc:[4026531839]
lrwxrwxrwx 1 root root 0 Sep 15 14:21 mnt -> mnt:[4026531840]
lrwxrwxrwx 1 root root 0 Sep 15 14:21 net -> net:[4026531957]
lrwxrwxrwx 1 root root 0 Sep 15 14:21 pid -> pid:[4026531836]
lrwxrwxrwx 1 root root 0 Sep 15 14:21 user -> user:[4026531837]
lrwxrwxrwx 1 root root 0 Sep 15 14:21 uts -> uts:[4026532506]
root@ubuntu:~#

与之前进行比较,我们可以清晰地发现,除了uts的namespace编号之外,其余都没有改变。

其他相关

内容URL
在CentOS7上使用LXC管理容器http://blog.csdn.net/liumiaocn/article/details/52348219
如何使用RHEL/CentOS 7安装创建和管理LXC (Linux Containers)http://blog.csdn.net/liumiaocn/article/details/52337479
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值