《零入门kubernetes网络实战》视频专栏地址
https://www.ixigua.com/7193641905282875942
本篇文章视频地址(稍后上传)
本篇文章主要是想通过golang编程来实现,为veth pair链接的网络命名空间添加网卡,配置veth pair的IP
即,使用代码创建一对veth pair,将其中一端放入到某个网络命名空间下
一台centos虚拟机
# 查看操作系统版本
cat /etc/centos-release
# 内核版本
uname -a
uname -r
# 查看网卡信息
ip a s eth0
打开xshell一个终端,输入下面的命令:
相关命令如下
ip netns list
ip netns add ns1
ip netns exec ns1 ip a s
ip netns exec ns1 sh
echo $$
获取到ns1使用的进程号
此终端,不要关闭。
重新再打开一个终端,编译,运行下面的测试代码。
3、编写代码,为ns1网络命名空间,添加veth2虚拟网卡,并设置IP |
下面代码的主要过程:
创建veth pair —>获取ns1的进程号—>将veth2网卡移动到ns1网络命名空间里—>获取当前二进制文件所在主网络命名空间—>切换到ns1网络命名空间里—>给veth2网卡设置IP—>再切换到主网络命名空间里—>给veth1网卡设置IP
package main
import (
"flag"
"fmt"
"github.com/vishvananda/netlink"
"github.com/vishvananda/netns"
"golang.org/x/sys/unix"
"net"
"os"
"runtime"
)
const (
veth1Name = "veth1"
veth2Name = "veth2"
)
var pid int
func main() {
flag.IntVar(&pid, "pid", 0, "Use -pid xxx")
flag.Parse()
l, err := netlink.LinkByName(veth1Name)
if err == nil {
netlink.LinkDel(l)
}
vethpeer := &netlink.Veth{
LinkAttrs: netlink.LinkAttrs{
Name: veth1Name,
Flags: net.FlagUp,
MTU: 1500,
},
PeerName: veth2Name,
}
err = netlink.LinkAdd(vethpeer)
if err != nil {
panic(err)
}
nsPath := fmt.Sprintf("/proc/%d/ns", pid)
ns, err := netns.GetFromPath(fmt.Sprintf("%s/%s", nsPath, "net"))
if err != nil {
panic(err)
}
defer ns.Close()
veth2, err := netlink.LinkByName(veth2Name)
if err != nil {
panic(err)
}
err = netlink.LinkSetNsFd(veth2, int(ns))
if err != nil {
panic(err)
}
hostNS, err := GetCurrentNS()
if err != nil {
panic(err)
}
err = netns.Set(ns)
if err != nil {
panic(err)
}
veth2, err = netlink.LinkByName(veth2Name)
if err != nil {
panic(err)
}
addr, _ := netlink.ParseAddr("10.244.1.2/24")
err = netlink.AddrAdd(veth2, addr)
if err != nil {
panic(err)
}
err = netlink.LinkSetUp(veth2)
if err != nil {
panic(err)
}
err = unix.Setns(int(hostNS.Fd()), unix.CLONE_NEWNET)
if err != nil {
panic(err)
}
addr, _ = netlink.ParseAddr("10.244.1.3/24")
veth1, err := netlink.LinkByName(veth1Name)
if err != nil {
panic(err)
}
err = netlink.AddrAdd(veth1, addr)
if err != nil {
panic(err)
}
netlink.LinkSetUp(veth1)
}
func GetCurrentNS() (*os.File, error) {
runtime.LockOSThread()
defer runtime.UnlockOSThread()
return GetNS(getCurrentThreadNetNSPath())
}
func getCurrentThreadNetNSPath() string {
currentNetNSPath := fmt.Sprintf("/proc/%d/task/%d/ns/net", os.Getpid(), unix.Gettid())
return currentNetNSPath
}
func GetNS(nspath string) (*os.File, error) {
fd, err := os.Open(nspath)
if err != nil {
return nil, err
}
return fd, nil
}
build:
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -o createveth main.go
scp:
scp createveth root@10.211.55.122:/root
all:
make build && make scp
执行运行
make all
将编译后二进制文件,上传到目标服务器上
5、在服务器上,运行createveth二进制文件 |
本篇文章最主要的几点:(仅供参考)
这样的话,就实现了为某个网络命名空间,添加虚拟网卡的目的。
既然,可以给ip netns创建的网络命名空间,添加虚拟网卡,
那么,能不能为docker环境下的容器,添加额外的虚拟网卡呢?
实现,多网络功能?
类似于multus-cni
<<零入门kubernetes网络实战>>技术专栏之文章目录