mirror of
https://github.com/vishvananda/netns
synced 2024-12-21 14:40:01 +00:00
Simple network namespace handling for go.
4c46424d73
> nerdctl uses this package for netns, for finch one of our customer requested it for their systems which uses nerdctl to create a container and have a custom network namespace the container connects to. Signed-off-by: Shubharanshu Mahapatra <shubhum@amazon.com> |
||
---|---|---|
.github | ||
.golangci.yml | ||
.yamllint.yml | ||
doc.go | ||
go.mod | ||
go.sum | ||
LICENSE | ||
netns_linux_test.go | ||
netns_linux.go | ||
netns_others.go | ||
nshandle_linux.go | ||
nshandle_others.go | ||
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)
}