Skip to main content

AI-POWERED DOCS

What do you want to know?

Thiết Lập Giao Tiếp MQTT

Hướng dẫn này chỉ cho bạn cách cấu hình giao tiếp MQTT giữa camera OV10i và các thiết bị bên ngoài bằng Node-RED. MQTT cho phép truyền tin nhắn nhẹ, đáng tin cậy cho các ứng dụng IoT và giao tiếp thiết bị từ xa.

Khi Nào Sử Dụng Giao Tiếp MQTT: Tích hợp thiết bị IoT, hệ thống giám sát từ xa, mô hình tin nhắn publish/subscribe, môi trường băng thông thấp, mạng cảm biến phân tán, hoặc khi bạn cần phân phối tin nhắn đáng tin cậy với tự động kết nối lại.

Bỏ qua thiết lập thủ công

Mô tả tích hợp MQTT của bạn bằng tiếng Anh đơn giản và Auto-Integration Builder sẽ tạo ra một flow Node-RED hoàn chỉnh cho bạn trong vài giây.

Điều Kiện Tiên Quyết

  • Hệ thống camera OV10i đã được thiết lập và kết nối
  • Kết nối mạng giữa camera và MQTT broker
  • MQTT broker khả dụng (local hoặc cloud)
  • Hiểu biết cơ bản về các khái niệm MQTT (topics, publish/subscribe)
  • Recipe đang hoạt động đã được cấu hình trên camera

Tổng Quan Về Giao Tiếp MQTT

Các Khái Niệm Chính Của MQTT:

  • Broker: Máy chủ trung tâm định tuyến tin nhắn giữa các client
  • Topics: Các danh mục tin nhắn (ví dụ: "camera/status", "commands/trigger")
  • Publish: Gửi tin nhắn đến một topic
  • Subscribe: Nhận tin nhắn từ một topic
  • QoS: Các cấp độ Chất Lượng Dịch Vụ (0, 1, 2)

Bước 1: Xác Minh Cấu Hình Mạng

1.1 Kiểm Tra Cài Đặt Mạng Camera

  1. Điều hướng đến System Settings
  2. Ghi chú địa chỉ IP camera (ví dụ: 192.168.0.100)
  3. Xác minh kết nối mạng đến MQTT broker

1.2 Yêu Cầu Về MQTT Broker

Đảm bảo khả năng truy cập MQTT broker:

  • Cùng mạng: Camera phải tiếp cận được địa chỉ IP của broker
  • Truy cập cổng: Cổng MQTT mặc định 1883 (hoặc 8883 cho TLS)
  • Xác thực: Username/password nếu broker yêu cầu
  • Firewall: Cho phép lưu lượng MQTT trên các cổng cần thiết

1.3 Yêu Cầu Mạng

Thành PhầnĐịa Chỉ IPCổngGhi Chú
Camera192.168.0.100N/APhải tiếp cận được broker
MQTT Broker192.168.0.2001883Cổng MQTT tiêu chuẩn
Thiết Bị Client192.168.0.xxxThay đổiBất kỳ thiết bị nào subscribe

Bước 2: Truy Cập Node-RED Editor

2.1 Điều Hướng Đến IO Block

  1. Mở recipe đang hoạt động trong Recipe Editor
  2. Nhấp vào Configure IO hoặc chọn IO Block trong menu breadcrumb để vào Node-RED editor

2.2 Xác Minh Các MQTT Nodes Khả Dụng

Kiểm tra bảng Node-RED cho các MQTT nodes:

  • mqtt in - Subscribe vào các MQTT topics
  • mqtt out - Publish đến các MQTT topics

Điểm kiểm tra: Bạn sẽ thấy các MQTT nodes trong mục Network ở bảng bên trái.

Bước 3: Cấu Hình Kết Nối MQTT Broker

3.1 Thêm Cấu Hình MQTT Broker

  1. Kéo node "mqtt in" lên canvas (để thiết lập ban đầu)
  2. Nhấp đúp vào node để mở cấu hình
  3. Nhấp vào biểu tượng bút chì bên cạnh trường Server
  4. Nhấp vào "Add new mqtt-broker"

