Docker部署TICK+Mosquitto实现MQTT数据输入图形化监视

TICK Stack简介

TICK Stack是来自时间序列数据库InfluxDB公司开发的四款监控开源产品集合。它由以下组件组成:

  • T=Telegraf从各种来源收集时间序列数据。
  • I=InfluxDB是开源的分布式时序、时间和指标数据库。
  • C=Chronograf可视化和图形化时间序列数据。
  • K=Kapacitor提供警报并检测时间序列数据中的异常,并提供数据分析与机器学习接口。
    TICK Stack架构
    更多内容请访问https://www.influxdata.com/time-series-platform/

准备工作

安装Docker与Portainer容器管理工具,参考LINUX安装Docker及Portainer可视化界面

安装Mosquitto镜像

$ sudo docker search mosquitto
NAME                         DESCRIPTION                                     STARS     OFFICIAL     AUTOMATED
eclipse-mosquitto            Eclipse Mosquitto is an open source message …   205        [OK]                
toke/mosquitto               mosquitto mqtt broker based on Debian Jessie…   61                        [OK]
ansi/mosquitto               MQTT Mosquitto 1.5 build on ubuntu 18.4         36                        [OK]
fstehle/rpi-mosquitto        Raspberry Pi compatible Docker Image with mo…   17                        [OK]
jllopis/mosquitto            Mosquitto MQTT Broker With auth plugin on Al…   13                        [OK]
......

默认安装方式

$ sudo docker run -d --name m2_mqtt -p 1883:1883 -p 9001:9001 eclipse-mosquitto
1543744425: mosquitto version 1.5.4 starting
1543744425: Config loaded from /mosquitto/config/mosquitto.conf.
1543744425: Opening ipv4 listen socket on port 1883.
1543744425: Opening ipv6 listen socket on port 1883.

可以安装mosquitto客户端进行测试,并通过Portainer查看容器情况
mosquitto容器情况
mosquitto log日志
更多配置请参考https://hub.docker.com/_/eclipse-mosquitto/

快速部署TICK

安装InfluxDB镜像

$ sudo docker run -d --name m2influx -p 8888:8888 -p 8086:8086 influxdb // 8888提供给Chronograf使用

更多配置请参考https://hub.docker.com/_/influxdb/

安装Telegraf镜像

针对MQTT输入自定义配置文件
  1. 获取telegraf配置文件模板另存为telegraf.conf
    $ sudo docker run --rm telegraf telegraf config > telegraf.conf
    
  2. 取消telegraf.conf中以下相关区域的注释
    [[outputs.influxdb]]
    urls = ["http://127.0.0.1:8086"]
    database = "telegraf"
    retention_policy = ""
    write_consistency = "any"
    timeout = "5s"
    insecure_skip_verify = false
    ......
    [[inputs.docker]] //输入docker监视数据
    endpoint = "unix:///var/run/docker.sock"
    gather_services = false
    container_names = []
    container_name_include = []
    container_name_exclude = []
    timeout = "5s"
    perdevice = true
    total = false
    tag_env = ["JAVA_HOME", "HEAP_SIZE"]
    docker_label_include = []
    docker_label_exclude = []
    ......
    [[inputs.mqtt_consumer]]
    servers = ["tcp://172.17.0.3:1883"] //与Mosquitto容器IP一致
    qos = 0
    connection_timeout = "30s"
    topics = ["sensors/iot_simulator"] //与Mosquitto发布主题一致
    persistent_session = false
    client_id = ""
    insecure_skip_verify = true
    data_format = "json"
    
使用工作目录下的telegraf.conf配置文件创造并启动telegraf容器
$ sudo docker run -d --net=container:m2influx \
        --name m2_telegraf \
        -v /var/run/docker.sock:/var/run/docker.sock \
        -v $PWD/telegraf.conf:/etc/telegraf/telegraf.conf \
        telegraf

telegraf容器情况
[inputs.mqtt_consumer]:connected 信息出现显示MQTT输入插件开始工作。
telegraf log日志
注意Hostname名称。更多配置请参考https://hub.docker.com/_/telegraf/

安装Chronograf镜像

$ sudo docker run -d --net=container:m2influx \
        --name m2_chronograf \
        -v chronograf:/var/lib/chronograf \
        chronograf

chronograf容器情况
浏览器访问主机IP地址的8888端口
向导开始
连接数据库
本例中数据库未开户使用用户名与密码。
连接数据库

选择内置监视面板
选择内置监视面板
暂时跳过不设置Kapacitor
暂时不设置Kapacitor
配置向导完成
配置向导完成
浏览主机
浏览主机
主机监视面板
Docker监视面板
Docker监视面板
MQTT输入数据
Docker监视面板
MQTT数据源为modular-2采集数据。更多配置请参考https://hub.docker.com/_/chronograf/

安装Kapacitor镜像

$ sudo docker run -d -p 9092:9092 \
      -v kapacitor:/var/lib/kapacitor \
      kapacitor

更多配置请参考https://hub.docker.com/_/kapacitor/

  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值