Akihiro Suda 5a1b06d7fd rerun vndr 8 lat temu
..
LICENSE f2614f2107 project: use vndr for vendoring 8 lat temu
README.md 5a1b06d7fd rerun vndr 8 lat temu
netns.go f2614f2107 project: use vndr for vendoring 8 lat temu
netns_linux.go f2614f2107 project: use vndr for vendoring 8 lat temu
netns_linux_386.go f2614f2107 project: use vndr for vendoring 8 lat temu
netns_linux_amd64.go f2614f2107 project: use vndr for vendoring 8 lat temu
netns_linux_arm.go f2614f2107 project: use vndr for vendoring 8 lat temu
netns_linux_arm64.go f2614f2107 project: use vndr for vendoring 8 lat temu
netns_linux_ppc64le.go f2614f2107 project: use vndr for vendoring 8 lat temu
netns_linux_s390x.go f2614f2107 project: use vndr for vendoring 8 lat temu
netns_unspecified.go f2614f2107 project: use vndr for vendoring 8 lat temu

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 (
    "net"
    "runtime"
    "github.com/vishvananada/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 tne network namespace
    ifaces, _ := net.Interfaces()
    fmt.Printf("Interfaces: %v\n", ifaces)

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