零入门kubernetes网络实战-20->golang编程syscall操作tun设备介绍
创始人
2024-05-29 19:33:32
0

《零入门kubernetes网络实战》视频专栏地址
https://www.ixigua.com/7193641905282875942

本篇文章视频地址(稍后上传)


本篇文章主要是使用golang自带的syscall包来创建tun类型的虚拟网络设备。

注意:

目前只能使用syscall包来创建tun类型的虚拟设备。

tun虚拟网卡设备的启动,IP配置,路由配置可能需要其他方式实现。

比方说通过netlink包方式来实现。

1、golang代码

package mainimport ("bytes""fmt""github.com/vishvananda/netlink""net""os""syscall""unsafe"
)const (tunDevice  = "/dev/net/tun"ifnameSize = 16
)type ifreqFlags struct {IfrnName  [ifnameSize]byteIfruFlags uint16
}func ioctl(fd int, request, argp uintptr) error {_, _, errno := syscall.Syscall(syscall.SYS_IOCTL, uintptr(fd), request, argp)if errno != 0 {return fmt.Errorf("ioctl failed with '%s'", errno)}return nil
}func fromZeroTerm(s []byte) string {return string(bytes.TrimRight(s, "\000"))
}func OpenTun(name string) (*os.File, string, error) {tun, err := os.OpenFile(tunDevice, os.O_RDWR, 0)if err != nil {fmt.Printf("----OpenTun----err:%v\n", err.Error())return nil, "", err}var ifr ifreqFlagscopy(ifr.IfrnName[:len(ifr.IfrnName)-1], []byte(name+"\000"))ifr.IfruFlags = syscall.IFF_TUN | syscall.IFF_NO_PIerr = ioctl(int(tun.Fd()), syscall.TUNSETIFF, uintptr(unsafe.Pointer(&ifr)))if err != nil {fmt.Printf("----OpenTun---ioctl----err:%v\n", err.Error())return nil, "", err}// 1,表示,程序结束后,创建的tun设备依旧在。// 默认为0,程序结束后,创建的tun设备就自动删除了err = ioctl(int(tun.Fd()), syscall.TUNSETPERSIST, 1)if err != nil {fmt.Printf("----OpenTun---ioctl---persist---err:%v\n", err.Error())return nil, "", err}ifname := fromZeroTerm(ifr.IfrnName[:ifnameSize])return tun, ifname, nil
}func configureIface(ifname string, ipn *net.IPNet, mtu int) error {iface, err := netlink.LinkByName(ifname)if err != nil {return fmt.Errorf("failed to lookup interface %v", ifname)}err = netlink.AddrAdd(iface, &netlink.Addr{IPNet: ipn, Label: ""})if err != nil {return fmt.Errorf("failed to add IP address %v to %v: %v", ipn.String(), ifname, err)}err = netlink.LinkSetMTU(iface, mtu)if err != nil {return fmt.Errorf("failed to set MTU for %v: %v", ifname, err)}err = netlink.LinkSetUp(iface)if err != nil {return fmt.Errorf("failed to set interface %v to UP state: %v", ifname, err)}err = netlink.RouteAdd(&netlink.Route{LinkIndex: iface.Attrs().Index,Scope:     netlink.SCOPE_UNIVERSE,Dst:       ipn,})if err != nil && err != syscall.EEXIST {return fmt.Errorf("failed to add route (%v -> %v): %v", ipn.String(), ifname, err)}return nil
}func main() {tun, fname, err := OpenTun("flannel-test")if err != nil {fmt.Printf("----Create--Tun------err:%v\n", err.Error())return}fmt.Printf("-----create---tun---name:%v\tfname:%v\n", tun.Name(), fname)_, ipn, _ := net.ParseCIDR("10.244.1.0/24")configureIface(fname, ipn, 1500)//time.Sleep(time.Hour)
}

在这里插入图片描述

2、本地编译

Makefile

build:CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build main.goscp:scp main root@10.211.55.122:/rootall:make build && make scp

在这里插入图片描述

3、远程服务器测试

route -n
å
ip a s | grep 10.211ip link sh flannel-test./main ip link sh flannel-testip a sh flannel-testroute -n

在这里插入图片描述

ip tuntap listethtool -i flannel-testethtool -i eth0

在这里插入图片描述

4、测试虚拟网卡flannel-test的连通性

在这里插入图片描述

5、/dev/net/tun: not pollable

在这里插入图片描述

read /dev/net/tun: not pollable

其实,曾经还出现过,此代码存在的情况下,也会报上面的错误。

可惜,已经不知道如何恢复异常场景了。


点击 下面 返回 专栏目录

<<零入门kubernetes网络实战>>技术专栏之文章目录

相关内容

热门资讯

冷库补贴政策2020标准(大学... 农产品物流越来越受到国家的重视。在国务院发布的《物流业发展中长期规划(2014—2020年)》(以下...
公司创业初心是什么(创业初心怎... 大家好,我是Xi帅。从2010年开始,我开始做跨境电商,速卖通,易趣,亚马逊,独立站.可能要追溯到我...
加盟项目培训教育,培训创业 加... 近年来,投资加盟行业的关注度不断上升。随着国家宏观政策推动的创业者数量不断增加,餐饮、服装、教育等行...
创新创业应该提问什么(创新创业... 近日,由瑞安房地产和中信泰富地产共同出资的光谷创新世界项目举行了创新创业中心启动签约仪式。活动地点武...
创新创业课程思维导图,创业思维... 上述导图在公众号的传送门:请点击文章末尾的“了解更多”。每周四和周日,思维导图和你见面,诺特曼微信官...
多地“超长待机”桑拿天怎么过?... 转自:中国环境网眼下,我国大部地区正经历今年以来范围最大、强度最强的高温天气,部分地区超过40摄氏度...
田栩宁网传女友否认身份 转自:河北新闻网 【#田栩宁网传女友否认身份# 】#经纪...
万科于大华银行的两笔贷款获延期... 观点网讯:7月4日,万科企业股份有限公司发布关于担保进展情况的公告。公告显示,2022年,万科控股子...
许正宇:香港完善数字资产监管 ... 7月4日,在香港数字金融大奖2025颁奖典礼上,香港财经事务及库务局局长许正宇表示,香港正大力推动数...
汪俊林年中定调郎酒营销:强调“... 7月4日,云酒头条自郎酒股份官微获悉,郎酒于当日召开全国经销商年中大会,郎酒集团董事长汪俊林作“坚定...