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
相关推荐
陈桴浮海19 分钟前
【Linux&Ansible】学习笔记合集三
linux·运维·云原生·ansible
小Pawn爷20 分钟前
1.Docker基础
运维·docker·容器
chinesegf22 分钟前
清理docker残留镜像images
运维·docker·容器
江湖有缘26 分钟前
基于华为openEuler系统部署Gitblit服务器
运维·服务器·华为
EnglishJun36 分钟前
Linux系统编程(二)---学习Linux系统函数
linux·运维·学习
小Pawn爷40 分钟前
2.Docker的存储
运维·docker·容器
CaracalTiger41 分钟前
OpenClaw-VSCode:在 VS Code 中通过 WebSocket 远程管理 OpenClaw 网关的完整方案
运维·ide·人工智能·vscode·websocket·开源·编辑器
qq_54702617941 分钟前
LangChain 1.0 核心概念
运维·服务器·langchain
广州中轴线1 小时前
OpenStack on Kubernetes 生产部署实战(十七)
容器·kubernetes·openstack
生而为虫1 小时前
[Windows] 【浏览器自动化精灵V1.0】用Excel表格控制浏览器的自动化
运维·自动化