Skip to content

Latest commit

 

History

History
227 lines (139 loc) · 7.69 KB

mqtt-config.md

File metadata and controls

227 lines (139 loc) · 7.69 KB

mqttclient配置及裁剪工具

  • MQTT_TOPIC_LEN_MAX

    配置客户端支持最大的主题名长度,主题是支持通配符的,如果主题太长则会被截断,默认值为64。

        #define     MQTT_TOPIC_LEN_MAX                  64
  • MQTT_ACK_HANDLER_NUM_MAX

    配置mqtt等待应答列表的最大记录个数,对于qos1、qos2服务质量有要求的可以将其设置大一点,当然也必须资源跟得上,它主要是保证qos1、qos2的mqtt报文能准确到达服务器,默认值为64。

        #define     MQTT_ACK_HANDLER_NUM_MAX            64
  • MQTT_DEFAULT_BUF_SIZE

    默认的读写数据缓冲区的大小,根据要收发数据量修改即可,默认值为1024。

        #define     MQTT_DEFAULT_BUF_SIZE               1024
  • MQTT_DEFAULT_CMD_TIMEOUT

    默认的命令超时,它主要是用于socket读写超时(还包括等待响应的时间、重连等待时间等),默认值为5000。

        #define     MQTT_DEFAULT_CMD_TIMEOUT            5000
  • MQTT_MAX_CMD_TIMEOUT

    设置最大的命令超时时间,默认值是20000。

        #define     MQTT_MAX_CMD_TIMEOUT                20000
  • MQTT_MIN_CMD_TIMEOUT

    设置最小的命令超时时间,默认值是1000。

        #define     MQTT_MIN_CMD_TIMEOUT                1000
  • MQTT_KEEP_ALIVE_INTERVAL

    设置默认的保活时间,它主要是保证MQTT客户端与服务器的保持活性连接,单位为,默认值为50。比如MQTT客户端与服务器在指定时间间隔内没有发送数据,有没有接收到数据,此时MQTT客户端会发送一个心跳包,确认一下这个连接是否存在,如果收到服务器的应答,那么说明这个连接还是存在的,可以随时收发数据,而如果不存在了,就尝试重连或者清除会话。

        #define     MQTT_KEEP_ALIVE_INTERVAL            50         // unit: second
  • MQTT_VERSION

    选择MQTT协议的版本,默认为4,表示使用MQTT 3.1.1版本,而3则表示使用MQTT 3.1版本。

        #define     MQTT_VERSION                        4           // 4 is mqtt 3.1.1
  • MQTT_RECONNECT_DEFAULT_DURATION

    设置默认的重连时间间隔,当发生掉线时,会以这个时间间隔尝试重连,默认值为1000。

        #define     MQTT_RECONNECT_DEFAULT_DURATION     1000
  • MQTT_THREAD_STACK_SIZE

    MQTT内部维护一个线程,需要设置默认的线程属性信息,MQTT_THREAD_STACK_SIZE表示线程栈的大小,默认值是2048。在linux环境下可以是不需要理会这些参数的,而在RTOS平台则需要配置,如果不使用mbedtls,线程栈2048字节已足够,而使用mbedtls加密后,需要配置4096字节以上

        #define     MQTT_THREAD_STACK_SIZE              2048    // 线程栈
  • MQTT_THREAD_PRIO

    设置线程优先级,默认为5。

        #define     MQTT_THREAD_PRIO                    5       // 线程优先级
  • MQTT_THREAD_TICK

    设置线程优时间片,默认为50。

        #define     MQTT_THREAD_TICK                    50      // 线程时间片
  • MQTT_NETWORK_TYPE_NO_TLS

    设置是否需要支持TLS加密传输,如果定义了该宏,则表示不支持TLS加密传输,否则默认将支持TLS加密传输。

        #define     MQTT_NETWORK_TYPE_NO_TLS

salof相关的配置

