[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"academy-blogs-th-1-1-all-js2go-ep48-logging-monitoring-production-go-nodejs-all--*":3,"academy-blog-translations-d8jrjoxb8k7la64":80},{"data":4,"page":79,"perPage":79,"totalItems":79,"totalPages":79},[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},"JS2GO EP.48 Logging & Monitoring for Production (Go & Node.js)","sclblg987654321","school_blog_translations","\u003Ch2>จาก “มี log” → สู่ “เข้าใจระบบทั้งก้อน” แบบมืออาชีพ\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>เมื่อระบบเริ่มเติบโต มีผู้ใช้มากขึ้น มีหลาย service มีหลาย instance และ deploy บ่อยขึ้น สิ่งที่ยากที่สุดไม่ใช่ “เขียนโค้ดให้รันได้” แต่คือ\u003C\u002Fp>\u003Cul>\u003Cli>❓ error เกิดที่ไหน\u003C\u002Fli>\u003Cli>❓ request นี้วิ่งผ่าน service อะไรบ้าง\u003C\u002Fli>\u003Cli>❓ ทำไม latency พุ่ง\u003C\u002Fli>\u003Cli>❓ ระบบกำลังจะล่มหรือยัง\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>คำตอบทั้งหมดอยู่ที่ Logging &amp; Monitoring ที่ออกแบบมาดี\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>บทความนี้จะพาคุณเรียนรู้แนวคิดและเครื่องมือที่ใช้จริงใน Production ทั้ง Go และ Node.js\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 1. Structured Logging คืออะไร และทำไม Production ต้องใช้\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>❌ Log แบบเดิม (Human-readable only)\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-text\">user login failed\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ปัญหา\u003C\u002Fp>\u003Cul>\u003Cli>ค้นหายาก\u003C\u002Fli>\u003Cli>ทำ dashboard ไม่ได้\u003C\u002Fli>\u003Cli>วิเคราะห์เชิงระบบแทบไม่ได้\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>✅ Structured Logging (Machine + Human readable)\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-json\">{\n  \"level\": \"error\",\n  \"service\": \"auth-service\",\n  \"event\": \"login_failed\",\n  \"user_id\": \"u123\",\n  \"request_id\": \"req-abc-001\"\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ข้อดี\u003C\u002Fp>\u003Cul>\u003Cli>Query ง่าย (Loki \u002F Elasticsearch)\u003C\u002Fli>\u003Cli>ทำ dashboard + alert ได้\u003C\u002Fli>\u003Cli>เชื่อมกับ tracing และ metrics ได้\u003C\u002Fli>\u003Cli>เหมาะกับ Microservices \u002F Cloud-native\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cblockquote>\u003Cp>📌 Production = JSON log เท่านั้น\u003C\u002Fp>\u003C\u002Fblockquote>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 2. Structured Logging ใน Go\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔹 Zap (มาตรฐานองค์กร)\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">logger, _ := zap.NewProduction()\ndefer logger.Sync()\n\nlogger.Info(\"order created\",\n    zap.String(\"order_id\", \"o123\"),\n    zap.Int(\"amount\", 1500),\n)\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔹 Zerolog (เร็วมาก \u002F JSON native)\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">log.Info().\n   Str(\"service\", \"payment\").\n   Str(\"user_id\", \"u123\").\n   Msg(\"payment success\")\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>เลือกอย่างไร\u003C\u002Fp>\u003Cfigure class=\"table\">\u003Ctable>\u003Cthead>\u003Ctr>\u003Cth>Logger\u003C\u002Fth>\u003Cth>เหมาะกับ\u003C\u002Fth>\u003C\u002Ftr>\u003C\u002Fthead>\u003Ctbody>\u003Ctr>\u003Ctd>Zap\u003C\u002Ftd>\u003Ctd>ระบบองค์กร \u002F long-term support\u003C\u002Ftd>\u003C\u002Ftr>\u003Ctr>\u003Ctd>Zerolog\u003C\u002Ftd>\u003Ctd>log ปริมาณสูงมาก \u002F performance critical\u003C\u002Ftd>\u003C\u002Ftr>\u003C\u002Ftbody>\u003C\u002Ftable>\u003C\u002Ffigure>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 3. Structured Logging ใน Node.js\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔹 Pino (แนะนำที่สุดสำหรับ Production)\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-js\">import pino from \"pino\";\nconst logger = pino();\n\nlogger.info({\n  service: \"order-api\",\n  orderId: \"o123\",\n  status: \"created\"\n});\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>เหตุผลที่ Pino เหมาะกับ Production\u003C\u002Fp>\u003Cul>\u003Cli>เร็วมาก\u003C\u002Fli>\u003Cli>JSON output\u003C\u002Fli>\u003Cli>ทำงานดีกับ Loki \u002F Elastic\u003C\u002Fli>\u003Cli>รองรับ async \u002F worker \u002F cluster\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 4. Correlation ID: หัวใจของ Microservices\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Correlation ID คือ ID เดียวที่ติดไปกับ request ทั้ง lifecycle\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext\">Client\n → API Gateway\n   → Auth Service\n     → Order Service\n       → Payment Service\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ทุก service log ด้วย \u003Ccode inline=\"\">request_id\u003C\u002Fcode> เดียวกัน → debug ได้ทั้งเส้นทาง\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔹 Go (Fiber Middleware)\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">func CorrelationID() fiber.Handler {\n    return func(c *fiber.Ctx) error {\n        id := c.Get(\"X-Request-ID\")\n        if id == \"\" {\n            id = uuid.NewString()\n        }\n        c.Set(\"X-Request-ID\", id)\n        c.Locals(\"request_id\", id)\n        return c.Next()\n    }\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ใช้ใน log\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">logger.Info(\"handling request\",\n    zap.String(\"request_id\", c.Locals(\"request_id\").(string)),\n)\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔹 Node.js (Express Middleware)\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-js\">import { v4 as uuid } from \"uuid\";\n\nfunction correlationId(req, res, next) {\n  req.requestId = req.headers[\"x-request-id\"] || uuid();\n  res.setHeader(\"X-Request-ID\", req.requestId);\n  next();\n}\n\nlogger.info({ requestId: req.requestId }, \"processing request\");\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 5. Distributed Tracing ด้วย OpenTelemetry\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Tracing ทำให้คุณเห็น เส้นทางของ request ทั้งก้อน\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext\">API → DB → External API → Cache\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔹 Go + OpenTelemetry\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">tracer := otel.Tracer(\"order-service\")\n\nctx, span := tracer.Start(ctx, \"CreateOrder\")\ndefer span.End()\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ส่ง trace ไปที่ Jaeger \u002F Tempo \u002F Zipkin\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔹 Node.js + OpenTelemetry\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-js\">const tracer = opentelemetry.trace.getTracer(\"order-service\");\nconst span = tracer.startSpan(\"create-order\");\n\u002F\u002F do work\nspan.end();\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 6. Metrics: รู้สถานะระบบแบบ Real-time\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Metrics ตอบคำถามสำคัญ\u003C\u002Fp>\u003Cul>\u003Cli>QPS เท่าไหร่\u003C\u002Fli>\u003Cli>Error rate %\u003C\u002Fli>\u003Cli>Latency p95 \u002F p99\u003C\u002Fli>\u003Cli>CPU \u002F Memory\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔹 Go + Prometheus\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">httpRequests := prometheus.NewCounterVec(\n  prometheus.CounterOpts{\n    Name: \"http_requests_total\",\n  },\n  []string{\"method\", \"status\"},\n)\n\nhttpRequests.WithLabelValues(\"GET\", \"200\").Inc()\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Expose \u003Ccode inline=\"\">\u002Fmetrics\u003C\u002Fcode>\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔹 Node.js + Prometheus\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-js\">import client from \"prom-client\";\n\nconst counter = new client.Counter({\n  name: \"http_requests_total\",\n  help: \"Total HTTP requests\"\n});\n\ncounter.inc();\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Grafana ใช้สำหรับ\u003C\u002Fp>\u003Cul>\u003Cli>Dashboard\u003C\u002Fli>\u003Cli>Alert\u003C\u002Fli>\u003Cli>SLA \u002F SLO\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 7. Error Monitoring ด้วย Sentry\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Logging บอกว่า เกิดอะไรขึ้น\u003C\u002Fp>\u003Cp>Error Monitoring บอกว่า\u003C\u002Fp>\u003Cul>\u003Cli>เกิดกี่ครั้ง\u003C\u002Fli>\u003Cli>stack trace เต็ม\u003C\u002Fli>\u003Cli>impact กับ user\u003C\u002Fli>\u003Cli>แจ้งเตือน real-time\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔹 Go\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">sentry.CaptureException(err)\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔹 Node.js\u003C\u002Fh3>\u003Cpre>\u003Ccode class=\"language-plaintext language-js\">Sentry.captureException(err);\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 8. Logging &amp; Monitoring Architecture (Production)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext\">Application\n ├─ Logs → Loki \u002F Elasticsearch\n ├─ Traces → Jaeger \u002F Tempo\n ├─ Metrics → Prometheus → Grafana\n └─ Errors → Sentry\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>🧠 Correlation ID = กาวที่เชื่อมทุกอย่างเข้าด้วยกัน\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 9. Best Practices สำหรับ Production\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✔ Log เป็น JSON เท่านั้น\u003Cbr>✔ ห้าม log password \u002F token \u002F credit card\u003Cbr>✔ ใช้ Correlation ID ทุก request\u003Cbr>✔ แยก log level (INFO \u002F WARN \u002F ERROR)\u003Cbr>✔ Alert จาก metrics มากกว่า log\u003Cbr>✔ อย่า log เยอะเกินไป (noise + cost)\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Chr>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>📌 สรุป\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Logging &amp; Monitoring ที่ดีทำให้คุณ\u003C\u002Fp>\u003Cul>\u003Cli>🔍 แก้ปัญหาเร็วขึ้นหลายเท่า\u003C\u002Fli>\u003Cli>🚨 รู้ปัญหาก่อนผู้ใช้\u003C\u002Fli>\u003Cli>🚀 Deploy ได้มั่นใจ\u003C\u002Fli>\u003Cli>🌐 Scale ได้โดยไม่ “มืด”\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ทั้ง Go และ Node.js มี ecosystem ที่พร้อมสำหรับ Production ถ้าออกแบบ Logging &amp; Monitoring ตั้งแต่วันแรก ระบบของคุณจะ อยู่รอดได้จริง 🚀\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔵 ตอนต่อไป: EP.49 Security: Authentication, Authorization &amp; Data Validation\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cul>\u003Cli>JWT \u002F Session \u002F OAuth\u003C\u002Fli>\u003Cli>Auth vs Authorization\u003C\u002Fli>\u003Cli>RBAC\u003C\u002Fli>\u003Cli>Input Validation\u003C\u002Fli>\u003Cli>ป้องกัน SQLi \u002F XSS \u002F CSRF\u003C\u002Fli>\u003Cli>Security Best Practices สำหรับ Production\u003C\u002Fli>\u003C\u002Ful>\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_js2_go_ep_48_logging_monitoring_for_production_go_node_qpowgw7zj4.js.webp","https:\u002F\u002Ftwsme-r2.tumwebsme.com\u002Fsclblg987654321\u002Fssj081nxo3m7iqh\u002Fcover_image_js2_go_ep_48_logging_monitoring_for_production_go_node_qpowgw7zj4.js.webp","2026-03-04 08:44:54.485Z","",{"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:53.651Z","tuo9u1ayxlr8xvm","Monitoring System","2026-04-10 16:12:51.456Z",{"collectionId":17,"collectionName":18,"created":24,"created_by":13,"id":25,"name":26,"updated":27,"updated_by":13},"2026-03-04 08:44:54.012Z","e283qzmjw1vq2l4","Logging Production","2026-04-10 16:12:51.523Z",{"collectionId":17,"collectionName":18,"created":29,"created_by":13,"id":30,"name":31,"updated":32,"updated_by":13},"2026-03-04 08:24:40.405Z","05u3tysava2z6ga","Node.js","2026-04-10 16:07:29.504Z",{"collectionId":17,"collectionName":18,"created":34,"created_by":13,"id":35,"name":36,"updated":37,"updated_by":13},"2026-03-04 08:20:42.484Z","vslzz9nvv6n77cx","JavaScript","2026-04-10 16:07:28.339Z",{"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},"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":54,"collectionId":55,"collectionName":56,"expand":57,"id":71,"views":72},"hsa1afr8fcnd6qb","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:24:37.986Z","js2_go_2_11zon_y6paxmuz32.webp","https:\u002F\u002Ftwsme-r2.tumwebsme.com\u002Fsclcatblg987654321\u002Fhsa1afr8fcnd6qb\u002Fjs2_go_2_11zon_y6paxmuz32.webp",{"en":66,"th":66},"JS2GO",10,"2025-08-11 03:41:08.820Z","published","2026-04-25 02:32:14.339Z","d8jrjoxb8k7la64",225,"ssj081nxo3m7iqh",[20,25,30,35,40],"2025-12-23 04:57:48.010Z","จากการมีแค่ log สู่การเข้าใจระบบทั้งก้อน เรียนรู้ Structured Logging, Correlation ID, Metrics, Tracing และ Error Monitoring เพื่อให้ระบบ Go และ Node.js พร้อมใช้งานจริงในระดับ Production และ Microservices","js2go-ep48-logging-monitoring-production-go-nodejs","2026-04-25 02:47:47.290Z",1,{"th":77}]