> can only handle up to 250Mbps-ish traffic I'm not familiar with gopacket, but I have seen multiple occasions where logging to a file or stdout became a bottleneck. Your code snippet is logging on every packet which seems excessive. Try logging with less frequency and, if using stdout, consider using a log destination with different buffering characteristics like a file or syslog over UDP.
On Fri, May 26, 2017 at 3:59 PM Egon <egonel...@gmail.com> wrote: > On Friday, 26 May 2017 20:51:55 UTC+3, Chun Zhang wrote: >> >> Good point. >> as a comparison: tcpdump -w /dev/null can handle up to 750Mbps, where >> sending machine's speed limit reached. I think it should be able to handle >> line rate. >> >> Are those two packages lighter/faster than gopacket? >> > > Nevermind, just noticed... gopacket/pcap is a fork of akrennmair/gopcap > > Anyways, to get more information on what is taking time in your program > see https://blog.golang.org/profiling-go-programs > > Maybe try something like this: > > handle, err := pcap.OpenLive(device, snapshot_len, promiscuous, timeout) > > // ... > for { > data, ci, err := handle.ZeroCopyReadPacketData() > // ... > > > This should remove allocations from critical path. > > *PS: code untested and may contain typos :P* > > >> >> >> Thanks, >> Chun >> >> On Friday, May 26, 2017 at 12:37:55 PM UTC-4, Egon wrote: >>> >>> As a baseline measurement I suggest writing the same code in C; this >>> shows how much your VM / config / machine can handle. >>> >>> With gopacket -- use src.NextPacket instead of Packets. >>> >>> There are also: https://github.com/akrennmair/gopcap and >>> https://github.com/miekg/pcap >>> >>> + Egon >>> >>> On Friday, 26 May 2017 19:01:20 UTC+3, Chun Zhang wrote: >>>> >>>> Hi, All, >>>> >>>> I am trying to write a small program to handle packets coming from a >>>> GigE wire. The testing code snip is as below. >>>> >>>> The problem I am facing is that this is extremely slow, can only handle >>>> up to 250Mbps-ish traffic with normal ipv4 sized packets, anything above >>>> that resulting significant packet drop. Note that I am doing nothing with >>>> the packet at this moment. If I try to do any packet processing, then >>>> apparently it gets slower. >>>> >>>> Has anybody measured the efficiency of the gopacket package? Is there >>>> any other faster alternatives? >>>> >>>> PS: the host machine is an ubuntu VM with 12-core and 12G memory, but >>>> looks only 2 cores are used for this program. >>>> >>>> Thanks, >>>> Chun >>>> >>>> >>>> >>>> // Open device >>>> handle, err = pcap.OpenLive(device, snapshot_len, promiscuous, timeout) >>>> if err == nil { >>>> Info.Println("Open interface ", device, "successfully") >>>> >>>> } >>>> defer handle.Close() >>>> >>>> >>>> //fmt.Println("In the deafult reading case ", time.Now()) >>>> // Use the handle as a packet source to process all packets >>>> packetSource := gopacket.NewPacketSource(handle, handle.LinkType()) >>>> Info.Println("pcketsourc is ", packetSource, time.Now()) >>>> for packet := range packetSource.Packets() { >>>> >>>> Debug.Println("-------------------------------------------------------------------") >>>> count++ >>>> Warning.Println("packet count ", count) >>>> >>>> // write to a pcap for testing >>>> /*err = w.WritePacket(packet.Metadata().CaptureInfo, >>>> packet.Data()) >>>> if err != nil { >>>> fmt.Println(err) >>>> }*/ >>>> >>>> continue >>>> >>>> -- > You received this message because you are subscribed to the Google Groups > "golang-nuts" group. > To unsubscribe from this group and stop receiving emails from it, send an > email to golang-nuts+unsubscr...@googlegroups.com. > For more options, visit https://groups.google.com/d/optout. > -- You received this message because you are subscribed to the Google Groups "golang-nuts" group. To unsubscribe from this group and stop receiving emails from it, send an email to golang-nuts+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.