docker安装EMQ服务

docker安装EMQ服务

1.镜像下载: http://emqtt.com/downloads/latest/docker

2.解压 emqttd-docker 镜像包:

unzip emqttd-docker-v2.3.10.zip

3.加载镜像:

docker load < emqttd-docker-v2.3.10

4.启动容器:

docker run -tid –name emq20 -p 1883:1883 -p 8083:8083 -p 8883:8883 -p 8084:8084 -p 18083:18083 emqttd-docker-v2.3.10

进入 Docker 控制台:

docker exec -it emq20 /bin/sh

MySql认证:
1.首先先关闭匿名认证(默认是开启的谁都能够登录)

vi /opt/emqttd/etc/eqm.conf

## Allow Anonymous authentication
mqtt.allow_anonymous = false

2.用户和权限的mysql表

CREATE TABLE mqtt_user (
id int(11) unsigned NOT NULL AUTO_INCREMENT,
username varchar(100) DEFAULT NULL,
password varchar(100) DEFAULT NULL,
salt varchar(20) DEFAULT NULL,
is_superuser tinyint(1) DEFAULT 0,
created datetime DEFAULT NULL,
PRIMARY KEY (id),
UNIQUE KEY mqtt_username (username)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

………………………………………………………………..

CREATE TABLE mqtt_acl (
id int(11) unsigned NOT NULL AUTO_INCREMENT,
allow int(1) DEFAULT NULL COMMENT ‘0: deny, 1: allow’,
ipaddr varchar(60) DEFAULT NULL COMMENT ‘IpAddress’,
username varchar(100) DEFAULT NULL COMMENT ‘Username’,
clientid varchar(100) DEFAULT NULL COMMENT ‘ClientId’,
access int(2) NOT NULL COMMENT ‘1: subscribe, 2: publish, 3: pubsub’,
topic varchar(100) NOT NULL DEFAULT ” COMMENT ‘Topic Filter’,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

3.修改mysql配置文件

vi /opt/emqttd/etc/plugins/emq_auth_mysql.conf
auth.mysql.server = xxxxxxxxx:3306
auth.mysql.username = root
auth.mysql.password = xxxxxxxx
auth.mysql.database = emq

可以配置超级管理员(超级管理员会无视ACL规则对所有的topic都有订阅和推送的权限)

update mqtt_user set is_superuser=1 where id=1;

4.重启

/opt/emqttd/bin
emqttd stop
/opt/emqttd/bin
emqttd start
emqttd_ctl plugins load emq_auth_mysql

  • 0
    点赞
  • 0
    评论
  • 4
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

打赏
文章很值,打赏犒劳作者一下
相关推荐
©️2020 CSDN 皮肤主题: 编程工作室 设计师:CSDN官方博客 返回首页

打赏

TingBen

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者