การดู : 287

22/04/2026 07:11น.

EP.32 การเชื่อมต่อ WebSocket กับ Microservices ใน Go เพื่อสร้างระบบที่ยืดหยุ่นและปรับขนาดได้

EP.32 การเชื่อมต่อ WebSocket กับ Microservices ใน Go เพื่อสร้างระบบที่ยืดหยุ่นและปรับขนาดได้

#การออกแบบระบบ

#ระบบเรียลไทม์

#Redis Pub/Sub

#API Gateway

#gRPC

#Load Balancing

#Microservices Architecture

#WebSocket Gateway

#Golang

#Go

#Microservices

#WebSocket

WebSocket กับ Microservices – การออกแบบระบบแบบกระจายตัวใน Go

Microservices คืออะไร และทำไมต้องใช้ร่วมกับ WebSocket?

Microservices เป็นสถาปัตยกรรมที่ช่วยให้แอปพลิเคชันถูกแยกเป็นบริการย่อยๆ (Services) ซึ่งแต่ละบริการสามารถพัฒนาและขยายตัวได้อย่างอิสระ โดยเมื่อใช้งานร่วมกับ WebSocket ซึ่งเป็นโปรโตคอลที่ช่วยให้ระบบสามารถสื่อสารแบบเรียลไทม์ได้ ทำให้สามารถรองรับผู้ใช้งานจำนวนมากและทำงานได้อย่างมีประสิทธิภาพ

 

การสร้าง WebSocket Gateway

package main

import (
    "encoding/json"
    "log"
    "net/http"

    "github.com/gorilla/websocket"
)

var upgrader = websocket.Upgrader{
    CheckOrigin: func(r *http.Request) bool {
        return true
    },
}

type Event struct {
    Service string      `json:"service"`
    Action  string      `json:"action"`
    Data    interface{} `json:"data"`
}

func handleConnections(w http.ResponseWriter, r *http.Request) {
    conn, err := upgrader.Upgrade(w, r, nil)
    if err != nil {
        log.Println("Error upgrading connection:", err)
        return
    }
    defer conn.Close()

    for {
        _, msg, err := conn.ReadMessage()
        if err != nil {
            log.Println("Error reading message:", err)
            break
        }

        var event Event
        if err := json.Unmarshal(msg, &event); err != nil {
            log.Println("Invalid event format:", err)
            continue
        }
    }
}

ท้าให้ลอง!

ลองสร้างระบบแจ้งเตือนแบบเรียลไทม์ที่แยกเป็น Microservices โดยใช้ WebSocket Gateway และ Redis Pub/Sub เพื่อจัดการการแจ้งเตือนให้ผู้ใช้!


EP ถัดไป

ใน EP ถัดไป เราจะพูดถึง การใช้ GraphQL กับ WebSocket เพื่อสร้าง API ที่ทรงพลังและรองรับการทำงานแบบเรียลไทม์!