Next.js + Spring Boot Kubernetes অ্যাপ্লিকেশনকে DDoS আক্রমণ থেকে সুরক্ষিত করার সম্পূর্ণ গাইড (ingress-nginx সহ)

DevOpsOstad
ডেভ অপ্স ওস্তাদ
Published on Sep, 14 2025 3 min read 0 comments
image

ভূমিকা

আজকের আধুনিক ওয়েব অ্যাপ্লিকেশন সাধারণত ফ্রন্টএন্ডে Next.js এবং ব্যাকএন্ডে Spring Boot দিয়ে তৈরি হয়, আর এগুলো Kubernetes এ ডিপ্লয় করা হয়। সমস্যা হচ্ছে, যত বেশি স্কেলেবল আর্কিটেকচার, তত বেশি টার্গেট হয় DDoS আক্রমণের জন্য।

একটা DDoS আক্রমণ (Distributed Denial of Service) আপনার সার্ভারকে অল্প সময়ে অকেজো করে দিতে পারে, যার ফলে—

  • ওয়েবসাইট ডাউন হয়ে যাবে 🚫
  • কাস্টমার লস হবে 😓
  • ব্র্যান্ড ইমেজ ক্ষতিগ্রস্ত হবে ⚠️

এর সমাধান? → Multi-layered Defense।
মানে, DDoS প্রতিরোধ শুধু এক জায়গায় নয়, বরং DNS/CDN → ingress-nginx → Cluster/Network → Application Layer — সব জায়গায় ব্যবস্থা নিতে হবে।

DDoS প্রতিরোধের স্তরসমূহ

1️⃣ DNS / CDN Layer (Cloudflare / AWS Shield)

সবচেয়ে গুরুত্বপূর্ণ প্রথম ধাপ।

  • Cloudflare / AWS Shield → গ্লোবাল নেটওয়ার্কে ট্রাফিক ছড়িয়ে দেয়, বড় আকারের volumetric attack absorb করে।
  • Pros → সার্ভার পর্যন্ত পৌছায় না, Layer 3/4 flood আটকায়।
  • Cons → Free plan এ সীমিত সাপোর্ট, বড় অ্যাটাকে paid দরকার।

👉 Recommendation: DNS Cloudflare এর proxied mode এ চালান, origin IP leak করবেন না।

2️⃣ ingress-nginx Layer (Kubernetes Gateway)

Ingress Controller এ rate-limit ও WAF চালু করা যায়।

উদাহরণ কনফিগ (Ingress manifest):

apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: my-app-ingress
  annotations:
    kubernetes.io/ingress.class: "nginx"
    nginx.ingress.kubernetes.io/limit-connections: "10"
    nginx.ingress.kubernetes.io/limit-rps: "5"
    nginx.ingress.kubernetes.io/whitelist-source-range: "203.0.113.0/24"
    nginx.ingress.kubernetes.io/modsecurity-enabled: "true"
spec:
  rules:
  - host: app.example.com
    http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: my-svc
            port:
              number: 80

👉 এর ফলে প্রতিটি IP নির্দিষ্ট পরিমাণ request এর বেশি পাঠাতে পারবে না। ModSecurity (WAF) দিয়ে SQLi, XSS, bot ট্রাফিক ফিল্টার করা যাবে।

3️⃣ Cluster / Network Layer

  • Horizontal Pod Autoscaler (HPA) → legitimate ট্রাফিক spike হ্যান্ডেল করবে।
  • NetworkPolicy → অপ্রয়োজনীয় pod-to-pod কানেকশন বন্ধ করবে।
  • Cloud Provider Scrubbing → AWS Shield, GCP Armor দিয়ে বড় লেভেলের আক্রমণ ফিল্টার করা।

4️⃣ Application Layer (Spring Boot + Next.js)

Spring Boot (Backend API):

  • Bucket4j / Resilience4j দিয়ে rate-limit implement করুন।
  • Redis backend ব্যবহার করলে multi-instance এ consistent limit পাওয়া যায়।
// Bucket4j + Redis integration (simplified example)
@Bean
public FilterRegistrationBean rateLimitFilter() {
   // IP/User ভিত্তিক rate limiting এর জন্য filter setup
}

Next.js (Frontend):

  • Static assets CDN cache করুন।
  • next.config.js এ caching headers দিন।
  • Login/Signup রুটে CAPTCHA ব্যবহার করুন।

মনিটরিং ও ইনসিডেন্ট রেসপন্স

DDoS প্রতিরোধ মানেই কনফিগ শেষ নয়।

  • Metrics Track করুন: ingress request rate, 4xx/5xx, pod CPU, latency।
  • Alert Rules সেট করুন: Prometheus/Grafana বা Datadog দিয়ে।
  • Runbook তৈরি করুন:
    1. CDN “Under Attack” mode চালু করুন।
    2. IP/Region block করুন।
    3. Application scaling বাড়ান।
    4. Provider এর সাথে যোগাযোগ করুন।

উপসংহার

Next.js + Spring Boot Kubernetes অ্যাপ্লিকেশনকে DDoS আক্রমণ থেকে রক্ষা করতে হলে একক কোনো সমাধান নেই।
👉 DNS/CDN → ingress-nginx → Cluster → Application — প্রতিটি লেয়ারে প্রতিরোধ ব্যবস্থা নিতে হবে।

এই multi-layered approach আপনার সার্ভারকে শুধু সুরক্ষিতই করবে না, বরং resilient এবং high-availability নিশ্চিত করবে।

0 Comments