reexec_netns_create.go 889 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. package libnetwork
  2. import (
  3. "os"
  4. "runtime"
  5. "syscall"
  6. log "github.com/Sirupsen/logrus"
  7. "github.com/vishvananda/netlink"
  8. )
  9. func createNetworkNamespace() {
  10. runtime.LockOSThread()
  11. if len(os.Args) < 2 {
  12. log.Fatalf("no namespace path provided")
  13. }
  14. if err := createNamespaceFile(os.Args[1]); err != nil {
  15. log.Fatal(err)
  16. }
  17. if err := syscall.Unshare(syscall.CLONE_NEWNET); err != nil {
  18. log.Fatal(err)
  19. }
  20. if err := loopbackUp(); err != nil {
  21. log.Fatal(err)
  22. }
  23. if err := syscall.Mount("/proc/self/ns/net", os.Args[1], "bind", syscall.MS_BIND, ""); err != nil {
  24. log.Fatal(err)
  25. }
  26. os.Exit(0)
  27. }
  28. func createNamespaceFile(path string) (err error) {
  29. var f *os.File
  30. if f, err = os.Create(path); err == nil {
  31. f.Close()
  32. }
  33. return err
  34. }
  35. func loopbackUp() error {
  36. iface, err := netlink.LinkByName("lo")
  37. if err != nil {
  38. return err
  39. }
  40. return netlink.LinkSetUp(iface)
  41. }