기술나눔

EMQX Flask InfluxDB Grafana 기반 다중 프로토콜 IoT 클라우드 플랫폼 구축: MQTT/HTTP 장치 액세스 및 데이터 시각화 프로세스(코드 예제 포함)

2024-07-12

한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina

요약: 이 글에서는 사물 인터넷, 클라우드 플랫폼, MQTT, HTTP, 데이터 시각화 등의 핵심 개념을 간단하고 이해하기 쉽게 소개하며, EMQX, Flask, InfluxDB, Grafana 등의 주류 도구를 결합하여 가르칩니다. 여러 프로토콜을 지원하는 사물 인터넷 클라우드 플랫폼을 구축하는 방법을 단계별로 설명합니다. 기사는 명확한 구조와 그림, 텍스트로 구성되어 있으며, 코드는 유익하고 이해하기 쉽습니다. 독자가 IoT 클라우드 플랫폼 구축의 핵심 기술을 빠르게 익힐 수 있도록 구성되었습니다.

핵심 단어:IoT, 클라우드 플랫폼, MQTT, HTTP, 데이터 시각화, EMQX, Flask, InfluxDB, Grafana


1. 사물인터넷 기본지식

1.1 사물인터넷 개요

사물 인터넷(IoT, Internet of Things)은 다양한 정보 센서, 무선 주파수 식별 기술, GPS(Global Positioning System) 등을 통해 모니터링, 연결 및 상호 작용해야 하는 모든 개체 또는 프로세스를 실시간으로 수집하는 것을 말합니다. 사물과 사물, 사물과 사람 사이의 유비쿼터스 커뮤니케이션을 실현합니다. 이를 통해 항목과 프로세스에 대한 지능적인 인식, 식별 및 관리를 달성할 수 있습니다.

1.2 IoT 아키텍처

IoT 시스템 아키텍처는 일반적으로 세 가지 계층으로 나뉩니다.

  • 인식 레이어:각종 센서, RFID 태그, GPS 모듈 등 데이터 수집을 담당합니다.
  • 네트워크 계층:WiFi, Bluetooth, Zigbee, NB-IoT 등 다양한 네트워크 프로토콜, 통신 기술 등을 포함한 데이터 전송을 담당합니다.
  • 애플리케이션 계층:데이터 분석, 원격제어, 지능형 의사결정 등 데이터 처리 및 애플리케이션 프리젠테이션을 담당합니다.

2. 클라우드 플랫폼 및 데이터 시각화

2.1 클라우드 플랫폼

클라우드 플랫폼은 인터넷 기반 관련 서비스의 추가, 사용 및 제공 모델을 말하며 일반적으로 인터넷을 통해 동적으로 확장 가능하고 종종 가상화되는 리소스를 제공하는 것을 포함합니다. 클라우드 플랫폼은 IoT 애플리케이션을 위한 강력한 컴퓨팅, 스토리지 및 네트워크 리소스를 제공하여 IoT 애플리케이션 개발 및 배포 비용을 절감할 수 있습니다.

2.2 데이터 시각화

데이터 시각화란 데이터를 그래픽, 차트 등의 시각적 형태로 표시하여 사용자가 데이터를 보다 직관적으로 이해하고 데이터 이면의 패턴과 추세에 대한 통찰력을 얻을 수 있도록 돕는 것을 의미합니다.

3. 일반적으로 사용되는 프로토콜 및 도구 소개

3.1 MQTT 프로토콜

MQTT(Message Queuing Telemetry Transport)는 저대역폭, 저전력 장치 및 네트워크용으로 설계된 경량 메시지 게시/구독 프로토콜입니다. MQTT는 사물인터넷 분야에서 널리 사용되며, 특히 리소스가 제한된 장치와 신뢰할 수 없는 네트워크 환경에 적합합니다.

3.2 HTTP 프로토콜

HTTP(Hypertext Transfer Protocol)는 웹 브라우저와 웹 서버 간에 정보를 전송하는 데 사용되는 응용 프로그램 계층 프로토콜입니다. HTTP 프로토콜은 간단하고 사용하기 쉬우며 사물 인터넷을 포함한 다양한 네트워크 애플리케이션에서 널리 사용됩니다.

