Simple network namespace handling for go.
Go to file
Vish Ishaya 604eaf189e Merge pull request #9 from brahmaroutu/support_ibm_z
add support from IBM Z architecture
2015-07-10 15:24:25 -07:00
LICENSE Initial commit of netns package 2014-08-31 14:20:31 -07:00
README.md Initial commit of netns package 2014-08-31 14:20:31 -07:00
netns.go Add Build Flags 2015-05-20 19:27:24 +01:00
netns_linux.go Add GetFromPath to construct NsHandle from any path 2015-06-07 13:25:43 -07:00
netns_linux_386.go Add Build Flags 2015-05-20 19:27:24 +01:00
netns_linux_amd64.go Add Build Flags 2015-05-20 19:27:24 +01:00
netns_linux_arm.go Using proper value for SYS_SETNS 2015-06-30 22:23:27 +02:00
netns_linux_arm64.go Add linux arm64 support 2015-06-17 13:33:40 -07:00
netns_linux_ppc64le.go Add syscall id for Powerpc(ppc64) Little Endian(LE) architecture 2015-05-25 19:06:15 +00:00
netns_linux_s390x.go add support from IBM Z architecture 2015-07-10 18:57:36 +00:00
netns_test.go Fix handling of namespaces in multi-threaded processes. 2015-01-26 16:46:24 -08:00
netns_unspecified.go Add Build Flags 2015-05-20 19:27:24 +01: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 (
    "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)
}