使用golang开发mqtt服务压力测试工具

package main

import (
    "flag"
    "fmt"
    "sync"
    "time"
    //导入mqtt包
    MQTT "github.com/eclipse/paho.mqtt.golang"
)

var f MQTT.MessageHandler = func(client MQTT.Client, msg MQTT.Message) {
    fmt.Printf("TOPIC: %s\n", msg.Topic())
    fmt.Printf("MSG: %s\n", msg.Payload())
}
var fail_nums int = 0

func main() {
    //生成连接的客户端数
    c := flag.Uint64("n", 3000, "client nums")
    flag.Parse()
    nums := int(*c)
    wg := sync.WaitGroup{}
    for i := 0; i < nums; i++ {
        wg.Add(1)
        time.Sleep(5 * time.Millisecond)
        go createTask(i, &wg)
    }
    wg.Wait()
}

func createTask(taskId int, wg *sync.WaitGroup) {
    defer wg.Done()
    opts := MQTT.NewClientOptions().AddBroker("tcp://192.168.1.110:1883").SetUsername("test").SetPassword("test")
    opts.SetClientID(fmt.Sprintf("go-simple-client:%d-%d", taskId, time.Now().Unix()))
    opts.SetDefaultPublishHandler(f)
    opts.SetConnectTimeout(time.Duration(60) * time.Second)

    //创建连接
    c := MQTT.NewClient(opts)

    if token := c.Connect(); token.WaitTimeout(time.Duration(60)*time.Second) && token.Wait() && token.Error() != nil {
        fail_nums++
        fmt.Printf("taskId:%d,fail_nums:%d,error:%s \n", taskId, fail_nums, token.Error())
        return
    }

    //每隔5秒向topic发送一条消息
    i := 0
    for {
        i++
        time.Sleep(time.Duration(5) * time.Second)
        text := fmt.Sprintf("this is msg #%d! from task:%d", i, taskId)
        token := c.Publish("test", 1, false, text)
        token.Wait()
    }

    c.Disconnect(250)
    fmt.Println("task ok!!")
}

  

package main

import (
	"bytes"
	"crypto/rand"
	"crypto/tls"
	"encoding/json"
	"flag"
	"fmt"
	"math/big"
	"sync"
	"time"

	MQTT "github.com/eclipse/paho.mqtt.golang"
)

type Device struct {
	ID                  int     `json:"id"`
	Mac                 string  `json:"mac"`
	Name                string  `json:"name"`
	ProductType         string  `json:"product_type"`
	Lang                string  `json:"lang"`
	IP                  string  `json:"ip"`
	IP2                 string  `json:"ip2"`
	Gateway             string  `json:"gateway"`
	Gateway2            string  `json:"gateway2"`
	Netmask             string  `json:"netmask"`
	Netmask2            string  `json:"netmask2"`
	Inet                string  `json:"inet"`
	AreaID              int     `json:"area_id"`
	State               int     `json:"state"`
	RestartTime         string  `json:"restart_time"`
	LiveDetection       int     `json:"live_detection"`
	FeverHigh           float32 `json:"fever_high"`
	FeverLow            float32 `json:"fever_low"`
	TempAdd             float32 `json:"temp_add"`
	FaceRecThred        float32 `json:"face_rec_thred"`
	FaceMinThred        float32 `json:"half_face_rec_thred"`
	GateIsOpen          int     `json:"gate_is_open"`
	GateOpenType        int     `json:"gate_open_type"`
	GateOpenDur         int     `json:"gate_open_dur"`
	GateOpenCondition   int     `json:"gate_open_condition"`
	IoType              int     `json:"io_type"`
	IDThred             float32 `json:"id_thred"`
	VisitorGateOpenType int     `json:"visitor_gate_open_type"`
	VisitorCardNo       string  `json:"visitor_card_no"`
	Volume              int     `json:"volume"`
	ScreenOff           int     `json:"screen_off"`
	ScreenFillLight     int     `json:"screen_fill_light"`
	SuccessMsg          string  `json:"success_msg"`
	FailMsg             string  `json:"fail_msg"`
	Version             string  `json:"version"`
	LogSnap             int     `json:"log_snap"`
	SyncPeriod          int     `json:"sync_period"`
	FlowKeep            int     `json:"flow_keep"`
	LastConnect         string  `json:"last_connect"`
	LastModify          string  `json:"last_modify"`
	CreateTime          string  `json:"create_time"`
	Online              bool    `json:"online"`
	GateVoltage         int     `json:"gate_voltage"`
	GateAlarm           int     `json:"gate_alarm"`
	GateAlarmSec        int     `json:"gate_alarm_sec"`
	Brightness          int     `json:"brightness"`
	AutoBacklightCom    int     `json:"auto_backlight_com"`
	AudioUpload         string  `json:"audio_upload"`
	OSVersion           string  `json:"os_version"`
	APKversion          string  `json:"apk_version"`
	MyVersion           string  `json:"funpacs_version"`
}

