moby--moby/vendor/github.com/vishvananda/netns
Sebastiaan van Stijn 818bad6ef2
vendor: vishvananda/netns db3c7e526aae966c4ccfa6c8189b693d6ac5d202
full diff: 0a2b9b5464...db3c7e526a

- Use golang.org/x/sys/unix instead of syscall
- Set O_CLOEXEC when opening a network namespace
    - Fixes "the container‘s netns fds leak, causing the container netns to not
      clean up successfully after the container stops"
- Allows to create and delete named network namespaces

Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
2020-07-28 21:26:13 +02:00
..
LICENSE
README.md Update modules to support riscv64 2019-06-29 18:45:42 +00:00
go.mod vendor: vishvananda/netns db3c7e526aae966c4ccfa6c8189b693d6ac5d202 2020-07-28 21:26:13 +02:00
netns.go vendor: vishvananda/netns db3c7e526aae966c4ccfa6c8189b693d6ac5d202 2020-07-28 21:26:13 +02:00
netns_linux.go vendor: vishvananda/netns db3c7e526aae966c4ccfa6c8189b693d6ac5d202 2020-07-28 21:26:13 +02:00
netns_unspecified.go bump libnetwork. vishvananda/netlink 1.0, vishvananda/netns 2019-06-25 14:10:15 +02:00

README.md

netns - network namespaces in go

The netns package provides an ultra-simple interface for handling network namespaces in go. Changing namespaces requires elevated privileges, so in most cases this code needs to be run as root.

Local Build and Test

You can use go get command:

go get github.com/vishvananda/netns

Testing (requires root):

sudo -E go test github.com/vishvananda/netns

Example

package main

import (
    "fmt"
    "net"
    "runtime"
    "github.com/vishvananda/netns"
)

func main() {
    // Lock the OS Thread so we don't accidentally switch namespaces
    runtime.LockOSThread()
    defer runtime.UnlockOSThread()

    // Save the current network namespace
    origns, _ := netns.Get()
    defer origns.Close()

    // Create a new network namespace
    newns, _ := netns.New()
    defer newns.Close()

    // Do something with the network namespace
    ifaces, _ := net.Interfaces()
    fmt.Printf("Interfaces: %v\n", ifaces)

    // Switch back to the original namespace
    netns.Set(origns)
}