物联网架构成长之路(3)-EMQ消息服务器了解
1. 了解
物联网最基础的就是通信了。通信协议,物联网协议好像有那么几个,以前各个协议都有优劣,最近一段时间,好像各大厂商都采用MQTT协议,所以我也不例外,不搞特殊,采用MQTT协议,选定了协议,接下来就是选一个MQTT服务器(Broker),项目初期肯定是使用开源的解决方案会好一点,一方面是有人为之填坑,一方面可以快速搭建原型。等以后有人、有资源、有用户,在自己定制开发一套系统。基于各种考虑(更多的是领导的要求)选择了国人开发的MQTTBroker EMQ框架 (http://emqtt.com/),目前最新版本是2.3.1 接下来大部分环境都是基于此版本的。
2. Erlang语言
一开始叫我学习这个语言我还是拒绝的,当然现在也是。其实我还是比较倾向于Java实现的MQTTBroker - Moquette 这个的。没办法,需要就学咯。
学习Erlang,我是在http://www.erlang-cn.com/这里找个快速入门的,简单了解一下语法和语言特性。没有怎么深入理解,这个在目前不是重点,在后面开发插件时,边写边学才是最快的。总结几个与以往有所区别的特性吧:
(1)非面向对象,面向函数(并发)编程
(2)无循环结构,只能通过递归实现,尽量采用尾递归
(3)变量不可变
(4)无数组概念,不能通过下标访问
(5)Erlang消息传递机制
3. EMQ框架
这个http://emqtt.com/ 是中文的官网,这个http://emqtt.io/ 是英文的官网。由于是国人自己开发的,加上我自己英文不好,其实看中文文档就可以了。文档 http://emqtt.com/docs/v2/index.html 在 http://emqtt.com/downloads 这里下载个可以用的版本,然后跟着文档一步一步就可以搭建起来了。没有什么可以说的,我说的还没有官方文档好。里面的一些知识点和商业吹捧也可以了解一下。
4. EMQ编译、安装
好了,这部分才是重点,由于官网提供的是二进制可运行版本,但是每个公司对应的业务需求都不同,所有就需要进行二次开发。EMQ提供的二次开发机制是,建议使用插件方式进行扩展。所以这里就需要下载源码了。
安装Erlang/OTP 框架
安装 emq-relx EMQ编译环境
git clone https://github.com/emqtt/emq-relx
cd emq-relx
make
这个make过程会比较久,会下载一大堆依赖,依赖存放在 deps 目录,然后把编译结果存放在 _rel 目录下,实际生产过程中,就是拷贝这个 _rel 目录下的所有文件就可以了。
我在当前(2017-12-21)版本下,编译的时候遇到以下这个问题
src/emq_sn_gateway.erl:: undefined macro 'SN_RC_MQTT_FAILURE'
我临时解决的办法是在./emq-relx/deps/emq_sn/include/emq_sn.hrl:56 行增加一个宏定义
-define(SN_RC_MQTT_FAILURE, #).
临时解决编译问题。
这个依赖下载过程会比较久,大部分是依赖与Github,下载编译后,目录有136M大小

下图就是编译好了

编译后,产生一个_rel 目录,这个目录下的文件,就是我们在官网上 http://emqtt.com/downloads 下载后解压的结果了。两者基本是一样的。
运行

./bin/emqttd start
./bin/emqttd_ctl status
./bin/emqttd stop
控制台地址: http://127.0.0.1:18083 默认用户密码 admin/public
更多内核调优,请参考官方文档。
几个常用端口,也可以看一下

5. EMQ运行
运行后,可以打开 http://host:18083 登录到后台管理界面。没什么说的,就在上面玩一会。

物联网架构成长之路(3)-EMQ消息服务器了解的更多相关文章
- 物联网架构成长之路(31)-EMQ基于HTTP权限验证
看过之前的文章就知道,我之前是通过搞插件,或者通过里面的MongoDB来进行EMQ的鉴权登录和权限验证.但是前段时间发现,还是通过HTTP WebHook 方式来调用鉴权接口比较适合实际使用.还是实现 ...
- 物联网架构成长之路(33)-EMQ数据存储到influxDB
一.前言 时隔一年半,技术变化特别快,学习也要跟上才行.以前写过EMQ数据转存问题,当时用了比较笨的方法,通过写插件的方式,把MQTT里面的数据发送到数据库进行存储.当时也是为了学习erlang和em ...
- 物联网架构成长之路(4)-EMQ插件创建
1. 说明 以下用到的知识,是建立在我目前所知道的知识领域,以后如果随着知识的拓展,不一定会更新内容.由于不是EMQ公司的人,EMQ的文档又很少,很多知识点都是靠猜的.2. 一些资料 架构设计 htt ...
- 物联网架构成长之路(5)-EMQ插件配置
1. 前言 上一小结说了插件的创建,这一节主要怎么编写代码,以及具体流程之类的.2. 增加一句Hello World 修改 ./deps/emq_plugin_wunaozai/src/emq_plu ...
- 物联网架构成长之路(6)-EMQ权限控制
1. 前言 EMQTT属于一个比较小众的开源软件,很多资料不全,很麻烦,很多功能都是靠猜测,还有就是看官方提供的那几个插件,了解. 2. 说明 上一小节的插件 emq_plugin_wunaozai ...
- 物联网架构成长之路(7)-EMQ权限验证小结
1. 前言 经过前面几小节,讲了一下插件开发,这一小节主要对一些代码和目录结构进行讲解,这些都是测试过程中一些个人经验,不一定是官方做法.而且也有可能会因为版本不一致导致差异. 2. 目录结构 这个目 ...
- 物联网架构成长之路(25)-Docker构建项目用到的镜像1
0. 前言 现在项目处于初级阶段,按照规划,先构建几个以后可能会用到的Image,并上传到阿里云的Docker仓库.以后博客中用到的Image,大部分都会用到这几个基础的Image,构建一个简单的物联 ...
- 物联网架构成长之路(8)-EMQ-Hook了解、连接Kafka发送消息
1. 前言 按照我自己设计的物联网框架,对于MQTT集群中的所有消息,是要持久化到磁盘的,这里采用一个消息队列中间件Kafka作为数据缓冲,缓冲结果存到数据仓库中,以供后续作为数据分析.由于MQTT集 ...
- 物联网架构成长之路(35)-利用Netty解析物联网自定义协议
一.前言 前面博客大部分介绍了基于EMQ中间件,通信协议使用的是MQTT,而传输的数据为纯文本数据,采用JSON格式.这种方式,大部分一看就知道是熟悉Web开发.软件开发的人喜欢用的方式.由于我也是做 ...
随机推荐
- 7-6 Bandwidth UVA140
没有清空向量导致debug了好久 这题难以下手 不知道怎么dfs 原来是用排序函数. letter[n]=i; id[i]=n++; 用来储存与设置标记十分巧妙 for(;;) { while(s[ ...
- hdu1573 X问题【中国剩余定理】
<题目链接> X问题 Problem Description 求在小于等于N的正整数中有多少个X满足:X mod a[0] = b[0], X mod a[1] = b[1], X mod ...
- 解决Ubuntu无法进行SSH连接的问题(以及如何使用SSH)
我们在VM中安装好Ubuntu 虚拟机后,经常需要使用Xshell.ssh等工具进行远程连接,方便我们在两个操作系统中进行文件的复制与移动,但是有时候会出现无法连接的问题,原因可能是Ubuntu中默认 ...
- 从源码看Spring Boot 2.0.1
Spring Boot 命名配置很少,却可以做到和其他配置复杂的框架相同的功能工作,从源码来看是怎么做到的. 我这里使用的Spring Boot版本是 2.0.1.RELEASE Spring Boo ...
- js数据结构之栈和队列的详细实现方法
队列 队列中我们主要实现两种: 1. 常规队列 2. 优先队列(实际应用中的排队加急情况等) 常规队列的实现方法如下: // 常规队列 function Queue () { this.queue = ...
- C# 的枚Enum
简短的解释: enum 关键字用来声明枚举,一种包含一组被称为枚举数列表的 enum myType{ a, b, c,} int num = 1;Console.Write((myType)num); ...
- Qt打包成单独可执行的exe文件
1.将图标newIco.ico复制到工程目录下. 2.在工程目录下新建空白txt文档,添加以下内容. IDI_ICON1 ICON DISCARDABLE "newIco.ico" ...
- 在Springboot2.0项目中使用Druid配置多数据源
在Springboot出现之前配置数据源以及相关的事物,缓存等内容一直是个繁琐的工作,但是Springboot出现后这些基本都可以靠默认配置搞定,就变得很轻松了.这就是现在推崇模板>配置的原因, ...
- tcp timestamps
最近讨论到net.ipv4.tcp_timestamps这个系统配置是否能够开启,RFC文档上说道该值必须为单调递增,否则接受到的包可能会被丢掉 于是查看下tcp协议栈中是根据什么来生成这个times ...
- redis源码分析
我阅读的源码版本是redis-2.8.19 src目录下总共96个.h,.c文件 1. 数据结构相关源码(15个左右)字符串代码: sds.h, sds.c字典:dict.h, dict.c链表: a ...