Simple network namespace handling for go.
Go to file
Sebastiaan van Stijn 1104d961a9 gha: add golangci-lint
Linting is disabled on Windows, as the current build-tags do not
properly exclude non-unix platforms;

    level=info msg="[runner/filename_unadjuster] Pre-built 0 adjustments in 1.0348ms"
    Error: level=error msg="[linters_context] typechecking error: D:\\a\\netns\\netns\\netns.go:28:18: Stat_t not declared by package unix"
    Error: level=error msg="[linters_context] typechecking error: D:\\a\\netns\\netns\\netns.go:29:17: Fstat not declared by package unix"
    Error: level=error msg="[linters_context] typechecking error: D:\\a\\netns\\netns\\netns.go:32:17: Fstat not declared by package unix"
    Error: level=error msg="[linters_context] typechecking error: D:\\a\\netns\\netns\\netns.go:43:13: Stat_t not declared by package unix"
    Error: level=error msg="[linters_context] typechecking error: D:\\a\\netns\\netns\\netns.go:44:17: Fstat not declared by package unix"
    Error: level=error msg="[linters_context] typechecking error: D:\\a\\netns\\netns\\netns.go:56:13: Stat_t not declared by package unix"
    Error: level=error msg="[linters_context] typechecking error: D:\\a\\netns\\netns\\netns.go:57:17: Fstat not declared by package unix"
    Error: level=error msg="[linters_context] typechecking error: D:\\a\\netns\\netns\\netns.go:71:17: Close not declared by package unix"

Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
2023-01-18 13:02:58 -08:00
.github gha: add golangci-lint 2023-01-18 13:02:58 -08:00
.golangci.yml gha: add golangci-lint 2023-01-18 13:02:58 -08:00
LICENSE Initial commit of netns package 2014-08-31 14:20:31 -07:00
README.md Drop note about `go` `1.10` compatibility 2023-01-13 12:20:54 -08:00
doc.go move package description to a doc.go 2023-01-13 09:56:59 -08:00
go.mod go.mod: update minimum version to go1.17 2023-01-13 12:18:28 -08:00
go.sum chore(deps): bump golang.org/x/sys to v0.2.0 2023-01-13 09:58:21 -08:00
netns_linux.go go.mod: update minimum version to go1.17 2023-01-13 12:18:28 -08:00
netns_linux_test.go fix unhandled error in TestGetNewSetDelete 2023-01-13 09:56:59 -08:00
netns_others.go make deprecated consts an alias, and don't use internally 2023-01-13 09:56:59 -08:00
nshandle_linux.go fix build-tags for non-linux platforms 2023-01-13 09:56:59 -08:00
nshandle_others.go fix build-tags for non-linux platforms 2023-01-13 09:56:59 -08: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)
}