salof 全称是:Synchronous Asynchronous Log Output Framework(同步异步日志输出框架),它是一个同步异步日志输出框架,可以在空闲时候输出对应的日志信息,并且该库与mqttclient无缝衔接。

  • LOG_LEVEL

    配置对应的日志输出级别,它支持以下4种级别:ERR_LEVEL、WARN_LEVEL、INFO_LEVEL、DEBUG_LEVEL。

        #define BASE_LEVEL      (0)
        #define ERR_LEVEL       (BASE_LEVEL + 1)          /* 日志输出级别:错误级别(高优先级) */
        #define WARN_LEVEL      (ERR_LEVEL + 1)             /* 日志输出级别:警告级别(中优先级) */
        #define INFO_LEVEL      (WARN_LEVEL + 1)            /* 日志输出级别:信息级别(低优先级) */
        #define DEBUG_LEVEL     (INFO_LEVEL + 1)            /* 日志输出级别:调试级别(更低优先级) */
    
        #define         LOG_LEVEL                   WARN_LEVEL      /* 日志输出级别 */
  • USE_SALOF

    如果该宏大于0,则表示使用salof指定的后端作为日志输出,反之则使用printf作为日志输出接口。

        #define         USE_SALOF                   (1U)
  • SALOF_OS

    设置salof日志库的操作系统,有以下选项:USE_LINUX、USE_TENCENTOS、USE_FREERTOS、USE_RTT。

        #define         SALOF_OS                    USE_LINUX
  • USE_IDLE_HOOK

    如果该宏大于0,则表示在操作系统中的空闲钩子函数中输出日志,反之则通过线程异步处理或者同步处理。

        #define         USE_IDLE_HOOK               (0U)
  • LOG_COLOR

    如果该宏大于0,则表示输出的日志是带有颜色的(需要终端的支持),反之则没有颜色。

        #define         LOG_COLOR                   (1U)
  • LOG_TS

    如果该宏大于0,则表示输出的日志是带有时间戳的,反之则没有时间戳。

        #define         LOG_TS                   (0U)
  • LOG_TAR

    如果该宏大于0,则表示输出的日志是带有标签的(任务名字),反之则没有标签。

        #define         LOG_TAR                   (0U)
  • SALOF_BUFF_SIZE

    设置日志库salof输出库的buf缓冲区大小,即最大一次性能输出多少个字节。

        #define         SALOF_BUFF_SIZE                   (512U)
  • SALOF_FIFO_SIZE

    设置日志库salof的fifo缓冲区大小,即最能缓存多少个字节的日志数据。

            #define         SALOF_FIFO_SIZE             (1024*4U)
  • SALOF_TASK_STACK_SIZE

    如果使用了空闲线程输出日志,则配置salof线程栈的大小。

        #define         SALOF_TASK_STACK_SIZE       (2048U)
  • SALOF_TASK_TICK

    如果使用了空闲线程输出日志,则配置salof线程栈的时间片大小。

        #define         SALOF_TASK_TICK             (50U)

使用mqttclient裁剪配置工具

我们可以通过配置很方便地裁剪我们需要的功能,设置上述MQTT客户端的默认参数,完全不需要手动修改代码,直接使用工具裁剪配置即可。

打开在线mqttclient裁剪配置工具:https://jiejietop.gitee.io/mqtt/mqtt-config.html

它支持裁剪配置相关的头文件,配置客户端默认的一些参数:

mqtt-config-tool01

还支持配置salof同步异步日志相关的信息,以保证日志能正常运作,配置完成后生成对应的代码,然后覆盖掉原本的MQTT客户端配置即可,如果不知道如何配置,那就导入默认的配置即可。

mqtt-config-tool02

如果是初次接触,看不懂上面配置的信息,没关系,我很贴心地准备了配置的宏定义及其描述信息,保证你能看得懂的。

mqtt-config-tool03

上一篇mqttclient代码生成工具

下一篇mqttclient设计与实现方式