3.3 EMQX

EMQX는 수백만 개의 동시 연결 및 메시지 처리량을 지원하는 확장 가능한 고성능 오픈 소스 MQTT 메시지 서버입니다.

3.4 플라스크

Flask는 Python으로 작성된 경량 웹 애플리케이션 프레임워크로, 배우고 사용하기 쉽고 웹 애플리케이션과 API 인터페이스를 빠르게 구축하는 데 적합합니다.

3.5 인플럭스DB

InfluxDB는 시계열 데이터 저장 및 조회를 위해 설계된 오픈소스 시계열 데이터베이스로, IoT 센서 데이터 저장, 모니터링 데이터 등에 적합합니다.

3.6 그라파나

Grafana는 여러 데이터 소스를 연결하여 아름답고 강력한 대시보드를 만들고 데이터를 실시간으로 표시할 수 있는 오픈 소스 데이터 시각화 도구입니다.

4. 멀티 프로토콜 IoT 클라우드 플랫폼 구축

이 프로젝트는 다음 기능을 달성하기 위해 MQTT 및 HTTP 프로토콜을 지원하는 IoT 클라우드 플랫폼을 구축합니다.

  • 다중 프로토콜 지원: MQTT 및 HTTP 프로토콜을 모두 사용하여 장치 액세스를 지원합니다.
  • 데이터 수집 및 저장: 다양한 프로토콜 장치에서 실시간으로 데이터를 수집하여 InfluxDB 데이터베이스에 저장합니다.
  • 데이터 시각화: Grafana를 사용하여 수집된 데이터를 시각적으로 표시합니다.
4.1 시스템 아키텍처

 

4.2 코드 구현

1. HTTP 서버 구축(Flask)

  1. # 导入 Flask 库
  2. from flask import Flask, request, jsonify
  3. # 创建 Flask 应用
  4. app = Flask(__name__)
  5. # 定义 HTTP 接口,接收 POST 请求
  6. @app.route('/data', methods=['POST'])
  7. def receive_data():
  8. # 获取请求数据
  9. data = request.get_json()
  10. # 数据处理逻辑,例如数据校验、格式转换等
  11. # ...
  12. # 将数据写入 InfluxDB (示例)
  13. from influxdb import InfluxDBClient
  14. client = InfluxDBClient('localhost', 8086, 'user', 'password', 'iot_data')
  15. json_body = [
  16. {
  17. "measurement": "sensor_data",
  18. "tags": {
  19. "sensor_id": data.get("sensor_id")
  20. },
  21. "fields": {
  22. "temperature": data.get("temperature"),
  23. "humidity": data.get("humidity")
  24. }
  25. }
  26. ]
  27. client.write_points(json_body)
  28. # 返回响应
  29. return jsonify({'message': 'Data received successfully!'}), 200
  30. # 启动 Flask 应用
  31. if __name__ == '__main__':
  32. app.run(debug=True)

코드 설명:

  • 사용Flask프레임워크는 HTTP 서버를 생성하고 정의합니다./data인터페이스는 POST 요청을 수신합니다.
  • 사용request.get_json()HTTP 요청에서 JSON 데이터를 가져옵니다.
  • 데이터 검증, 형식 변환 등의 데이터 처리를 수행합니다.
  • 사용InfluxDBClientInfluxDB 데이터베이스에 연결하고 데이터베이스에 데이터를 씁니다.
  • 클라이언트에게 데이터 수신이 성공했음을 알리기 위해 JSON 형식으로 응답을 반환합니다.

