moby/libnetwork/reexec_netns_create.go
Arnaud Porterie 0d29ca540f Initial import
Signed-off-by: Arnaud Porterie <arnaud.porterie@docker.com>
2015-02-19 17:30:18 -08:00

52 lines
862 B
Go

package libnetwork
import (
"log"
"os"
"runtime"
"syscall"
"github.com/vishvananda/netlink"
)
func createNetworkNamespace() {
runtime.LockOSThread()
if len(os.Args) < 2 {
log.Fatalf("no namespace path provided")
}
if err := createNamespaceFile(os.Args[1]); err != nil {
log.Fatal(err)
}
if err := syscall.Unshare(syscall.CLONE_NEWNET); err != nil {
log.Fatal(err)
}
if err := loopbackUp(); err != nil {
log.Fatal(err)
}
if err := syscall.Mount("/proc/self/ns/net", os.Args[1], "bind", syscall.MS_BIND, ""); err != nil {
log.Fatal(err)
}
os.Exit(0)
}
func createNamespaceFile(path string) (err error) {
var f *os.File
if f, err = os.Create(path); err == nil {
f.Close()
}
return err
}
func loopbackUp() error {
iface, err := netlink.LinkByName("lo")
if err != nil {
return err
}
return netlink.LinkSetUp(iface)
}