[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"academy-blogs-th-1-1-all-js2go-ep43-rate-limiting-throttling-go-nodejs-all--*":3,"academy-blog-translations-xnajds5fdcdxt16":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.43 การทำ Rate Limiting และ Throttling ใน Go และ Node.js","sclblg987654321","school_blog_translations","\u003Cp>ควบคุมโหลด ป้องกัน DDoS และทำให้ API “เสถียรแม้ถูกยิงหลายหมื่น request\u002Fวินาที” 🚀\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Rate Limiting คือเทคนิคที่บอกระบบว่า 👉 “ผู้ใช้ 1 ราย สามารถส่ง request ได้กี่ครั้งภายในช่วงเวลาเท่าไหร่” เพื่อป้องกันไม่ให้ระบบถูกยิงเกินกำลังที่รองรับได้\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ใช้สำหรับแก้ปัญหาเหล่านี้:\u003C\u002Fp>\u003Cul>\u003Cli>API ล่มเพราะถูกยิง request ถี่เกินไป\u003C\u002Fli>\u003Cli>Hacker brute-force login\u003C\u002Fli>\u003Cli>Bot spam \u002F script อันตราย\u003C\u002Fli>\u003Cli>บริการหลังบ้าน เช่น DB\u002FCache overload\u003C\u002Fli>\u003Cli>ค่าเซิร์ฟเวอร์พุ่งไม่จำเป็น\u003C\u002Fli>\u003Cli>ระบบต้องรักษาคุณภาพของบริการ (QoS)\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ใน EP นี้… คุณจะได้เข้าใจ Pattern ของ Rate Limiting แบบ Production Ready ทั้งใน Go และ Node.js พร้อมโค้ดที่แทบจะนำไปใช้จริงได้ทันที ✔\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 1) ทำไม “Rate Limiting” จำเป็นในระบบระดับ Production?\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ถ้าไม่มี Rate Limit → ระบบจะพังแน่นอน เพราะ:\u003C\u002Fp>\u003Cfigure class=\"table\">\u003Ctable>\u003Cthead>\u003Ctr>\u003Cth>ปัญหา\u003C\u002Fth>\u003Cth>ผลกระทบ\u003C\u002Fth>\u003C\u002Ftr>\u003C\u002Fthead>\u003Ctbody>\u003Ctr>\u003Ctd>User ส่ง request ผิดพลาดเป็นหมื่นครั้ง (infinite loop)\u003C\u002Ftd>\u003Ctd>API ค้างทั้งระบบ\u003C\u002Ftd>\u003C\u002Ftr>\u003Ctr>\u003Ctd>Bot ยิงถี่\u003C\u002Ftd>\u003Ctd>CPU 100%\u003C\u002Ftd>\u003C\u002Ftr>\u003Ctr>\u003Ctd>Hacker brute-force password\u003C\u002Ftd>\u003Ctd>Security breach\u003C\u002Ftd>\u003C\u002Ftr>\u003Ctr>\u003Ctd>API gateway overload\u003C\u002Ftd>\u003Ctd>Latency พุ่ง\u003C\u002Ftd>\u003C\u002Ftr>\u003Ctr>\u003Ctd>DB ถูกคิวตัน\u003C\u002Ftd>\u003Ctd>Query fail ทั้งระบบ\u003C\u002Ftd>\u003C\u002Ftr>\u003Ctr>\u003Ctd>ระบบ microservices call กันเองแบบไม่มี limit\u003C\u002Ftd>\u003Ctd>เกิด cascade failure\u003C\u002Ftd>\u003C\u002Ftr>\u003C\u002Ftbody>\u003C\u002Ftable>\u003C\u002Ffigure>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Rate Limiting = Safety Shield ของ API ในทุกระบบจริง 🔰\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 2) 3 Approaches ที่ใช้จริงใน Production\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔶 Token Bucket (นิยมที่สุด)\u003C\u002Fh3>\u003Ch4>แนวคิด:\u003C\u002Fh4>\u003Cul>\u003Cli>Bucket ใส่ token ได้จำนวนหนึ่ง\u003C\u002Fli>\u003Cli>มีการเติม token ตามเวลา\u003C\u002Fli>\u003Cli>ทุก request ต้องใช้ 1 token\u003C\u002Fli>\u003Cli>ถ้า token หมด → block หรือ delay\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch4>เหมาะกับ:\u003C\u002Fh4>\u003Cul>\u003Cli>ระบบที่มี burst traffic\u003C\u002Fli>\u003Cli>Public API\u003C\u002Fli>\u003Cli>Microservices\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch4>ข้อดี\u003C\u002Fh4>\u003Cp>✔ รองรับการยิงทีละเยอะ (burst) ได้\u003Cbr>✔ ง่ายต่อการ implement\u003Cbr>✔ ใช้ได้ทั้งในระบบ local และ distributed\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔶 Leaky Bucket\u003C\u002Fh3>\u003Ch4>แนวคิด:\u003C\u002Fh4>\u003Cul>\u003Cli>งานถูกเทเข้าบัคเก็ตได้ไม่จำกัด\u003C\u002Fli>\u003Cli>แต่ “ไหลออก” ด้วยอัตราคงที่\u003Cbr>เหมือนการควบคุม throughput ให้คงที่มากที่สุด\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch4>เหมาะกับ:\u003C\u002Fh4>\u003Cul>\u003Cli>Streaming\u003C\u002Fli>\u003Cli>Log processing\u003C\u002Fli>\u003Cli>Job queue\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch4>ข้อดี\u003C\u002Fh4>\u003Cp>✔ Traffic stable\u003Cbr>✔ Load หลังบ้านนิ่ง\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🔶 Sliding Window\u003C\u002Fh3>\u003Ch4>แนวคิด:\u003C\u002Fh4>\u003Cp>นับจำนวน request ภายในช่วง “เวลาเลื่อน” เช่น 1 นาทีล่าสุด\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch4>เหมาะกับ:\u003C\u002Fh4>\u003Cul>\u003Cli>Login\u002FAuthentication\u003C\u002Fli>\u003Cli>API ที่ต้องป้องกัน brute-force\u003C\u002Fli>\u003Cli>Public API ที่ต้องการความแม่นยำสูง\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch4>ข้อดี\u003C\u002Fh4>\u003Cp>✔ แม่นยำกว่า Fixed Window\u003Cbr>✔ ป้องกัน request spike ได้ดีกว่า\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 3) ตัวอย่างโค้ด Production Go (Golang)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🟦 Token Bucket — Go (Middleware Version)\u003C\u002Fh3>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">package main\n\nimport (\n\t\"net\u002Fhttp\"\n\t\"sync\"\n\t\"time\"\n)\n\ntype TokenBucket struct {\n\ttokens     float64\n\tcapacity   float64\n\tfillRate   float64 \u002F\u002F token per second\n\tlastFilled time.Time\n\tmu         sync.Mutex\n}\n\nfunc NewTokenBucket(capacity, fillRate float64) *TokenBucket {\n\treturn &amp;TokenBucket{\n\t\ttokens:     capacity,\n\t\tcapacity:   capacity,\n\t\tfillRate:   fillRate,\n\t\tlastFilled: time.Now(),\n\t}\n}\n\nfunc (tb *TokenBucket) Allow() bool {\n\ttb.mu.Lock()\n\tdefer tb.mu.Unlock()\n\n\tnow := time.Now()\n\telapsed := now.Sub(tb.lastFilled).Seconds()\n\ttb.tokens = tb.tokens + elapsed*tb.fillRate\n\n\tif tb.tokens &gt; tb.capacity {\n\t\ttb.tokens = tb.capacity\n\t}\n\n\ttb.lastFilled = now\n\n\tif tb.tokens &gt;= 1 {\n\t\ttb.tokens -= 1\n\t\treturn true\n\t}\n\treturn false\n}\n\nfunc RateLimit(tb *TokenBucket) func(http.Handler) http.Handler {\n\treturn func(next http.Handler) http.Handler {\n\t\treturn http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {\n\t\t\tif !tb.Allow() {\n\t\t\t\thttp.Error(w, \"Too Many Requests\", http.StatusTooManyRequests)\n\t\t\t\treturn\n\t\t\t}\n\t\t\tnext.ServeHTTP(w, r)\n\t\t})\n\t}\n}\n\nfunc main() {\n\ttb := NewTokenBucket(10, 5) \u002F\u002F capacity=10, fillRate=5 tokens\u002Fs\n\n\tmux := http.NewServeMux()\n\tmux.HandleFunc(\"\u002Fapi\", func(w http.ResponseWriter, r *http.Request) {\n\t\tw.Write([]byte(\"OK\"))\n\t})\n\n\thttp.ListenAndServe(\":8080\", RateLimit(tb)(mux))\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🟦 Sliding Window — Go\u003C\u002Fh3>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">var (\n\trequests = make(map[string][]time.Time)\n\tmu       sync.Mutex\n\tlimit    = 5\n\twindow   = 10 * time.Second\n)\n\nfunc SlidingWindow(next http.Handler) http.Handler {\n\treturn http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {\n\t\tip := r.RemoteAddr\n\t\tnow := time.Now()\n\n\t\tmu.Lock()\n\t\thistory := requests[ip]\n\n\t\t\u002F\u002F keep only valid timestamps\n\t\tvalid := history[:0]\n\t\tfor _, t := range history {\n\t\t\tif now.Sub(t) &lt;= window {\n\t\t\t\tvalid = append(valid, t)\n\t\t\t}\n\t\t}\n\n\t\tif len(valid) &gt;= limit {\n\t\t\tmu.Unlock()\n\t\t\thttp.Error(w, \"Too Many Requests\", http.StatusTooManyRequests)\n\t\t\treturn\n\t\t}\n\n\t\trequests[ip] = append(valid, now)\n\t\tmu.Unlock()\n\n\t\tnext.ServeHTTP(w, r)\n\t})\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 4) ตัวอย่างโค้ด Production Node.js (Express)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🟧 Token Bucket — Node.js\u003C\u002Fh3>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-js\">class TokenBucket {\n  constructor(capacity, fillRate) {\n    this.capacity = capacity;\n    this.tokens = capacity;\n    this.fillRate = fillRate;\n    this.lastRefill = Date.now();\n  }\n\n  allow() {\n    const now = Date.now();\n    const elapsed = (now - this.lastRefill) \u002F 1000;\n\n    this.tokens = Math.min(\n      this.capacity,\n      this.tokens + elapsed * this.fillRate\n    );\n\n    this.lastRefill = now;\n\n    if (this.tokens &gt;= 1) {\n      this.tokens -= 1;\n      return true;\n    }\n    return false;\n  }\n}\n\nfunction rateLimit(bucket) {\n  return (req, res, next) =&gt; {\n    if (!bucket.allow()) {\n      return res.status(429).send(\"Too Many Requests\");\n    }\n    next();\n  };\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>🟧 Sliding Window — Node.js\u003C\u002Fh3>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-js\">const windowMs = 10 * 1000;\nconst limit = 5;\nconst history = new Map();\n\nfunction slidingWindow(req, res, next) {\n  const ip = req.ip;\n  const now = Date.now();\n\n  const reqLog = history.get(ip) || [];\n  const filtered = reqLog.filter(t =&gt; now - t &lt;= windowMs);\n\n  if (filtered.length &gt;= limit) {\n    return res.status(429).send(\"Too Many Requests\");\n  }\n\n  filtered.push(now);\n  history.set(ip, filtered);\n\n  next();\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ 5) Production Tips (สำคัญมาก)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✔ ใช้ Redis สำหรับระบบ multi-instance (ถ้าคุณมีหลาย container\u002Fpod → memory local จะไม่ sync)\u003C\u002Fp>\u003Cp>✔ ทำ rate limit หลายชั้น\u003C\u002Fp>\u003Cul>\u003Cli>API Gateway\u003C\u002Fli>\u003Cli>Load Balancer\u003C\u002Fli>\u003Cli>App server\u003C\u002Fli>\u003C\u002Ful>\u003Cp>✔ Sliding Window เหมาะกับ Public API\u003Cbr>✔ Token Bucket เหมาะกับ Microservices\u003Cbr>✔ ใช้ exponential backoff สำหรับ retry\u003C\u002Fp>\u003Cp>✔ ตั้ง Log + Monitoring ให้ครบ\u003Cbr>เพื่อดูว่า rate limit ทำงานปกติหรือไม่\u003C\u002Fp>\u003Cp>✔ คืน error JSON ที่อ่านง่าย เช่น\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-json\">{\n  \"error\": \"Too Many Requests\",\n  \"retry_after\": 3\n}\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Chr>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>⭐ สรุปสุดท้าย\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Rate Limiting เป็น “เกราะป้องกันหลัก” ของ API\u003Cbr>ช่วยป้องกัน:\u003C\u002Fp>\u003Cul>\u003Cli>การยิง request ถี่เกิน\u003C\u002Fli>\u003Cli>bot \u002F hacker\u003C\u002Fli>\u003Cli>brute-force\u003C\u002Fli>\u003Cli>overload\u003C\u002Fli>\u003Cli>ค่า server พุ่ง\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ทั้ง Go และ Node.js มีวิธีทำที่ชัดเจนและคุณสามารถนำโค้ดในบทความนี้ไปใช้งานจริงได้ทันที 🚀\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔵 EP.44 (ตอนต่อไป)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>เชื่อมต่อ Database: SQL &amp; NoSQL ใน JavaScript และ Go\u003C\u002Fh3>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>คุณจะได้เรียนรู้:\u003C\u002Fp>\u003Cul>\u003Cli>เชื่อมต่อ PostgreSQL \u002F MySQL \u002F MongoDB \u002F Redis\u003C\u002Fli>\u003Cli>Code ตัวอย่าง Go Fiber + Node.js Express\u003C\u002Fli>\u003Cli>ORM\u002FQuery Builder ที่ควรใช้\u003C\u002Fli>\u003Cli>การจัดการ Connection Pool อย่างถูกต้อง\u003C\u002Fli>\u003Cli>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_43_rate_limiting_and_throttling_in_go_and_node_083y6kqmje.js.webp","https:\u002F\u002Ftwsme-r2.tumwebsme.com\u002Fsclblg987654321\u002Fkwtikt0mr8bk7nk\u002Fcover_image_js2_go_ep_43_rate_limiting_and_throttling_in_go_and_node_083y6kqmje.js.webp","2026-03-04 08:45:16.034Z","",{"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:38.026Z","m3dqo2zalnfaoof","Token Bucket","2026-04-10 16:12:47.845Z",{"collectionId":17,"collectionName":18,"created":24,"created_by":13,"id":25,"name":26,"updated":27,"updated_by":13},"2026-03-04 08:45:14.634Z","k64fy7g22x7ash7","Throttling","2026-04-10 16:12:56.314Z",{"collectionId":17,"collectionName":18,"created":29,"created_by":13,"id":30,"name":31,"updated":32,"updated_by":13},"2026-03-04 08:20:11.547Z","ey3puyme01a9bsw","Go","2026-04-10 16:07:25.893Z",{"collectionId":17,"collectionName":18,"created":34,"created_by":13,"id":35,"name":36,"updated":37,"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":39,"created_by":13,"id":40,"name":41,"updated":42,"updated_by":13},"2026-03-04 08:34:07.915Z","921nl48h9in67sw","Rate Limiting","2026-04-10 16:08:07.808Z",{"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","xnajds5fdcdxt16",224,"kwtikt0mr8bk7nk",[20,25,30,35,40],"2025-12-03 14:28:15.587Z","เรียนรู้วิธีป้องกันระบบล่มด้วย Rate Limiting และ Throttling ทั้ง Token Bucket, Leaky Bucket และ Sliding Window พร้อมตัวอย่างโค้ดจริงใน Go และ Node.js สำหรับใช้งานในระบบระดับ Production","js2go-ep43-rate-limiting-throttling-go-nodejs","2026-04-25 02:47:51.658Z",1,{"th":77}]