type DeviceState struct {
	CPU        float32 `json:"CPU"`
	CPUTemp    float32 `json:"CPUTemp"`
	Memory     int64   `json:"Memory"`
	Runtime    int64   `json:"runtime"`
	APK        int     `json:"APK"`
	APKRuntime int64   `json:"APKRuntime"`
	NPU        bool    `json:"NPU"`
}

type MqttMsg struct {
	Mac         string      `json:"mac"`
	Cate        string      `json:"cate"`
	SubCate     int         `json:"subCate"`
	Cmd         string      `json:"cmd"`
	SN          uint64      `json:"SN"`
	Time        int64       `json:"time"`
	DeviceData  Device      `json:"deviceData"`
	DeviceState DeviceState `json:"deviceState"`
}

var f MQTT.MessageHandler = func(client MQTT.Client, msg MQTT.Message) {
	fmt.Printf("TOPIC: %s\n", msg.Topic())
	fmt.Printf("MSG: %s\n", msg.Payload())
}

func CreateRandomString(len int) string {
	var container string
	var str = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890"
	b := bytes.NewBufferString(str)
	length := b.Len()
	bigInt := big.NewInt(int64(length))
	for i := 0; i < len; i++ {
		randomInt, _ := rand.Int(rand.Reader, bigInt)
		container += string(str[randomInt.Int64()])
	}
	return container
}

var fail_nums int = 0
var gMyDevice Device

func main() {
	fmt.Println("PACS test start")

	//生成连接的客户端数
	c := flag.Uint64("n", 1, "client nums")
	flag.Parse()
	nums := int(*c)

	fmt.Println("Client number: ", nums)

	wg := sync.WaitGroup{}
	for i := 0; i < nums; i++ {
		wg.Add(1)
		time.Sleep(5 * time.Millisecond)
		go createTask(i, &wg)
	}
	wg.Wait()
}

func createTask(taskId int, wg *sync.WaitGroup) {
	defer wg.Done()
	opts := MQTT.NewClientOptions().AddBroker("tls://192.168.6.123:8883").SetUsername("superpacsmqtt").SetPassword("mqttpacssuper")
	opts.SetClientID(fmt.Sprintf("pacs-test-client:%d-%d", taskId, time.Now().Unix()))
	opts.SetTLSConfig(&tls.Config{InsecureSkipVerify: true})
	opts.SetDefaultPublishHandler(f)
	opts.SetConnectTimeout(time.Duration(60) * time.Second)

	//创建连接
	c := MQTT.NewClient(opts)

	if token := c.Connect(); token.WaitTimeout(time.Duration(60)*time.Second) && token.Wait() && token.Error() != nil {
		fail_nums++
		fmt.Printf("taskId:%d,fail_nums:%d,error:%s \n", taskId, fail_nums, token.Error())
		return
	}

	gServerRunTime := time.Now().Unix()
	//mac := "TEST" + strconv.Itoa(taskId)
	mac := "TEST" + CreateRandomString(8)

	topic := "hub/funpacs/u/" + mac

	gMyDevice.ID = taskId
	gMyDevice.Mac = mac
	gMyDevice.Name = mac
	gMyDevice.ProductType = "MS-5738"
	gMyDevice.Lang = "en"
	gMyDevice.State = 1
	gMyDevice.MyVersion = "1.0.68"

	data := MqttMsg{SN: 1, Time: time.Now().Unix(), Mac: mac, Cate: "status", Cmd: "deviceData", DeviceData: gMyDevice}
	jsDat, _ := json.Marshal(&data)
	msg := string(jsDat)
	fmt.Println(msg)
	c.Publish(topic, 1, false, msg)

	//每隔5秒向topic发送一条消息
	i := 0
	for {
		i++
		time.Sleep(time.Duration(5) * time.Second)

		runtime := time.Now().Unix() - gServerRunTime
		ds := DeviceState{Runtime: runtime, APK: i}

		sdata := MqttMsg{SN: 1, Time: time.Now().Unix(), Mac: mac, Cate: "status", Cmd: "deviceStat", DeviceState: ds}
		jsDat, _ := json.Marshal(&sdata)
		msg := string(jsDat)
		fmt.Println(msg)
		token := c.Publish(topic, 1, false, msg)
		token.Wait()
	}

}

  

posted on 2021-11-12 11:18  清明-心若淡定  阅读(948)  评论(0编辑  收藏  举报