3.2 Cấu Hình Cài Đặt Broker

Cấu Hình Broker Cơ Bản:

Cài ĐặtGiá TrịMô Tả
NameCamera MQTT BrokerĐịnh danh mô tả
Server192.168.0.200Địa chỉ IP MQTT broker
Port1883Cổng MQTT tiêu chuẩn
ProtocolMQTT V3.1.1Phiên bản được khuyến nghị
Client ID(tự động tạo)Để trống để tự động

3.3 Cài Đặt Xác Thực (Nếu Yêu Cầu)

Nếu broker yêu cầu xác thực:

Cài ĐặtMô Tả
UsernameTên người dùng MQTT broker
PasswordMật khẩu MQTT broker
Use TLSBật cho kết nối bảo mật (port 8883)

3.4 Cài Đặt Nâng Cao

Tùy Chọn Kết Nối:

Cài ĐặtGiá Trị Khuyến NghịMô Tả
Keep Alive60 giâyKhoảng thời gian heartbeat
Clean SessionTrueBắt đầu mới mỗi lần kết nối
Auto ConnectTrueTự động kết nối lại

3.5 Lưu Cấu Hình Broker

  1. Nhấp "Add" để lưu cài đặt broker
  2. Nhấp "Done" để đóng cấu hình node
  3. Cấu hình broker giờ đây có sẵn cho tất cả các node MQTT

Bước 4: Cấu Hình MQTT Input (Subscribe)

4.1 Thiết Lập Node MQTT In

  1. Chọn node "mqtt in" mà bạn đã thêm
  2. Nhấp đúp để cấu hình
  3. Cấu hình cài đặt subscription:

4.2 Cấu Hình MQTT In

Cài Đặt Subscription:

Cài ĐặtGiá Trị Ví DụMô Tả
ServerCamera MQTT BrokerChọn broker đã cấu hình
Topiccamera/commandsTopic để subscribe
QoS0Chất lượng phân phối tin nhắn
Outputauto-detectĐịnh dạng tin nhắn
NameCommand ListenerĐịnh danh node

4.3 Quy Ước Đặt Tên Topic

Cấu trúc topic khuyến nghị:

Mục ĐíchVí Dụ TopicSử Dụng
Commandscamera/commandsNhận lệnh điều khiển
Status requestscamera/status/requestYêu cầu thông tin trạng thái
Configurationcamera/configThay đổi cấu hình

4.4 Cấu Hình Xử Lý Tin Nhắn

  1. Thêm node "debug" để giám sát tin nhắn đến
  2. Kết nối: MQTT In → Debug
  3. Cấu hình node debug để hiển thị tin nhắn đầy đủ

Bước 5: Cấu Hình MQTT Output (Publish)

5.1 Thêm Node MQTT Out

  1. Kéo node "mqtt out" vào canvas
  2. Nhấp đúp để cấu hình
  3. Chọn cùng cấu hình broker

5.2 Cấu Hình MQTT Out

Cài Đặt Publishing:

Cài ĐặtGiá Trị Ví DụMô Tả
ServerCamera MQTT BrokerCùng broker với input
Topiccamera/responsesTopic cho phản hồi từ camera
QoS0Chất lượng phân phối tin nhắn
RetainFalseKhông lưu tin nhắn cuối
NameResponse PublisherĐịnh danh node

5.3 Cấu Trúc Topic Phản Hồi

Topic phản hồi khuyến nghị:

Loại Phản HồiVí Dụ TopicSử Dụng
Status updatescamera/statusThông tin trạng thái camera
Resultscamera/resultsKết quả inspection
Acknowledgmentscamera/ackXác nhận lệnh

Bước 6: Tạo Flow Giao Tiếp Cơ Bản

6.1 Xây Dựng Flow Tin Nhắn Đi

