[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"academy-blogs-en-1-1-all-ep117-iot-multi-device-websocket-all--*":3,"academy-blog-translations-nboyiqnzglp5uh7":79},{"data":4,"page":67,"perPage":67,"totalItems":67,"totalPages":67},[5],{"alt":6,"collectionId":7,"collectionName":8,"content":9,"cover_image":10,"cover_image_path":11,"created":12,"created_by":13,"expand":14,"id":73,"keywords":74,"locale":49,"published_at":75,"scheduled_at":13,"school_blog":71,"short_description":76,"slug":77,"status":69,"title":6,"updated":78,"updated_by":13,"views":72},"EP.117 Connecting Multiple IoT Devices with WebSocket (Real-time IoT Network)","sclblg987654321","school_blog_translations","\u003Cp>Modern IoT systems no longer consist of just a single device. Instead, they involve hundreds or thousands of devices working in parallel, such as:\u003C\u002Fp>\u003Cul>\u003Cli>Temperature &amp; humidity sensors\u003C\u002Fli>\u003Cli>Smart home devices\u003C\u002Fli>\u003Cli>Industrial machines and robots\u003C\u002Fli>\u003Cli>GPS trackers and vehicle monitoring systems\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>All of them require real-time, stable, energy-efficient, and secure communication.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>Why WebSocket is Ideal for IoT?\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>WebSocket is one of the most effective technologies for real-time IoT communication, because it offers:\u003C\u002Fp>\u003Cp>✅ Persistent connection with continuous data transfer\u003Cbr>✅ Ultra-low latency (milliseconds)\u003Cbr>✅ Bandwidth efficiency\u003Cbr>✅ Full-duplex communication (two-way)\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🧱 1. Real-time IoT Architecture Using WebSocket\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>A typical real-time IoT system consists of four core components:\u003C\u002Fp>\u003Ch3>1) IoT Device (Client)\u003C\u002Fh3>\u003Cp>Could be a sensor, ESP32, Raspberry Pi, or even a mobile app. These devices initiate the WebSocket connection.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>2) WebSocket Gateway (Server)\u003C\u002Fh3>\u003Cp>Responsible for:\u003C\u002Fp>\u003Cul>\u003Cli>Authenticating devices\u003C\u002Fli>\u003Cli>Receiving and sending sensor data\u003C\u002Fli>\u003Cli>Forwarding data to a database or message broker\u003C\u002Fli>\u003Cli>Broadcasting real-time updates to a dashboard\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>3) Message Broker \u002F Data Stream Layer\u003C\u002Fh3>\u003Cp>Such as Redis Pub\u002FSub, Kafka, or NATS used to route sensor data to multiple services in parallel.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>4) Monitoring Dashboard\u003C\u002Fh3>\u003Cp>A real-time dashboard to monitor device data (e.g., a screen showing machine statuses in a factory).\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔐 2. Device Authentication (Security First!)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Security is the top priority in IoT. Each device must be authenticated properly.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>Common techniques:\u003C\u002Fh3>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✅ Device Token\u003Cbr>Assign a unique token for each device:\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-json\">{\n  \"device_id\": \"SENSOR-01\",\n  \"device_secret\": \"98asdh9283dj29\"\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✅ JWT with Device ID\u003Cbr>More suitable for large-scale IoT platforms.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✅ IP Whitelisting\u003Cbr>Used in closed networks (e.g., factories, labs).\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>📡 3. Device-to-Connection Mapping (Server Side)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>You need to map each device to its WebSocket connection:\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">var devices = make(map[string]*websocket.Conn)\n\ntype DeviceAuth struct {\n    DeviceID string `json:\"device_id\"`\n    Token    string `json:\"token\"`\n}\n\nfunc handleDevice(c *websocket.Conn) {\n    var auth DeviceAuth\n    c.ReadJSON(&amp;auth)\n\n    if !validateToken(auth.DeviceID, auth.Token) {\n        c.WriteMessage(websocket.TextMessage, []byte(\"AUTH_FAILED\"))\n        c.Close()\n        return\n    }\n\n    devices[auth.DeviceID] = c\n    fmt.Println(\"Device connected:\", auth.DeviceID)\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>📊 4. Real-time Sensor Data Transmission\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Example of sensor payload:\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-json\">{\n  \"device_id\": \"TEMP-01\",\n  \"temperature\": 26.5,\n  \"humidity\": 80\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Server-side Go code to listen and broadcast:\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">type SensorData struct {\n    DeviceID    string  `json:\"device_id\"`\n    Temperature float64 `json:\"temperature\"`\n    Humidity    float64 `json:\"humidity\"`\n}\n\nfunc listenDevice(deviceID string, conn *websocket.Conn) {\n    for {\n        var data SensorData\n        if err := conn.ReadJSON(&amp;data); err != nil {\n            delete(devices, deviceID)\n            return\n        }\n\n        broadcastToDashboard(data)\n    }\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔄 5. Bandwidth Management (Prevent Server Overload)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Some sensors send data every 100ms this can easily overwhelm your system.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>Techniques to manage this:\u003C\u002Fh3>\u003Cp>✅ Rate Limiting per Device\u003Cbr>Example: Max 10 messages per second.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✅ Message Aggregation\u003Cbr>Combine multiple data points into one message.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✅ Adaptive Data Rate\u003Cbr>Increase frequency only on abnormal values; reduce when values are stable.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✅ Compression\u003Cbr>Use GZIP or Protocol Buffers (Protobuf) to reduce payload size.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🖥 6. Dashboard Listener Example (WebSocket Client in Go)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">func dashboardListener() {\n    conn, _, err := websocket.DefaultDialer.Dial(\"ws:\u002F\u002Flocalhost:8080\u002Fdashboard\", nil)\n    if err != nil { panic(err) }\n\n    for {\n        _, msg, _ := conn.ReadMessage()\n        fmt.Println(\"New Sensor Update:\", string(msg))\n    }\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>📈 7. Scaling to Support 10,000+ Devices\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>To scale your IoT system properly, use the following techniques:\u003C\u002Fp>\u003Cp>✅ Horizontal Scaling\u003Cbr>Run multiple WebSocket instances.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✅ Redis Pub\u002FSub\u003Cbr>Sync messages between instances.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✅ Kubernetes + HPA\u003Cbr>Automatically scale based on system load.\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✅ Sharding Devices\u003Cbr>Divide devices into groups (e.g., \u003Ccode inline=\"\">shard-01\u003C\u002Fcode>, \u003Ccode inline=\"\">shard-02\u003C\u002Fcode>, etc.).\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🧪 Test It Yourself!\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Try building a mini IoT demo:\u003C\u002Fp>\u003Col>\u003Cli>Simulate a device using Go or ESP32 that sends temperature data every second\u003C\u002Fli>\u003Cli>WebSocket Server receives and stores the data\u003C\u002Fli>\u003Cli>Dashboard shows real-time data updates\u003C\u002Fli>\u003Cli>Add alert logic when temperature exceeds a threshold\u003C\u002Fli>\u003C\u002Fol>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>This is the foundation of Smart Homes, Smart Factories, and Smart Agriculture systems!\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Chr>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔮 Next Episode AI + WebSocket for IoT\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>In EP.118, we’ll teach you how to build an AI-powered WebSocket system for IoT!\u003C\u002Fp>\u003Cp>You’ll learn:\u003C\u002Fp>\u003Cul>\u003Cli>Real-time anomaly detection\u003C\u002Fli>\u003Cli>Predictive maintenance using ML\u003C\u002Fli>\u003Cli>Automatic alert generation via WebSocket\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>If you complete this you’re on your way to becoming a real-time system pro. 🎯 See you in the next episode!\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cdiv class=\"raw-html-embed\">\u003Cdiv style=\"margin:0 0 6px 0; font-weight:700;\">Read more:\u003C\u002Fdiv>\n\u003Cul style=\"list-style:none; padding:0; margin:0; line-height:1.4;\">\n  \u003Cli style=\"margin:0;\">\u003Ca href=\"\u002Fen\u002Fblogs\u002Fcategories\u002FGolang\" title=\"Golang The Series\">Golang The Series\u003C\u002Fa>\u003C\u002Fli>\n  \u003Cli style=\"margin:0;\">\u003Ca href=\"\u002Fen\u002Fblogs\u002Fcategories\u002FJS2GO\" title=\"JS2GO\">JS2GO\u003C\u002Fa>\u003C\u002Fli>\n  \u003Cli style=\"margin:0;\">\u003Ca href=\"\u002Fen\u002Fblogs\u002Fcategories\u002FTailwind%20CSS\" title=\"Tailwind CSS\">Tailwind CSS\u003C\u002Fa>\u003C\u002Fli>\n\u003C\u002Ful>\u003C\u002Fdiv>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cdiv class=\"raw-html-embed\">\n  \u003Cp style=\"margin:0 0 6px 0;\">\u003Cstrong>Follow Us:\u003C\u002Fstrong>\u003C\u002Fp>\n  \u003Cul style=\"list-style:none; padding:0; margin:0; line-height: 0.4;\">\n    \u003Cli style=\"display:flex; align-items:center; gap:6px; margin:0;\">\n      \n      \u003Csvg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"#1877F2\" aria-hidden=\"true\">\n        \u003Cpath d=\"M22 12.07C22 6.48 17.52 2 11.93 2S2 6.48 2 12.07c0 5 3.66 9.14 8.44 9.93v-7.02H7.9v-2.91h2.54V9.41c0-2.5 1.49-3.88 3.77-3.88 1.09 0 2.24.2 2.24.2v2.46h-1.26c-1.24 0-1.63.77-1.63 1.56v1.87h2.78l-.44 2.91h-2.34V22c4.78-.79 8.44-4.93 8.44-9.93Z\">\u003C\u002Fpath>\n      \u003C\u002Fsvg>\n      \u003Ca href=\"https:\u002F\u002Fwww.facebook.com\u002Fsuperdev.academy.th\" target=\"_blank\" rel=\"nofollow noopener\" title=\"Follow Superdev Academy on Facebook\">Facebook: Superdev Academy\u003C\u002Fa>\n    \u003C\u002Fli>\n\n    \u003Cli style=\"display:flex; align-items:center; gap:6px; margin:0;\">\n      \n      \u003Csvg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"#FF0000\" aria-hidden=\"true\">\n        \u003Cpath d=\"M23.5 6.2a3 3 0 0 0-2.1-2.1C19.5 3.5 12 3.5 12 3.5s-7.5 0-9.4.6A3 3 0 0 0 .5 6.2 31.5 31.5 0 0 0 0 12a31.5 31.5 0 0 0 .5 5.8 3 3 0 0 0 2.1 2.1c1.9.6 9.4.6 9.4.6s7.5 0 9.4-.6a3 3 0 0 0 2.1-2.1A31.5 31.5 0 0 0 24 12a31.5 31.5 0 0 0-.5-5.8ZM9.75 15.02V8.98L15.5 12l-5.75 3.02Z\">\u003C\u002Fpath>\n      \u003C\u002Fsvg>\n      \u003Ca href=\"https:\u002F\u002Fwww.youtube.com\u002F@SuperdevAcademy\" target=\"_blank\" rel=\"nofollow noopener\" title=\"Watch on YouTube\">YouTube: Superdev Academy\u003C\u002Fa>\n    \u003C\u002Fli>\n\n    \u003Cli style=\"display:flex; align-items:center; gap:6px; margin:0;\">\n      \n      \u003Csvg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"#E4405F\" aria-hidden=\"true\">\n        \u003Cpath d=\"M7 2h10a5 5 0 0 1 5 5v10a5 5 0 0 1-5 5H7a5 5 0 0 1-5-5V7a5 5 0 0 1 5-5Zm10 2H7a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V7a3 3 0 0 0-3-3Zm-5 3.5A5.5 5.5 0 1 1 6.5 13 5.5 5.5 0 0 1 12 7.5Zm0 2A3.5 3.5 0 1 0 15.5 13 3.5 3.5 0 0 0 12 9.5Zm5.75-2.75a1.25 1.25 0 1 1-1.25 1.25 1.25 1.25 0 0 1 1.25-1.25Z\">\u003C\u002Fpath>\n      \u003C\u002Fsvg>\n      \u003Ca href=\"https:\u002F\u002Fwww.instagram.com\u002Fsuperdevacademy\u002F?hl=en target=\" _blank\"=\"\" rel=\"nofollow noopener\" title=\"See behind-the-scenes on Instagram\">Instagram: Superdev Academy\u003C\u002Fa>\n    \u003C\u002Fli>\n\n    \u003Cli style=\"display:flex; align-items:center; gap:6px; margin:0;\">\n      \n      \u003Csvg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"#000000\" aria-hidden=\"true\">\n        \u003Cpath d=\"M21 8.12a6.86 6.86 0 0 1-4.8-2V16a6 6 0 1 1-6-6 5.9 5.9 0 0 1 1.63.23V8.05a9.08 9.08 0 0 1-1.63-.15V4.5a6.86 6.86 0 0 0 4.8 2.05V6.5a6.86 6.86 0 0 0 4.8 1.62ZM9.2 12.5A3.5 3.5 0 1 0 12.7 16V9.94a6 6 0 0 1-1.63-.27v3.95a3.5 3.5 0 0 1-1.87 3.17 3.5 3.5 0 0 1-4.78-3.23 3.5 3.5 0 0 1 4.78-3.06Z\">\u003C\u002Fpath>\n      \u003C\u002Fsvg>\n      \u003Ca href=\"https:\u002F\u002Fwww.tiktok.com\u002F@superdevacademy\" target=\"_blank\" rel=\"nofollow noopener\" title=\"Watch short tips on TikTok\">TikTok: @superdevacademy\u003C\u002Fa>\n    \u003C\u002Fli>\n\n    \u003Cli style=\"display:flex; align-items:center; gap:6px; margin:0;\">\n      \n      \u003Csvg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"#111827\" aria-hidden=\"true\">\n        \u003Cpath d=\"M12 2a10 10 0 1 0 10 10A10.01 10.01 0 0 0 12 2Zm6.93 6h-3.26a15.6 15.6 0 0 0-1.39-3.62A8.03 8.03 0 0 1 18.93 8ZM12 4c.73.93 1.7 2.74 2.2 4H9.8C10.3 6.74 11.27 4.93 12 4ZM8.72 4.38A15.6 15.6 0 0 0 7.32 8H4.07a8.03 8.03 0 0 1 4.65-3.62ZM4.07 16h3.25a15.6 15.6 0 0 0 1.4 3.62A8.03 8.03 0 0 1 4.07 16ZM12 20c-.73-.93-1.7-2.74-2.2-4h4.4C13.7 17.26 12.73 19.07 12 20Zm3.28-.38A15.6 15.6 0 0 0 16.68 16h3.25a8.03 8.03 0 0 1-4.65 3.62ZM20 14h-3.54a13.8 13.8 0 0 1-.26-4H20a7.98 7.98 0 0 1 0 4Zm-12.2 0H4a7.98 7.98 0 0 1 0-4h3.54a13.8 13.8 0 0 1-.26 4Zm2 .5h4.4a17.8 17.8 0 0 1-.72-4.5c0-1.58.25-3.1.72-4.5H9.8a17.8 17.8 0 0 1 .72 4.5c0 1.58-.25 3.1-.72 4.5Z\">\u003C\u002Fpath>\n      \u003C\u002Fsvg>\n      \u003Ca href=\"https:\u002F\u002Fwww.superdevacademy.com\u002F\" target=\"_blank\" rel=\"noopener\" title=\"Visit the official website of Superdev Academy\">Official Website: Superdev Academy.com\u003C\u002Fa>\n    \u003C\u002Fli>\n  \u003C\u002Ful>\n\u003C\u002Fdiv>\u003Cp>&nbsp;\u003C\u002Fp>","cover_image_ep_ljh8lpgnxz.eswithWebSocket.webp","https:\u002F\u002Ftwsme-r2.tumwebsme.com\u002Fsclblg987654321\u002Fspxc3if2zeefxzq\u002Fcover_image_ep_ljh8lpgnxz.eswithWebSocket.webp","2026-03-04 08:45:04.458Z","",{"keywords":15,"locale":43,"school_blog":53},[16,23,28,33,38],{"collectionId":17,"collectionName":18,"created":19,"created_by":13,"id":20,"name":21,"updated":22,"updated_by":13},"sclkey987654321","school_keywords","2026-03-04 08:44:49.054Z","vbjgbr5ah0kh43p","Real-time System","2026-04-10 16:12:50.311Z",{"collectionId":17,"collectionName":18,"created":24,"created_by":13,"id":25,"name":26,"updated":27,"updated_by":13},"2026-03-04 08:44:56.136Z","1ant8hjpcxuj8a2","IoT","2026-04-10 16:12:51.845Z",{"collectionId":17,"collectionName":18,"created":29,"created_by":13,"id":30,"name":31,"updated":32,"updated_by":13},"2026-03-04 08:20:14.253Z","ah6lvy4x8qe08l5","Golang","2026-04-10 16:07:26.172Z",{"collectionId":17,"collectionName":18,"created":34,"created_by":13,"id":35,"name":36,"updated":37,"updated_by":13},"2026-03-04 08:34:00.920Z","ecac9y661or1xka","WebSocket","2026-04-10 16:08:05.227Z",{"collectionId":17,"collectionName":18,"created":39,"created_by":13,"id":40,"name":41,"updated":42,"updated_by":13},"2026-03-04 08:20:11.547Z","ey3puyme01a9bsw","Go","2026-04-10 16:07:25.893Z",{"code":44,"collectionId":45,"collectionName":46,"created":47,"flag":48,"id":49,"is_default":50,"label":51,"updated":52},"en","pbc_1989393366","locales","2026-01-22 11:00:02.726Z","twemoji:flag-united-states","qv9c1llfov2d88z",false,"English","2026-04-10 15:42:46.825Z",{"category":54,"collectionId":55,"collectionName":56,"expand":57,"id":71,"views":72},"wqxt7ag2gn7xcmk","pbc_2105096300","school_blogs",{"category":58},{"blogIds":59,"collectionId":60,"collectionName":61,"created":62,"created_by":13,"id":54,"image":63,"image_alt":13,"image_path":64,"label":65,"name":66,"priority":67,"publish_at":68,"scheduled_at":13,"status":69,"updated":70,"updated_by":13},[],"sclcatblg987654321","school_category_blogs","2026-03-04 08:33:53.210Z","59ty92ns80w_15oc1implw.png","https:\u002F\u002Ftwsme-r2.tumwebsme.com\u002Fsclcatblg987654321\u002Fwqxt7ag2gn7xcmk\u002F59ty92ns80w_15oc1implw.png",{"en":66,"th":66},"Golang The Series",1,"2026-03-16 04:39:38.440Z","published","2026-04-25 02:32:15.470Z","nboyiqnzglp5uh7",210,"spxc3if2zeefxzq",[20,25,30,35,40],"2025-12-15 01:58:53.801Z","Learn how to build a real-time IoT system using Go and WebSocket that supports thousands of devices. Covers authentication, bandwidth management, and scalable architecture for smart factories and IoT apps.","ep117-iot-multi-device-websocket","2026-04-25 02:47:48.977Z",{"en":77}]