网站首页 > 资源文章 正文
User Namespace主要是隔离用户的用户组ID。也就是说每一个进程的User ID和Group ID在User Namespace内外可以是不同的。比较常用的是,在宿主机上以一个非root用户运行创建一个User Namesapce,然后在User Namespace里面却映射成root用户。这意味着,这个进程在User Namespace里面有root权限,但是在User Namesapce外面却没有root的权限。从Linux Kernel 3.8开始,非root进程也可以创建User Namespace,并且用户在Namespace里面可以被映射成root,且在Namespace内有root权限。
下面,继续以一个例子来描述,代码如下:
package main
import (
"log"
"os"
"os/exec"
"syscall"
)
func main() {
cmd := exec.Command("sh")
cmd.SysProcAttr = &syscall.SysProcAttr{
Cloneflags: syscall.CLONE_NEWUTS | syscall.CLONE_NEWIPC | syscall.CLONE_NEWPID | syscall.CLONE_NEWNS | syscall.CLONE_NEWUSER,
}
cmd.Stdin = os.Stdin
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
if err := cmd.Run(); err != nil {
log.Fatal(err)
}
os.Exit(-1)
}
本例在原来的基础上增加了syscall.CLONE_NEWUSER。首先,以root来运行这个程序,运行前在宿主机上来看一下当前的用户和用户组,显示如下:
可以看到我们是root用户,接下来运行一下程序。
可以看到,它们的UID是不同的,因此说明User Namespace生效了。
猜你喜欢
- 2024-10-21 hadoop启动报错:there is no HDFS_NAMENODE_USER _Error JAVA_HOME
- 2024-10-21 大同古城墙(大同古城墙的景点介绍)
- 2024-10-21 Maven快速入门(二)手动创建maven项目hellomaven
- 2024-10-21 盘点Python网页开发轻量级框架Flask知识(上篇)
- 2024-10-21 flask web服务器的开发就这样简单的入门
- 2024-10-21 Mybatis二级缓存的实现(mybatis 二级缓存)
- 2024-10-21 高一学生寒假(复习及预习用)数学、物理等学科教学视频目录
- 2024-10-21 怎么连接隐藏SSID无线网络(如何连接隐藏wifi网络)
- 2024-10-21 MyBatis中Dao层、Service层以及xml文件的CRUD模板
- 2024-10-21 HTML5表单自动验证(html5自带的表单验证功能)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- 电脑显示器花屏 (79)
- 403 forbidden (65)
- linux怎么查看系统版本 (54)
- 补码运算 (63)
- 缓存服务器 (61)
- 定时重启 (59)
- plsql developer (73)
- 对话框打开时命令无法执行 (61)
- excel数据透视表 (72)
- oracle认证 (56)
- 网页不能复制 (84)
- photoshop外挂滤镜 (58)
- 网页无法复制粘贴 (55)
- vmware workstation 7 1 3 (78)
- jdk 64位下载 (65)
- phpstudy 2013 (66)
- 卡通形象生成 (55)
- psd模板免费下载 (67)
- shift (58)
- localhost打不开 (58)
- 检测代理服务器设置 (55)
- frequency (66)
- indesign教程 (55)
- 运行命令大全 (61)
- ping exe (64)
本文暂时没有评论,来添加一个吧(●'◡'●)