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

栏目: Go · 发布时间: 6年前

内容简介:最近公司项目需要优化mqtt服务,为了更全面的测试mqtt服务性能模拟正式环境,这里使用golang的写了一个测试工具代码如下:

最近公司项目需要优化mqtt服务,为了更全面的测试mqtt服务性能模拟正式环境,这里使用golang的写了一个测试工具

代码如下:

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!!")
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

推荐系统实践

推荐系统实践

项亮 / 人民邮电出版社 / 2012-6-1 / 49.00元

内容简介: 随着信息技术和互联网的发展,人们逐渐从信息匮乏的时代走入了信息过载(information overload)的时代 。在这个时代,无论是信息消费者还是信息生产者都遇到了很大的挑战:对于信息消费者,从大量信息中找到自己感兴趣的信息是一件非常困难的事情;对于信息生产者,让自己生产的信息脱颖而出,受到广大用户的关注,也是一件非常困难的事情。推荐系统就是解决这一矛盾的重要工具。推荐系统......一起来看看 《推荐系统实践》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

MD5 加密
MD5 加密

MD5 加密工具