centos7 mqtt服务mosquitto搭建记录

1、系统centos7.6,安装默认版本

yum install mosquitto

2、启动运行

systemctl start mosquitto

3、设置自启动

systemctl enable mosquitto

4、修改配置文件 vim /etc/mosquitto/mosquitto.conf

监听端口,默认为1883,需要修改删除前面 # 注释,改为自己的端口

listener 1883

是否启用密码,为true不需要,false需要,默认为false,如果不要用户名和密码可连接时,删除掉前面的 # 注释,后面添加true 

allow_anonymous

需要密码,配置密码文件,删除password_file 前面的 # 注释,后面添加密码配置文件

password_file /etc/mosquitto/passwordFile

拷贝创建密码文件 

cp /etc/mosquitto/pwfile.example  /etc/mosquitto/passwordfile

5、创建用户和密码

mosquitto_passwd -c /etc/mosquitto/passwd username

其中username 需要换成自己的账户名,比如admin,回车执行后,会提示输入密码和输入确认密码,完成后重启服务生效

扩展,重启服务 systemctl restart mosquitto,停止服务systemctl stop mosquitto

到此mqtt服务器搭建完成

  6、连接测试 

下载MQTTX工具进行测试连接可发布消息,https://mqttx.app/zh/downloads

如果 填写名称、IP/域名,端口,账号密码,点击Connect 连接,连接成功左侧状态 会是绿色,失败会提示,连接成功发布消息 test为主题---topic,下面输入消息内容---message,点击发送

java springboot 连接测试

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-integration</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.integration</groupId>
            <artifactId>spring-integration-mqtt</artifactId>
        </dependency>

 config

package com.szhz.util;

import lombok.extern.slf4j.Slf4j;
import org.eclipse.paho.client.mqttv3.*;
import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;

import javax.annotation.PostConstruct;

import org.springframework.context.annotation.Configuration;

@Configuration
@Slf4j
public class MqttPubConfig {

    private  String hostUrl = "tcp://192.168.1.1:1883";
    private String clientId = "mqtt123456_test1";
    private String username = "admin";
    private String password = "123456";
    /**
     * 客户端对象
     */
    private MqttClient client;
    /**
     * 在bean初始化后连接到服务器
     */
    @PostConstruct
    public void init() {
        connect();
    }

    /**
     * 客户端连接服务端
     */
    public void connect() {
        try {
            //创建MQTT客户端对象
            client = new MqttClient(hostUrl, clientId, new MemoryPersistence());
            //连接设置
            MqttConnectOptions options = new MqttConnectOptions();
            //是否清空session,设置false表示服务器会保留客户端的连接记录(订阅主题,qos),客户端重连之后能获取到服务器在客户端断开连接期间推送的消息
            //设置为true表示每次连接服务器都是以新的身份
            options.setCleanSession(true);
            //设置连接用户名
            options.setUserName(username);
            //设置连接密码
            options.setPassword(password.toCharArray());
            //设置超时时间,单位为秒
            options.setConnectionTimeout(100);
            //设置心跳时间 单位为秒,表示服务器每隔 1.5*20秒的时间向客户端发送心跳判断客户端是否在线
            options.setKeepAliveInterval(20);
            //设置遗嘱消息的话题,若客户端和服务器之间的连接意外断开,服务器将发布客户端的遗嘱信息
            options.setWill("willTopic", (clientId + "与服务器断开连接").getBytes(), 0, false);
            //设置回调
            client.setCallback(new MqttPubCallBack());
            client.connect(options);
        } catch (MqttException e) {
            e.printStackTrace();
        }

    }

