Chinaunix首页 | 论坛 | 博客
  • 博客访问: 85068
  • 博文数量: 22
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 221
  • 用 户 组: 普通用户
  • 注册时间: 2015-08-28 11:18
文章分类

全部博文(22)

文章存档

2021年(4)

2020年(1)

2016年(10)

2015年(7)

我的朋友

分类: LINUX

2016-08-04 10:17:08

        今天开始搞我的论文,感觉很大可能完不成。但是总要努力一把吧。还剩不到三个月,还一点思路没有。我的论文题目是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
# 安装
sudo make install

1.2 安装注意点
【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原码的学习分析过程。

阅读(1475) | 评论(0) | 转发(0) |
0

上一篇:分布式原理学习

下一篇:mqtt(2)

给主人留下些什么吧!~~