Tạo flow để publish tin nhắn từ camera:

  1. Thêm node "inject" để kích hoạt tin nhắn
  2. Thêm node "function" để định dạng tin nhắn
  3. Thêm node "mqtt out" để publish
  4. Kết nối: Inject → Function → MQTT Out

6.2 Xây Dựng Flow Tin Nhắn Đến

Tạo một flow riêng để nhận tin nhắn:

  1. Thêm node "mqtt in" để subscribe
  2. Thêm node "debug" để giám sát
  3. Kết nối: MQTT In → Debug

6.3 Cấu Hình Inject Node

  1. Nhấp đúp vào inject node
  2. Cấu hình các thiết lập:
    • Name: "Send Test Message"
    • Payload: Timestamp
    • Topic: (để trống)
  3. Nhấp "Done"

6.4 Cấu Hình Function Node

Định dạng tin nhắn đơn giản:

// Format outgoing message
msg.topic = "camera/status";
msg.payload = "Camera online - " + new Date().toISOString();
return msg;

  1. Nhấp đúp vào function node
  2. Sao chép đoạn mã ở trên vào tab "On Message"
  3. Name: "Format Message"
  4. Nhấp "Done"

6.5 Cấu Hình MQTT Out Node

  1. Nhấp đúp vào mqtt out node
  2. Chọn broker: Camera MQTT Broker (đã cấu hình trước đó)
  3. Topic: (để trống - được thiết lập bởi function node)
  4. Name: "Publish Status"
  5. Nhấp "Done"

6.6 Cấu Hình MQTT In Node

  1. Nhấp đúp vào mqtt in node
  2. Chọn broker: Camera MQTT Broker
  3. Topic: camera/commands
  4. Name: "Command Listener"
  5. Nhấp "Done"

6.7 Cấu Hình Debug Node

  1. Nhấp đúp vào debug node
  2. Output: Complete msg object
  3. Name: "Incoming Messages"
  4. Nhấp "Done"

6.8 Cấu Trúc Flow Cuối Cùng

Flow hoàn chỉnh của bạn sẽ là:

Outgoing: Inject → Function → MQTT Out Incoming: MQTT In → Debug

Bước 7: Deploy và Kiểm Tra Cấu Hình

7.1 Deploy Flow

  1. Nhấp nút "Deploy" (góc trên bên phải)
  2. Xác nhận thông báo deploy thành công
  3. Kiểm tra các chỉ báo trạng thái của node:
    • Chấm xanh lá: Đã kết nối với broker
    • Chấm đỏ: Kết nối thất bại
    • Chấm vàng: Đang kết nối

7.2 Kiểm Tra Giao Tiếp Nội Bộ

Kiểm tra tính năng publish MQTT của camera:

  1. Nhấp nút inject để gửi tin nhắn kiểm tra
  2. Xác nhận MQTT Out node hiển thị hoạt động
  3. Kiểm tra debug panel nếu bạn có tin nhắn từ bên ngoài

7.3 Kiểm Tra Bên Ngoài (Tùy Chọn)

Kiểm tra với MQTT client bên ngoài để gửi lệnh đến camera:

Sử dụng công cụ dòng lệnh:

# Send a test command to the camera
mosquitto_pub -h 192.168.0.100 -t "camera/commands" -m "test_command"

Kết quả mong đợi: Debug node sẽ hiển thị tin nhắn đến trong debug panel của Node-RED.

7.4 Xác Minh Giao Tiếp

Kiểm tra các khía cạnh sau:

Kiểm TraKết Quả Mong ĐợiTrạng Thái
Kết nối brokerTrạng thái xanh lá trên các MQTT node
Publish tin nhắnInject kích hoạt MQTT Out thành công
Nhận tin nhắnDebug hiển thị tin nhắn từ bên ngoài
Kết nối lạiTự động kết nối lại sau khi mạng bị gián đoạn

Bước 8: Khắc Phục Sự Cố MQTT

8.1 Vấn Đề Kết Nối

