我正在学习Linux命名空间,并尝试通过golang创建UTS命名空间。这是我的代码
func main() {
cmd := exec.Command("sh")
cmd.SysProcAttr = &syscall.SysProcAttr{
Cloneflags: syscall.CLONE_NEWUTS,
}
cmd.Stdin = os.Stdin
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
if err := cmd.Run(); err != nil {
log.Fatal(err)
}
}
执行go run uts.go
时出现错误fork/exec /bin/sh: operation not permitted
。我的操作系统是Ubuntu 18.04.3
,Linux Kerenl版本是5.0.0-32-generic
。
答案 0 :(得分:0)
从Linux doc
CLONE_NEWUTS(从Linux 2.6.19开始)
uname(2);其中,域名和主机名可以是
分别由setdomainname(2)和sethostname(2)修改。
对UTS命名空间中的标识符所做的更改是可见的
到同一名称空间中的所有其他进程,但不是
对其他UTS名称空间中的进程可见。
只能使用特权进程(CAP_SYS_ADMIN) CLONE_NEWUTS。
答案 1 :(得分:0)
改为构建程序,然后以sudo身份运行可执行文件。
开始构建uts.go
sudo ./uts