    /**
     * 发送主题内容
     *
     * @param topic 主题
     */
    public void publish( String topic, String message) {
        MqttMessage mqttMessage = new MqttMessage();
        mqttMessage.setQos(1);
        mqttMessage.setRetained(false);
        mqttMessage.setPayload(message.getBytes());
        //主题的目的地,用于发布/订阅信息
        MqttTopic mqttTopic = client.getTopic(topic);
        //提供一种机制来跟踪消息的传递进度
        //用于在以非阻塞方式(在后台运行)执行发布是跟踪消息的传递进度
        MqttDeliveryToken token;
        try {
            //将指定消息发布到主题,但不等待消息传递完成,返回的token可用于跟踪消息的传递状态
            //一旦此方法干净地返回,消息就已被客户端接受发布,当连接可用,将在后台完成消息传递。
            token = mqttTopic.publish(mqttMessage);
            token.waitForCompletion();
        } catch (MqttException e) {
            e.printStackTrace();
        }
    }

    /**
     * 订阅主题 ,此方法默认的的Qos等级为:1
     *
     * @param topic 主题
     */
    public void sub(String topic) throws MqttException {
        client.subscribe(topic);
    }


    public static void main(String[] args) throws MqttException {
        MqttPubConfig mqttPubConfig = new MqttPubConfig();
        mqttPubConfig.connect();
        mqttPubConfig.sub("test111");
        mqttPubConfig.publish("test111", "我发的第一条消息!");
    }

}
MqttPubCallBack
package com.szhz.util;


import org.eclipse.paho.client.mqttv3.IMqttAsyncClient;
import org.eclipse.paho.client.mqttv3.IMqttDeliveryToken;
import org.eclipse.paho.client.mqttv3.MqttCallback;
import org.eclipse.paho.client.mqttv3.MqttMessage;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;

@Configuration
public class MqttPubCallBack implements MqttCallback{

    @Value("${spring.mqtt.clientId}")
    private String clientId;
    /**
     * 与服务器断开的回调
     */
    @Override
    public void connectionLost(Throwable cause) {
        System.out.println(clientId+"与服务器断开连接");
    }

    /**
     * 接受消息
     */
    @Override
    public void messageArrived(String topic, MqttMessage message) throws Exception {
        System.out.println(String.format("接收消息主题 : %s",topic));
        System.out.println(String.format("接收消息内容 : %s",new String(message.getPayload())));

    }

    /**
     * 消息发布成功的回调
     */
    @Override
    public void deliveryComplete(IMqttDeliveryToken token) {
        IMqttAsyncClient client = token.getClient();
        System.out.println(client.getClientId()+"发布消息成功!");

    }

}
SendController
package com.szhz.controller;


//import com.szhz.util.MqttPubConfig;
import com.szhz.entity.MqttEntity;
import com.szhz.util.MqttPubConfig;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
public class SendController {
    @Autowired
    private MqttPubConfig providerClient;


    @RequestMapping(value = "/pubMessage", method = RequestMethod.POST)
    @ResponseBody
    public String sendMessage(@RequestBody MqttEntity entity){
        try {
            providerClient.publish(entity.getTopic(), entity.getMessage());
            return "发送成功";
        } catch (Exception e) {
            e.printStackTrace();
            return "发送失败";
        }
    }

    @RequestMapping("/subTopic")
    @ResponseBody
    public String subTopic(String topic){
        try {
            providerClient.sub(topic);
            return "订阅成功";
        } catch (Exception e) {
            e.printStackTrace();
            return "订阅失败";
        }
    }
}

