[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"academy-blogs-th-1-1-all-deploy-websocket-server-kubernetes-production-all--*":3,"academy-blog-translations-jdvfu3khsdfw08k":84},{"data":4,"page":72,"perPage":72,"totalItems":72,"totalPages":72},[5],{"alt":6,"collectionId":7,"collectionName":8,"content":9,"cover_image":10,"cover_image_path":11,"created":12,"created_by":13,"expand":14,"id":78,"keywords":79,"locale":54,"published_at":80,"scheduled_at":13,"school_blog":76,"short_description":81,"slug":82,"status":74,"title":6,"updated":83,"updated_by":13,"views":77},"EP.121 Deploy WebSocket Server บน Kubernetes ให้เสถียรและพร้อมใช้งานจริง","sclblg987654321","school_blog_translations","\u003Cp>เมื่อ WebSocket Server ของคุณ...\u003C\u002Fp>\u003Cul>\u003Cli>รองรับผู้ใช้งานจำนวนมาก\u003C\u002Fli>\u003Cli>ทำงานแบบ Real-time ซับซ้อน (Chat, Game, Whiteboard, IoT)\u003C\u002Fli>\u003Cli>ต้องออนไลน์เสถียร 24\u002F7\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>คำถามสำคัญคือ 👉 จะ Deploy อย่างไรให้ “เสถียร ขยายได้ และพร้อมใช้งานจริงในระดับ Production”?\u003C\u002Fp>\u003Cp>คำตอบคือ: Kubernetes (K8s)\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>บทความนี้จะพาคุณ Deploy WebSocket Server (Go) เข้าสู่ Production Environment อย่างมั่นคง ด้วยเทคนิคที่ใช้ได้จริงในระบบขนาดใหญ่\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🧠 ทำไม WebSocket ต้องใช้ Kubernetes?\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>WebSocket แตกต่างจาก HTTP ธรรมดา เพราะ...\u003C\u002Fp>\u003Cul>\u003Cli>ใช้ การเชื่อมต่อแบบต่อเนื่อง (Long-lived Connection)\u003C\u002Fli>\u003Cli>ต้องจัดการ Connection Lifecycle ที่ซับซ้อน\u003C\u002Fli>\u003Cli>การ Scale ยากกว่าระบบแบบ Request\u002FResponse\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Kubernetes เข้ามาช่วยในเรื่อง:\u003C\u002Fp>\u003Cul>\u003Cli>ควบคุมการทำงานของ WebSocket Server ได้เต็มรูปแบบ\u003C\u002Fli>\u003Cli>รองรับ Auto Scaling\u003C\u002Fli>\u003Cli>บริหาร Load Balancer ให้เชื่อมต่อได้แม่นยำ\u003C\u002Fli>\u003Cli>ลด Downtime เวลาเกิดการเปลี่ยนแปลงในระบบ\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🏗️ ภาพรวมสถาปัตยกรรม (Architecture Overview)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext\">Client\n  ↓\nLoad Balancer (L4\u002FL7)\n  ↓\nKubernetes Service\n  ↓\nWebSocket Pods (Go)\n  ↕\nRedis \u002F Message Broker\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🐳 1. เตรียม WebSocket Server สำหรับ Kubernetes\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ตัวอย่างโค้ด Go แบบง่าย:\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">http.HandleFunc(\"\u002Fws\", handleWebSocket)\nhttp.ListenAndServe(\":8080\", nil)\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>✅ ข้อควรระวัง:\u003C\u002Fh3>\u003Cul>\u003Cli>อย่า Hardcode พอร์ต\u003C\u002Fli>\u003Cli>ควรทำ Graceful Shutdown ให้เรียบร้อย\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>📦 2. สร้าง Docker Image\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-dockerfile\">FROM golang:1.22-alpine AS builder\nWORKDIR \u002Fapp\nCOPY . .\nRUN go build -o ws-server\n\nFROM alpine:latest\nWORKDIR \u002Fapp\nCOPY --from=builder \u002Fapp\u002Fws-server .\nEXPOSE 8080\nCMD [\".\u002Fws-server\"]\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>คำสั่ง Build &amp; Push:\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-bash\">docker build -t your-org\u002Fws-server:1.0 .\ndocker push your-org\u002Fws-server:1.0\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>☸️ 3. Deploy บน Kubernetes\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>✅ Deployment:\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-yaml\">apiVersion: apps\u002Fv1\nkind: Deployment\nmetadata:\n  name: ws-server\nspec:\n  replicas: 3\n  selector:\n    matchLabels:\n      app: ws\n  template:\n    metadata:\n      labels:\n        app: ws\n    spec:\n      containers:\n      - name: ws\n        image: your-org\u002Fws-server:1.0\n        ports:\n        - containerPort: 8080\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🌐 4. Load Balancer (Service)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-yaml\">apiVersion: v1\nkind: Service\nmetadata:\n  name: ws-service\nspec:\n  type: LoadBalancer\n  selector:\n    app: ws\n  ports:\n  - port: 80\n    targetPort: 8080\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔁 5. Sticky Session (สำคัญมาก!)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>WebSocket ต้องการ Connection Stickiness เพื่อให้ Client กลับไปยัง Pod เดิม\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>ตัวอย่าง (Ingress + NGINX):\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-yaml\">annotations:\n  nginx.ingress.kubernetes.io\u002Faffinity: \"cookie\"\n  nginx.ingress.kubernetes.io\u002Fsession-cookie-name: \"ws-session\"\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>หากไม่เปิด Sticky Session:\u003C\u002Fp>\u003Cul>\u003Cli>❌ Client อาจเชื่อมต่อไปยัง Pod ใหม่เมื่อ Reconnect\u003C\u002Fli>\u003Cli>❌ State หาย การ Sync ข้อมูลผิดพลาด\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>📈 6. Auto Scaling (HPA)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-yaml\">apiVersion: autoscaling\u002Fv2\nkind: HorizontalPodAutoscaler\nmetadata:\n  name: ws-hpa\nspec:\n  scaleTargetRef:\n    apiVersion: apps\u002Fv1\n    kind: Deployment\n    name: ws-server\n  minReplicas: 3\n  maxReplicas: 10\n  metrics:\n  - type: Resource\n    resource:\n      name: cpu\n      target:\n        type: Utilization\n        averageUtilization: 70\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>คำแนะนำ: การ Scale ด้วย CPU อย่างเดียวไม่พอ ควรใช้ Custom Metrics เช่น:\u003C\u002Fp>\u003Cul>\u003Cli>จำนวน Active Connections\u003C\u002Fli>\u003Cli>Messages per Second\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔗 7. แชร์ State ระหว่าง Pods\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>หากคุณมีหลาย Pod ทำงานพร้อมกัน เช่น:\u003C\u002Fp>\u003Cul>\u003Cli>User A อยู่ Pod 1\u003C\u002Fli>\u003Cli>User B อยู่ Pod 3\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ต้องใช้ Redis Pub\u002FSub หรือ Message Broker เพื่อแชร์ข้อมูลระหว่างกัน\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext\">WebSocket Pod → Redis Pub\u002FSub → WebSocket Pod\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🛑 8. Graceful Shutdown\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>หาก Pod ถูก Scale Down หรือ Restart:\u003C\u002Fp>\u003Cul>\u003Cli>ห้ามตัด Connection ทันที!\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>แนวทางที่แนะนำ:\u003C\u002Fp>\u003Cul>\u003Cli>ใช้ \u003Ccode inline=\"\">context.Context\u003C\u002Fcode> เพื่อจัดการ Lifecycle\u003C\u002Fli>\u003Cli>ส่งสัญญาณให้ Client เตรียม Reconnect\u003C\u002Fli>\u003Cli>Wait อย่างเหมาะสมก่อนปิดตัว\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>✅ 9. Checklist ก่อนขึ้น Production\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cul>\u003Cli>✅ Sticky Session ใช้งานได้จริง\u003C\u002Fli>\u003Cli>✅ Auto Scaling ไม่ทำให้ Connection หลุด\u003C\u002Fli>\u003Cli>✅ Redis \u002F Message Broker พร้อม\u003C\u002Fli>\u003Cli>✅ Health Check แยก HTTP และ WebSocket\u003C\u002Fli>\u003Cli>✅ ระบบ Logging และ Metrics ครบถ้วน\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🚀 เริ่ม Deploy ของคุณเลย!\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cul>\u003Cli>เริ่มต้นที่ 2–3 Replicas\u003C\u002Fli>\u003Cli>เปิด Sticky Session\u003C\u002Fli>\u003Cli>ทดสอบ Scale Up \u002F Down\u003C\u002Fli>\u003Cli>ตรวจสอบว่าการเชื่อมต่อยังคงอยู่ครบ\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ถ้าทำครบ → WebSocket Server ของคุณพร้อมสำหรับ Production แล้ว!\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🧠 Key Takeaways\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cul>\u003Cli>Kubernetes ช่วยบริหาร WebSocket Server ได้อย่างยืดหยุ่น\u003C\u002Fli>\u003Cli>Sticky Session สำคัญกับการรักษาสถานะของผู้ใช้\u003C\u002Fli>\u003Cli>ต้องมี Redis\u002FBroker เพื่อแชร์สถานะข้าม Pods\u003C\u002Fli>\u003Cli>Graceful Shutdown จำเป็นสำหรับระบบ Production\u003C\u002Fli>\u003Cli>Auto Scaling ต้องใช้ Metrics ที่สอดคล้องกับ Real-time Workload\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Chr>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔮 EP.122 Horizontal &amp; Geo-distributed Scaling Strategies\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ตอนถัดไปเราจะขยายระบบ WebSocket ข้าม Cluster และรองรับหลาย Region พร้อมแนวทางลด Latency ระดับโลก 🌍\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cdiv class=\"raw-html-embed\">\u003Cdiv style=\"margin:0 0 6px 0; font-weight:700;\">อ่านบทความ Series อื่นๆ:\u003C\u002Fdiv>\n\u003Cul style=\"list-style:none; padding:0; margin:0; line-height:1.4;\">\n  \u003Cli style=\"margin:0;\">\u003Ca href=\"\u002Fblogs\u002Fcategories\u002FGolang\" title=\"Golang The Series\">Golang The Series\u003C\u002Fa>\u003C\u002Fli>\n  \u003Cli style=\"margin:0;\">\u003Ca href=\"\u002Fblogs\u002Fcategories\u002FJS2GO\" title=\"JS2GO\">JS2GO\u003C\u002Fa>\u003C\u002Fli>\n  \u003Cli style=\"margin:0;\">\u003Ca href=\"\u002Fblogs\u002Fcategories\u002FTailwind%20CSS\" title=\"10 Ep ที่จะให้คุณเป็นมือโปร Tailwind CSS ในชั่วข้ามคืน\">10 Ep ที่จะให้คุณเป็นมือโปร 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_itflh3jc0p.oductionSystems.webp","https:\u002F\u002Ftwsme-r2.tumwebsme.com\u002Fsclblg987654321\u002F7zzc9diqnbfzpd5\u002Fcover_image_ep_itflh3jc0p.oductionSystems.webp","2026-03-04 08:44:50.865Z","",{"keywords":15,"locale":48,"school_blog":58},[16,23,28,33,38,43],{"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:34:00.920Z","ecac9y661or1xka","WebSocket","2026-04-10 16:08:05.227Z",{"collectionId":17,"collectionName":18,"created":24,"created_by":13,"id":25,"name":26,"updated":27,"updated_by":13},"2026-03-04 08:34:10.799Z","m3qoswhgnc4c38n","Kubernetes","2026-04-10 16:08:08.875Z",{"collectionId":17,"collectionName":18,"created":29,"created_by":13,"id":30,"name":31,"updated":32,"updated_by":13},"2026-03-04 08:44:18.923Z","jt1jqlzs29xu1i7","Deploy","2026-04-10 16:12:43.373Z",{"collectionId":17,"collectionName":18,"created":34,"created_by":13,"id":35,"name":36,"updated":37,"updated_by":13},"2026-03-04 08:44:47.385Z","li4cs2v3atd0wds","Production","2026-04-10 16:12:49.890Z",{"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",{"collectionId":17,"collectionName":18,"created":44,"created_by":13,"id":45,"name":46,"updated":47,"updated_by":13},"2026-03-04 08:20:14.253Z","ah6lvy4x8qe08l5","Golang","2026-04-10 16:07:26.172Z",{"code":49,"collectionId":50,"collectionName":51,"created":52,"flag":53,"id":54,"is_default":55,"label":56,"updated":57},"th","pbc_1989393366","locales","2026-01-22 10:59:55.832Z","twemoji:flag-thailand","s8wri3bt4vgg2ji",true,"Thai","2026-04-10 15:42:46.614Z",{"category":59,"collectionId":60,"collectionName":61,"expand":62,"id":76,"views":77},"wqxt7ag2gn7xcmk","pbc_2105096300","school_blogs",{"category":63},{"blogIds":64,"collectionId":65,"collectionName":66,"created":67,"created_by":13,"id":59,"image":68,"image_alt":13,"image_path":69,"label":70,"name":71,"priority":72,"publish_at":73,"scheduled_at":13,"status":74,"updated":75,"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":71,"th":71},"Golang The Series",1,"2026-03-16 04:39:38.440Z","published","2026-04-25 02:32:15.470Z","jdvfu3khsdfw08k",271,"7zzc9diqnbfzpd5",[20,25,30,35,40,45],"2025-12-29 10:10:07.916Z","เรียนรู้วิธี Deploy WebSocket Server ด้วย Kubernetes ตั้งแต่การสร้าง Docker Image, ตั้งค่า Load Balancer, ใช้ Sticky Session, Auto Scaling และจัดการ Graceful Shutdown ให้พร้อมใช้งานในระดับ Production จริง","deploy-websocket-server-kubernetes-production","2026-04-25 02:47:46.561Z",{"th":82}]