作为我大学项目的一部分,我正在尝试在 Go 中编写一个容器守护程序,并且由于某种原因,Chroot('/to/a/directory')
这给了我一个错误:
shell-init: error retrieving current directory: getcwd: cannot access parent directories: No such file or directory
我已经尝试syscall.Chroot()
在 SysProcAttr 中使用和 Chroot 字段,但正如它可能已经清楚的那样,错误仍然存在。
我使用 Ubuntu 18.04,我的 Go 版本是1.13.5
编辑:
代码:
package main
import (
"fmt"
"os"
"os/exec"
"syscall"
)
func main() {
switch os.Args[1] {
case "run":
run()
case "child":
child()
default:
panic("Too less arguments")
}
}
func run() {
fmt.Printf("Running: %v\n", os.Args[2:])
cmd := exec.Command("/proc/self/exe", append([]string{"child"}, os.Args[2:]...)...)
cmd.Stdin = os.Stdin
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
cmd.SysProcAttr = &syscall.SysProcAttr{
Cloneflags: syscall.CLONE_NEWUTS,
}
cnr(cmd.Run())
}
func child() {
cmd := exec.Command(os.Args[2], os.Args[3:]...)
cmd.Stdin = os.Stdin
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
cmd.SysProcAttr = &syscall.SysProcAttr{
Cloneflags: syscall.CLONE_NEWUTS,
}
syscall.Sethostname([]byte("container"))
syscall.Chroot("/home/utsav")
syscall.Chdir("/")
cnr(cmd.Run())
}
func cnr(err error) { //Check and Run
if err != nil {
panic(err)
}
}