首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >可以在Linux中不指定接口来接收原始以太网帧吗?

可以在Linux中不指定接口来接收原始以太网帧吗?
EN

Stack Overflow用户
提问于 2022-01-11 03:15:00
回答 1查看 398关注 0票数 1

我使用mdlayher (golang)库来处理原始以太网帧,以便在网络设备上接收和处理LLDP数据包。我希望监视LLDP帧的大量接口(最多128)。

在Linux 不要相信这是必需的中指定一个接口来捕获设备数据,但我可能错了。是否可以通过绑定到go中的AF_PACKET来跨所有接口接收原始以太网帧?也就是说,是否有办法在raw.ListenPacket中指定通配符接口,还是我最好为每个接口创建一个新的goroutine?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-01-11 18:22:28

是的你可以。我相信这就是你想要的:

代码语言:javascript
复制
package main

import (
    "fmt"
    "net"
    "os"
    "syscall"
)

func main() {
    fd, err := syscall.Socket(syscall.AF_PACKET, syscall.SOCK_RAW, int(htons(syscall.ETH_P_ALL)))
    if err != nil {
        fmt.Fprintf(os.Stderr, "syscall socket: %s", err.Error())
        os.Exit(1)
    }

    // Make a 32KB buffer
    buf := make([]byte, 1<<16)
    for {
        len, sockaddr, err := syscall.Recvfrom(fd, buf, 0)
        if err != nil {
            fmt.Fprintf(os.Stderr, "syscall recvfrom: %s", err.Error())
            os.Exit(1)
        }

        if llsa, ok := sockaddr.(*syscall.SockaddrLinklayer); ok {
            inter, err := net.InterfaceByIndex(llsa.Ifindex)
            if err != nil {
                fmt.Fprintf(os.Stderr, "interface from ifindex: %s", err.Error())
                os.Exit(1)
            }
            fmt.Print(inter.Name + ": ")
        }

        fmt.Printf("% X\n", buf[:len])
    }
}

// htons converts a short (uint16) from host-to-network byte order.
func htons(i uint16) uint16 {
    return (i<<8)&0xff00 | i>>8
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70661217

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档