<think>好的,我现在需要回答用户关于Mosquitto MQTT broker的介绍和使用的问题。首先,我需要整理用户提供的引用内容,并确保回答符合系统级指令的要求,比如正确使用LaTeX格式、生成相关问题等。 首先,根据引用[2],Mosquitto是一个开源的MQTT代理,支持多种协议版本,适用于不同设备。我需要强调它的轻量级和跨平台特性。然后,引用[5]提到配置文件的位置和关闭匿名访问的设置,这部分在配置部分需要提及。 接下来,用户可能想知道如何安装和配置Mosquitto。根据引用[5],在CentOS上安装的步骤,包括安装EPEL仓库和mosquitto软件包。Ubuntu的安装步骤应该类似,使用apt命令。配置部分需要提到编辑mosquitto.conf文件,设置监听端口和关闭匿名访问,如allow_anonymous false,并设置密码文件,引用[1]和[5]中的内容。 关于MQTT TLS配置,引用[1]提到需要生成证书,并在配置文件中指定证书路径。这部分需要简要说明步骤,比如使用OpenSSL生成证书,然后在配置文件中添加相关选项,如cafile、certfile和keyfile。 桥接功能方面,引用[4]提到Mosquitto可以桥接到AWS IoT,这里可以说明桥接配置的基本结构,比如在配置文件中定义连接和主题转发规则。 最后,生成相关问题需要考虑用户可能想深入了解的内容,比如性能优化、安全配置、日志管理以及与其他服务的集成,如AWS IoT或Kubernetes部署。需要确保问题覆盖配置、安全、监控和扩展等方面。 在回答过程中,要检查LaTeX的正确使用,比如数学公式或变量用$包围,但根据引用内容,可能较少需要数学表达式,但如果有涉及版本号的地方,比如MQTT 5.0,可能需要用$5.0$?不过通常版本号不需要LaTeX。需注意不要误用,保持自然。 确保回答结构清晰,分点介绍,包含概述、安装步骤、配置、TLS设置、桥接示例和最佳实践,并在末尾添加相关问题。同时,引用标识要正确对应,如引用[1]到[5]。</think>### Mosquitto MQTT Broker 介绍与使用 #### 1. **Mosquitto 概述** Mosquitto 是开源的 MQTT 代理(Broker),支持 MQTT 协议版本 5.0、3.1.1 和 3.1,由 Eclipse 基金会维护。其核心功能是接收客户端(如传感器、应用程序)发布的消息,并根据订阅规则转发给其他客户端[^2]。 **特点**: - **轻量级**:适用于从低功耗设备(如树莓派)到服务器的多种场景。 - **跨平台**:支持 Linux、Windows 等操作系统。 - **扩展性**:提供 C 语言客户端库及命令行工具(如 `mosquitto_pub` 和 `mosquitto_sub`)[^2]。 --- #### 2. **安装 Mosquitto** **CentOS 7 示例**: ```bash # 安装 EPEL 仓库 yum install epel-release # 安装 Mosquitto yum install mosquitto # 启动服务 systemctl start mosquitto ``` **Ubuntu/Debian 示例**: ```bash sudo apt-get install mosquitto mosquitto-clients ``` --- #### 3. **基础配置** 配置文件默认位于 `/etc/mosquitto/mosquitto.conf`[^5]。常用配置项: - **监听端口**:默认 1883(明文)和 8883(TLS)。 ```conf listener 1883 ``` - **禁用匿名访问**(增强安全性): ```conf allow_anonymous false password_file /etc/mosquitto/passwd ``` 通过 `mosquitto_passwd` 命令创建用户密码文件[^5]。 --- #### 4. **配置 MQTT TLS** 1. **生成证书**(使用 OpenSSL): ```bash openssl req -x509 -newkey rsa:2048 -keyout key.pem -out cert.pem -days 365 ``` 2. **修改配置文件**: ```conf listener 8883 cafile /path/to/ca.crt certfile /path/to/server.crt keyfile /path/to/server.key ``` 此配置启用 TLS 加密通信,防止数据窃听[^1]。 --- #### 5. **桥接示例(连接 AWS IoT)** 在配置文件中添加桥接规则: ```conf connection aws_bridge address aws-iot-endpoint:8883 bridge_cafile /path/to/amazon-root-ca.pem bridge_certfile /path/to/client-cert.pem bridge_keyfile /path/to/client-key.pem topic # both 0 ``` 此配置将本地 Mosquitto 消息转发至 AWS IoT[^4]。 --- #### 6. **最佳实践** - **日志监控**:启用日志记录以排查问题。 ```conf log_dest file /var/log/mosquitto.log ``` - **权限控制**:通过 ACL 文件限制客户端权限。 ```conf acl_file /etc/mosquitto/acl ``` - **定期更新**:保持软件版本最新以修复安全漏洞[^3]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值