今天开始搞我的论文,感觉很大可能完不成。但是总要努力一把吧。还剩不到三个月,还一点思路没有。我的论文题目是mqtt服务分布式。今天开始我会一直记录我的学习过程。
我的初步打算是:(1)学习mqtt的原码分析,运行mqtt服务器。学习mqtt协议理解实体功能
(2)我的打算是使用zookeeper像hadoop HA的形式组建mqtt的服务分布式,所以第二步是学习zookeeper。但是我看到网上好像有搭建集群的方式,可以参考一下
(3)搭建运行,写论文
今天就是搭建一个mqtt服务器,然后使用已经有的两个客户端。分别是订阅客户端mosquitto_sub和发布客户端mosquitto_pub完成一个消息的发送。
过程如下:
解压
tar zxfv mosquitto-1.4.5.tar.gz
# 进入目录
cd mosquitto-1.4.5
# 编译
make
【1】编译找不到openssl/ssl.h
【解决方法】——安装openssl
sudo apt-get install libssl-dev
【2】编译过程找不到ares.h
sudo apt-get install libc-ares-dev
【3】编译过程找不到uuid/uuid.h
sudo apt-get install uuid-dev
【4】使用过程中找不到libmosquitto.so.1
error while loading shared libraries: libmosquitto.so.1: cannot open shared object file: No such file or directory
【解决方法】——修改libmosquitto.so位置
# 创建链接
sudo ln -s /usr/local/lib/libmosquitto.so.1 /usr/lib/libmosquitto.so.1
# 更新动态链接库
sudo ldconfig
【5】make: g++:命令未找到
【解决方法】
安装g++编译器
sudo apt-get install g++
2 简单测试
一个完整的MQTT示例包括一个代理器,一个发布者和一个订阅者。测试分为以下几个步骤:
【1】启动服务mosquitto。
【2】订阅者通过mosquitto_sub订阅指定主题的消息。
【3】发布者通过mosquitto_pub发布指定主题的消息。
【4】代理服务器把该主题的消息推送到订阅者。
【测试说明】
测试环境:ubuntu 14.04 虚拟机
在本例中,发布者、代理和订阅者均为localhsot,但是在实际的情况下三种并不是同一个设备,在mosquitto中可通过-h(--host)设置主机名称(hostname)。为了实现这个简单的测试案例,需要在linux中打开三个控制台,分别代表代理服务器、发布者和订阅者。
图1 示例
2.1 启动代理服务
mosquitto -v
【-v】打印更多的调试信息
启动的时候出现问题
Error: Invalid user 'mosquitto'.
解决方法就是增加一个mosquitto用户
useradd mosquitto
2.2 订阅主题
mosquitto_sub -v -t whq
【-t】指定主题,此处为whq
【-v】打印更多的调试信息
2.3 发布内容
mosquitto_pub -t whq -m wanghanqi
【-t】指定主题
【-m】指定消息内容
2.4 运行结果
当发布者推送消息之后,订阅者获得以下内容
sensor 12
而代理服务器控制台中会出现——连接、消息发布和心跳等调试信息。通过代理服务器的调试输出可以对MQTT协议的相关过程有所了解。
图2 代理服务器调试输出
在订阅端我们可以看到发送的消息wanghanqi
whq wanghanqi
前面是topic 后面是消息内容
上午的工作就是这样。继续努力吧
下午进行mqtt原码的学习分析过程。
阅读(1463) | 评论(0) | 转发(0) |