用emq实现简单聊天室功能(含离线缓存数据)

本文介绍如何在Ubuntu上部署EMQ MQTT服务器,并提供了一个使用Python编写的MQTT客户端示例,该客户端能够连接到EMQ服务器,实现消息订阅和发布功能。
Python3.8

Python3.8

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

EMQ官方地址:http://emqtt.com/ 
EMQ中文文档:http://emqtt.com/docs/v2/guide.html

在ubuntu上部署emq服务器,

#!/usr/bin/python3
# -*- coding: utf-8 -*-
# @Time    : 2018/11/21 10:58
# @Author  : Tom
# @File    : chat_a.py
# @Software: PyCharm

import paho.mqtt.client as mqtt
import json


def on_connect(client,userdata,flags,rc):
    print('connected with result code',str(rc))

    client.subscribe("chat")
    client.publish('chat',json.dumps('hello,everyone.....'))

def on_message(client,userdata,msg):
    info = json.loads(msg.payload.decode())
    say_user = info.get("user")
    if say_user != client.user:
        print(info.get('user')+": "+info.get('say')+'\n')

if __name__ == '__main__':
    HOST = '127.0.0.1'
    PORT = 1883

    client = mqtt.Client(client_id='2008001',clean_session=False)
    # client = mqtt.Client(client_id='2008002',clean_session=False)
    # client = mqtt.Client(client_id='2008003',clean_session=False)
    print('生成的client',client)
    client.on_connect = on_connect
    client.on_message = on_message

    client.connect(HOST,PORT)

    user = input('请输入名字:')
    client.user = user
    client.loop_start()

    while True:
        say_str = input('')
        if say_str:
            info = {'user':user,'say':say_str}
            client.publish('chat',json.dumps(info))

 

您可能感兴趣的与本文相关的镜像

Python3.8

Python3.8

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

EMQX实现MQTT客户端上下线状态的监听,可以通过订阅特定的系统主题(`$SYS`主题)来完成。EMQX提供了针对客户端连接和断开事件的通知机制,通过订阅这些系统主题,可以实时获取客户端的上下线状态[^2]。 ### 监听客户端上下线事件 EMQX会通过以下两个系统主题发布客户端的上下线事件: - 上线事件:`$SYS/brokers/${node}/clients/${clientid}/connected` - 下线事件:`$SYS/brokers/${node}/clients/${clientid}/disconnected` 当任意客户端上线或下线时,EMQX会向对应的系统主题发布消息。消息的`Payload`以JSON格式提供,包客户端的相关信息,例如客户端ID、IP地址、连接时间、断开原因等[^4]。 #### 示例:上线事件的Payload ```json { "username": "foo", "ts": 1625572213873, "sockport": 1883, "proto_ver": 4, "proto_name": "MQTT", "keepalive": 60, "ipaddress": "127.0.0.1", "expiry_interval": 0, "connected_at": 1625572213873, "connack": 0, "clientid": "emqtt-8348fe27a87976ad4db3", "clean_start": true } ``` #### 示例:下线事件的Payload ```json { "username": "foo", "ts": 1625572213873, "sockport": 1883, "reason": "tcp_closed", "proto_ver": 4, "proto_name": "MQTT", "ipaddress": "127.0.0.1", "disconnected_at": 1625572213873, "clientid": "emqtt-8348fe27a87976ad4db3" } ``` 这些信息可以用于业务逻辑的处理,例如记录日志、更新状态或触发其他操作。 ### 订阅系统主题的注意事项 默认情况下,EMQX只允许本机的MQTT客户端订阅`$SYS`主题。如果需要从远程客户端订阅这些系统主题,必须修改EMQX的ACL(访问控制列表)配置,以允许远程客户端订阅相关的系统主题[^2]。 ### 示例:使用Java客户端订阅上下线事件 以下是一个使用Java版MQTT客户端订阅EMQX上下线事件的示例代码: ```java import org.eclipse.paho.client.mqttv3.*; import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence; public class MqttClientExample { public static void main(String[] args) { String serverURL = "tcp://localhost:1883"; String mClientId = "subscriber"; MemoryPersistence mPersistence = new MemoryPersistence(); try { MqttClient mMqttClient = new MqttClient(serverURL, mClientId, mPersistence); MqttConnectOptions mMqttConnectOptions = new MqttConnectOptions(); mMqttConnectOptions.setUserName("username"); mMqttConnectOptions.setPassword("password".toCharArray()); mMqttConnectOptions.setCleanSession(true); mMqttClient.setCallback(new MqttCallback() { @Override public void connectionLost(Throwable cause) { System.out.println("Connection lost: " + cause.getMessage()); } @Override public void messageArrived(String topic, MqttMessage message) throws Exception { System.out.println("Received message from topic: " + topic); System.out.println("Message: " + new String(message.getPayload())); } @Override public void deliveryComplete(IMqttDeliveryToken token) { // Not used in this example } }); mMqttClient.connect(mMqttConnectOptions); mMqttClient.subscribe("$SYS/brokers/+/clients/+/connected"); mMqttClient.subscribe("$SYS/brokers/+/clients/+/disconnected"); } catch (MqttException me) { me.printStackTrace(); } } } ``` ### 处理上下线事件的业务逻辑 在实际业务中,可以通过解析订阅到的消息内容,提取关键信息(如客户端ID、连接时间、断开原因等),并将其用于状态管理、日志记录或触发其他业务操作。例如,可以通过分析`reason`字段来区分正常断开和异常断开,并采取不同的处理策略[^1]。 ### 总结 通过订阅EMQX的系统主题,可以实时获取客户端的上下线状态。结合业务逻辑,可以实现对客户端状态的动态管理。需要注意的是,默认情况下EMQX限制远程客户端订阅系统主题,因此需要调整ACL规则以确保订阅功能的正常运行[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值