2. MQTT 메시지 처리(Python)

  1. # 导入必要的库
  2. import paho.mqtt.client as mqtt
  3. from influxdb import InfluxDBClient
  4. import json
  5. # MQTT Broker 配置
  6. MQTT_BROKER = "localhost"
  7. MQTT_PORT = 1883
  8. MQTT_TOPIC = "sensor/data"
  9. # InfluxDB 配置
  10. INFLUXDB_HOST = "localhost"
  11. INFLUXDB_PORT = 8086
  12. INFLUXDB_USER = "user"
  13. INFLUXDB_PASSWORD = "password"
  14. INFLUXDB_DATABASE = "iot_data"
  15. # 创建 InfluxDB 客户端
  16. influxdb_client = InfluxDBClient(
  17. host=INFLUXDB_HOST,
  18. port=INFLUXDB_PORT,
  19. username=INFLUXDB_USER,
  20. password=INFLUXDB_PASSWORD,
  21. database=INFLUXDB_DATABASE
  22. )
  23. # 连接到 MQTT Broker
  24. def on_connect(client, userdata, flags, rc):
  25. print("Connected to MQTT Broker with result code " + str(rc))
  26. client.subscribe(MQTT_TOPIC)
  27. # 接收 MQTT 消息
  28. def on_message(client, userdata, msg):
  29. # 解析数据
  30. data = json.loads(msg.payload.decode())
  31. # 构建 InfluxDB 数据点
  32. influxdb_data = [
  33. {
  34. "measurement": "sensor_data",
  35. "tags": {
  36. "sensor_id": data.get("sensor_id"),
  37. },
  38. "fields": {
  39. "temperature": data.get("temperature"),
  40. "humidity": data.get("humidity"),
  41. }
  42. }
  43. ]
  44. # 写入 InfluxDB
  45. influxdb_client.write_points(influxdb_data)
  46. print("Data written to InfluxDB: " + str(influxdb_data))
  47. # 创建 MQTT 客户端
  48. mqtt_client = mqtt.Client()
  49. mqtt_client.on_connect = on_connect
  50. mqtt_client.on_message = on_message
  51. mqtt_client.connect(MQTT_BROKER, MQTT_PORT, 60)
  52. # 启动 MQTT 客户端
  53. mqtt_client.loop_start()
  54. # 保持程序运行
  55. while True:
  56. pass

코드 설명:

  • 사용paho.mqtt.clientMQTT 브로커에 연결하고 지정된 주제를 구독합니다.
  • MQTT 메시지가 수신되면 다음을 사용하십시오.json.loads()메시지 내용을 구문 분석합니다.
  • 구문 분석된 데이터를 InfluxDB 데이터 포인트 형식으로 빌드합니다.
  • 사용influxdb_client.write_points()InfluxDB 데이터베이스에 데이터를 씁니다.

3. 데이터 시각화(Grafana)

  • Grafana를 설치하고 InfluxDB 데이터베이스에 연결하도록 데이터 소스를 구성합니다.
  • 대시보드를 생성하고 대시보드에 꺾은선형 차트, 막대형 차트 등의 차트를 추가하세요.
  • 차트의 데이터 소스를 InfluxDB로 구성하고 InfluxDB에서 데이터를 가져오는 쿼리문을 작성합니다.
  • 데이터 표시를 보다 직관적이고 이해하기 쉽게 만들기 위해 필요에 따라 차트의 스타일, 제목, 축 및 기타 속성을 구성합니다.

예제 Grafana 쿼리 문:

SELECT "temperature", "humidity" FROM "sensor_data" WHERE time > now() - 1h

쿼리는 다음에서 시작됩니다.sensor_data측정 마지막 시간의 온도, 습도 데이터를 조회합니다.

이 프로젝트는 Flask, EMQX, InfluxDB 및 Grafana와 같은 도구를 결합하여 MQTT 및 HTTP 프로토콜을 지원하고 데이터 수집, 저장 및 시각적 표시를 실현하는 IoT 클라우드 플랫폼을 구축합니다. 플랫폼은 더 많은 유형의 장치와 프로토콜 액세스를 지원하도록 유연하게 확장할 수 있으며 실제 필요에 따라 기능을 사용자 정의할 수 있습니다.

알아채다:

  • 위의 코드는 단지 참조용이며 실제 애플리케이션의 특정 요구에 따라 수정되어야 합니다.
  • 모든 종속 라이브러리가 설치되어 있는지 확인하십시오.paho-mqttinfluxdbflask기다리다.
  • 실제 배포에서는 데이터 보안, 시스템 안정성 등의 요소를 고려해야 합니다.

구체적인 코드나 아이디어를 원하시면 개인 메시지를 보내주세요! ! !