Vấn ĐềTriệu ChứngGiải Pháp
Không thể kết nối với brokerChỉ báo trạng thái đỏKiểm tra IP và port của broker
Xác thực thất bạiKết nối bị từ chốiXác minh username/password
Mạng hết thời gian chờTrạng thái đang kết nối màu vàngKiểm tra kết nối mạng
Firewall chặnKhông có nỗ lực kết nốiMở các cổng MQTT

8.2 Vấn Đề Tin Nhắn

Vấn ĐềTriệu ChứngGiải Pháp
Không nhận được tin nhắnDebug không hiển thị gìKiểm tra các topic subscription
Tin nhắn không được publishCác client bên ngoài không thấy gìXác minh các publish topic
Lỗi định dạng tin nhắnPhân tích thất bạiSử dụng tin nhắn văn bản đơn giản
Mất tin nhắnTruyền tải không liên tụcKiểm tra kết nối broker

8.3 Vấn Đề Về Hiệu Suất

Vấn đềTriệu chứngGiải pháp
Độ trễ caoTin nhắn được gửi chậm trễKiểm tra hiệu suất broker
Mất kết nốiKết nối lại thường xuyênĐiều chỉnh cài đặt keep-alive
Tràn tin nhắnBroker quá tảiTriển khai throttling tin nhắn

8.4 Kỹ Thuật Debug

Khắc phục sự cố có hệ thống:

  1. Kiểm tra trạng thái kết nối broker trong Node-RED
  2. Theo dõi bảng debug Node-RED để xem luồng tin nhắn
  3. Sử dụng tin nhắn văn bản đơn giản trước khi dùng dữ liệu phức tạp
  4. Xác minh kết nối mạng bằng ping
  5. Kiểm tra với topic cơ bản trước khi triển khai luồng nâng cao

Thành Công! Giao Tiếp MQTT Của Bạn Đã Sẵn Sàng

Hệ thống giao tiếp MQTT của bạn giờ có thể:

  • Kết nối đến MQTT broker với xác thực phù hợp
  • Subscribe đến topic để nhận lệnh và dữ liệu
  • Publish tin nhắn để cập nhật trạng thái và phản hồi
  • Xử lý định dạng tin nhắn JSON cho giao tiếp có cấu trúc
  • Tự động kết nối lại sau khi mạng bị gián đoạn
  • Hỗ trợ nhiều cấp QoS cho các mức ưu tiên tin nhắn khác nhau

Bảo Trì Liên Tục

Kiểm Tra Hệ Thống Định Kỳ

  • Theo dõi trạng thái kết nối broker trong Node-RED
  • Xác minh việc gửi tin nhắn bằng tin nhắn kiểm tra
  • Kiểm tra log của broker để phát hiện các mẫu lỗi
  • Cập nhật thông tin xác thực khi cần thiết

Giám Sát Hiệu Suất

  • Theo dõi độ trễ tin nhắn và thời gian gửi
  • Giám sát sử dụng tài nguyên broker để đảm bảo khả năng mở rộng
  • Phân tích mẫu sử dụng topic để tối ưu hóa
  • Xem xét cài đặt QoS dựa trên yêu cầu thực tế

Các Bước Tiếp Theo

Sau khi thiết lập giao tiếp MQTT cơ bản:

  1. Triển khai các quy trình nhắn tin cụ thể cho ứng dụng của bạn
  2. Thiết lập phân cấp topic để tổ chức giao tiếp
  3. Bổ sung các biện pháp bảo mật như mã hóa TLS
  4. Tích hợp với các hệ thống bên ngoài bằng giao thức MQTT tiêu chuẩn
  5. Tạo dashboard giám sát cho tình trạng hệ thống
Tự động tạo luồng MQTT

Integration Builder có thể tạo các luồng giao tiếp MQTT hoàn chỉnh từ mô tả bằng tiếng Anh thông thường. Mô tả mẫu nhắn tin của bạn (ví dụ: "publish kết quả kiểm tra lên một MQTT topic với trạng thái pass/fail và điểm tin cậy") và nhận được luồng Node-RED sẵn sàng cho môi trường production chỉ trong vài giây.

🔗 Xem Thêm