Docker底层原理:Namespace的使用

文章目录

unshare命令设置命名空间:

sh 复制代码
sudo unshare [options] [command]

options可选参数

-m 或 --mount:创建新的Mount命名空间

-i 或 --ipc:创建新的IPC命名空间

-p 或 --pid:创建新的PID命名空间

-n 或 --net:创建新的Network命名空间

-u 或 --uts:创建新的UTS命名空间

-U 或 --user:创建新的User命名空间

-C 或 --cgroup[=]:创建新的Cgroup命名空间

command是在新的命名空间中运行的命令

例子:

sh 复制代码
# 在一个新的PID namespace中运行一个shell会话
sudo unshare -p /bin/bash

# 创建一个新的Mount命名空间并挂载一个文件系统
sudo unshare -m mount -t ext4 /dev/sdb1 /mnt

# 创建一个新的IPC命名空间并运行指定的命令
sudo unshare -i ls -l

nsenter命令进入已有的命名空间

sh 复制代码
sudo nsenter [options] [command]

options可选参数

-m 或 --mount[=]:进入指定的Mount命名空间。

-i 或 --ipc[=]:进入指定的IPC命名空间。

-p 或 --pid[=]:进入指定的PID命名空间。

-n 或 --net[=]:进入指定的Network命名空间。

-u 或 --uts[=]:进入指定的UTS命名空间。

-U 或 --user[=<UID/GID map>]:进入指定的User命名空间。

-s 或 --setuid :设置指定的UID。

-r 或 --setgid :设置指定的GID。

command是要在特定命名空间中运行的命令

例子:

sh 复制代码
# 进入指定的PID命名空间并执行命令:
sudo nsenter -t <PID> -p /bin/bash

# 进入指定的Mount命名空间并挂载一个文件系统:
sudo nsenter -t <PID> -m mount -t ext4 /dev/sdb1 /mnt

# 进入指定的UTS命名空间并修改主机名:
sudo nsenter -t <PID> -u hostname newhostname
相关推荐
测试人社区-千羽3 分钟前
生物识别系统的测试安全性与漏洞防护实践
运维·人工智能·opencv·安全·数据挖掘·自动化·边缘计算
一点事18 分钟前
centos7:离线安装docker
运维·docker·容器
初学者_xuan39 分钟前
K8S资源无法删除处理方法
容器·贪心算法·kubernetes
晚风_END1 小时前
postgresql数据库|数据库维护系列|postgresql数据库参数配置详解和数据库维护时机的选择(三)
运维·开发语言·数据库·postgresql·oracle
RisunJan1 小时前
Linux命令-grep命令(文本搜索工具)
linux·运维·服务器
The Electronic Cat1 小时前
树莓派安装nginx
运维·chrome·nginx
不想画图2 小时前
ELK+Filebeat实战
运维·elk
码界奇点2 小时前
基于Python与Django的白泽自动化运维系统设计与实现
运维·python·django·毕业设计·源代码管理
安当加密2 小时前
防勒索方案在信创服务器上的部署实践
运维·服务器
行思理2 小时前
Linux多PHP如何切换系统默认PHP版本
linux·运维·php