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
相关推荐
Dillon Dong31 分钟前
【系统运维】Docker版本冲突问题详解:从错误到解决方案
docker·容器
Dillon Dong35 分钟前
【系列主题】从 Docker 构建失败看依赖隔离:多阶段构建的“隐形陷阱”
运维·docker·容器
云飞云共享云桌面43 分钟前
精密机械制造工厂研发部门使用SolidWorks和ug,三维设计云桌面如何选择?
大数据·运维·服务器·网络·数据库·人工智能·制造
网络小白不怕黑1 小时前
1.2 VMware部署Rocky Linux 9 (MBR分区表,图形化安装)
linux·运维·服务器
BizObserver1 小时前
从 SEO 到 GEO:2026 年品牌信息分发逻辑的颠覆性变革
大数据·运维·网络·人工智能·安全
AI服务老曹1 小时前
从底层协议对接说起:基于 GB28181/RTSP 的异构视频流接入架构设计与源码级解析
人工智能·docker
狂奔蜗牛飙车2 小时前
大数据赛项(中职组)-VMware+CentOS 7环境安装
linux·运维·centos·大数据应用与服务·大数据入门指南·中职组大数据应用及服务赛项·vmware中装centos7
蚰蜒螟2 小时前
深度剖析:从 clone3 到 start_routine —— Linux 新线程的“破茧成蝶”之旅
java·linux·运维
空中海2 小时前
Nginx 知识体系 · 下篇:高级与实战
运维·nginx·spring
小五传输2 小时前
内外网文件交换系统产品推荐:安全高效一体化,破解内外网传输难题
大数据·运维·安全