【golang】发送自定义数量的UDP报文

package main

import (
	"net"
	"fmt"
	"flag"
	"context"
	"time"
)

const (
	IP = "192.168.0.245"
	PORT = "514"
)

var (
	number int
	count int
	timer bool
	mesg = "<10>Apr 29 17:59:08 localhost t_syslog[29121]: This is a syslog test message generated by program './t_syslog'"
)

func SendMesg(number, cnt int, timer bool) (err error) {
	Addr := IP + ":" + PORT
	conn, err := net.Dial("udp", Addr)
	if err != nil {
		fmt.Println("Dial() err:", err)
		return err
	}
	defer conn.Close()

	ch := make(chan bool)
	ctx, cancel := context.WithCancel(context.Background())

	var sendNum int = 0
	go func() {
		select {
		case <-time.After(1 * time.Second):
			fmt.Printf("In a second, %d messages send\n", sendNum)
		case <-ctx.Done():
			fmt.Printf("Less than a second, %d messages send!\n", sendNum)
		}
		ch <- true
	}()

	sendData := []byte(mesg)
	for i := 0; i < number; i++ {
		_, err = conn.Write(sendData)
		if err != nil {
			fmt.Println("Write() err:", err)
			break
		}
		sendNum++
	}
	if !timer {
		cancel()
	}
	<-ch 
	return err
}

func main() {
	flag.IntVar(&number, "n", 100, "number of message to send")
	flag.IntVar(&count, "c", 1, "frequency")
	flag.BoolVar(&timer, "t", false, "send in a second")
	flag.Parse()

	t1 := time.Now()
	for i := 0; i < count; i++ {
		err := SendMesg(number, i, timer)
		if err != nil {
			break
		}
	}
	fmt.Println("Total sending time:", time.Since(t1))
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值