Parallelism এবং Load Balancing Techniques

Advanced Concurrency Patterns (অ্যাডভান্সড কনকারেন্সি প্যাটার্নস) - গো প্রোগ্রামিং (Go Programming) - Computer Programming

302

Parallelism এবং Load Balancing Techniques in Go

Parallelism এবং Load Balancing দুটি গুরুত্বপূর্ণ কৌশল, যা সিস্টেমের পারফরম্যান্স এবং স্কেলেবিলিটি উন্নত করতে ব্যবহৃত হয়। Go প্রোগ্রামিং ভাষা এই দুইটি কৌশল সহজে ইমপ্লিমেন্ট করার জন্য অনেক শক্তিশালী টুলস প্রদান করে, যেমন goroutines এবং channels

এই টিউটোরিয়ালে আমরা দেখব কীভাবে Parallelism এবং Load Balancing Go তে কার্যকরীভাবে প্রয়োগ করা যায়।


১. Parallelism (প্যারালালিজম)

Parallelism হল একাধিক কাজ বা প্রক্রিয়া একই সময়ে চালানো, যাতে সিস্টেমের কনকারেন্সি ক্ষমতা (CPU, I/O) ব্যবহার করা যায়। Go তে goroutines এবং channels এর মাধ্যমে parallelism খুব সহজে অর্জন করা যায়। প্রতিটি goroutine মূল থ্রেড থেকে আলাদা হয়ে কার্যক্রম সম্পন্ন করে, যার ফলে একাধিক কাজ একসঙ্গে চালানো যায়।

১.১ Goroutines এবং Parallelism

Go-তে goroutines হল খুবই হালকা থ্রেড যা concurrency বা parallelism পরিচালনা করতে সহায়তা করে।

package main

import (
    "fmt"
    "time"
)

// Parallel function
func printNumbers() {
    for i := 1; i <= 5; i++ {
        fmt.Println(i)
        time.Sleep(time.Second) // স্লিপ করতে হবে, যাতে parallelism স্পষ্টভাবে দেখা যায়
    }
}

func main() {
    go printNumbers()  // goroutine তৈরি করা
    go printNumbers()  // আরও একটি goroutine তৈরি করা

    time.Sleep(6 * time.Second)  // main goroutine অপেক্ষা করবে, যাতে অন্য goroutines কাজ করতে পারে
    fmt.Println("Parallelism completed")
}

এখানে দুটি goroutine একসঙ্গে কাজ করছে এবং printNumbers ফাংশনটি প্রতিটি goroutine থেকে প্যারালালভাবে চালানো হচ্ছে। go কিওয়ার্ড দ্বারা গোরাউটিন তৈরি হয়, যা মূল ফাংশনের সাথে একসাথে চলে।

আউটপুট:

1
1
2
2
3
3
4
4
5
5
Parallelism completed

এখানে প্রতিটি goroutine আলাদাভাবে কাজ করছে, এবং একসাথে শেষ হচ্ছে।


২. Load Balancing (লোড ব্যালান্সিং)

Load Balancing হল একটি কৌশল যা সার্ভার বা সিস্টেমের উপর ভার সুষমভাবে বিতরণ করার জন্য ব্যবহৃত হয়, যাতে কোনো একক সার্ভার বা প্রসেসে অতিরিক্ত চাপ না পড়ে এবং পুরো সিস্টেমের কার্যকারিতা বৃদ্ধি পায়। Go তে load balancing সাধারণত worker goroutines এবং channels ব্যবহার করে ইমপ্লিমেন্ট করা হয়।

২.১ Load Balancing Example with Worker Goroutines

package main

import (
    "fmt"
    "math/rand"
    "time"
)

// Worker function, যেখানে বিভিন্ন কাজের লোড ভারসাম্য করা হবে
func worker(id int, jobs <-chan int, results chan<- int) {
    for job := range jobs {
        fmt.Printf("Worker %d started job %d\n", id, job)
        time.Sleep(time.Duration(rand.Intn(1000)) * time.Millisecond)  // কাজ করার সময়
        fmt.Printf("Worker %d finished job %d\n", id, job)
        results <- job * 2  // কাজের ফলাফল
    }
}

func main() {
    jobs := make(chan int, 10)   // jobs channel
    results := make(chan int, 10) // results channel

    // Worker goroutines তৈরি
    for w := 1; w <= 3; w++ {
        go worker(w, jobs, results)
    }

    // jobগুলি প্রেরণ করা
    for j := 1; j <= 5; j++ {
        jobs <- j
    }
    close(jobs)

    // ফলাফল গ্রহণ করা
    for a := 1; a <= 5; a++ {
        fmt.Println("Result:", <-results)
    }
}

এখানে:

  • আমরা তিনটি worker goroutine তৈরি করেছি।
  • jobs চ্যানেল মাধ্যমে jobs প্রেরণ করা হচ্ছে।
  • results চ্যানেল মাধ্যমে ফলাফল গ্রহণ করা হচ্ছে।

প্রতিটি worker goroutine একটি নির্দিষ্ট job প্রক্রিয়া করছে এবং শেষ হলে ফলাফলটি results চ্যানেলে পাঠাচ্ছে।

আউটপুট:

Worker 1 started job 1
Worker 2 started job 2
Worker 3 started job 3
Worker 1 finished job 1
Worker 1 started job 4
Worker 3 finished job 3
Worker 2 finished job 2
Worker 2 started job 5
Worker 1 finished job 4
Worker 3 started job 5
Worker 3 finished job 5
Result: 2
Result: 4
Result: 6
Result: 8
Result: 10

এখানে তিনটি worker goroutine parallelভাবে job প্রক্রিয়া করছে, যা load balancing তৈরি করে। প্রত্যেক worker একটি নির্দিষ্ট job গ্রহণ করছে এবং তার উপর কাজ করছে, যাতে কোনও এক worker-এ অতিরিক্ত চাপ না পড়ে।


৩. Advanced Load Balancing with Round-Robin

আরও উন্নত লোড ব্যালান্সিং পদ্ধতিতে round-robin কৌশল ব্যবহার করা যেতে পারে, যেখানে প্রতি worker প্রতি সময় একটি job পায়।

package main

import (
    "fmt"
    "time"
)

func worker(id int, jobs <-chan int, results chan<- int) {
    for job := range jobs {
        fmt.Printf("Worker %d started job %d\n", id, job)
        time.Sleep(2 * time.Second) // কাজ করার সময়
        fmt.Printf("Worker %d finished job %d\n", id, job)
        results <- job * 2  // কাজের ফলাফল
    }
}

func main() {
    jobs := make(chan int, 5)
    results := make(chan int, 5)

    // Worker goroutines তৈরি করা
    for w := 1; w <= 3; w++ {
        go worker(w, jobs, results)
    }

    // Round-Robin style job assignment
    for j := 1; j <= 5; j++ {
        jobs <- j
    }
    close(jobs)

    // ফলাফল গ্রহণ করা
    for a := 1; a <= 5; a++ {
        fmt.Println("Result:", <-results)
    }
}

এখানে:

  • Round-Robin স্টাইলের মাধ্যমে jobs চ্যানেলে গেটার্ড (distributed) করা হচ্ছে।
  • worker goroutines একে একে job নিয়ে কাজ করছে।

আউটপুট:

Worker 1 started job 1
Worker 2 started job 2
Worker 3 started job 3
Worker 1 finished job 1
Worker 1 started job 4
Worker 3 finished job 3
Worker 2 finished job 2
Worker 2 started job 5
Worker 1 finished job 4
Worker 3 started job 5
Worker 3 finished job 5
Result: 2
Result: 4
Result: 6
Result: 8
Result: 10

এখানে round-robin কৌশল ব্যবহার করে কাজ গুলি worker goroutines মধ্যে ব্যালান্স করা হচ্ছে।


৪. Load Balancing with Multiple Servers (Multiple Instances)

কিছু সময়ে, লোড ব্যালান্সিংয়ের জন্য আপনাকে একাধিক সার্ভার বা ইনস্ট্যান্স চালাতে হতে পারে, যেখানে রিকোয়েস্টগুলো একটি Load Balancer দ্বারা পরিচালিত হয়। তবে Go-তে সাধারনত একাধিক সার্ভার রেডিরেক্ট এবং ট্র্যাফিক ম্যানেজমেন্ট Nginx বা HAProxy দ্বারা করা হয়।


সারসংক্ষেপ

  • Parallelism: Go তে parallelism অর্জন করা সহজ goroutines ব্যবহার করে, যা একাধিক কাজ একসঙ্গে চালাতে সাহায্য করে।
  • Load Balancing: Load balancing Go তে worker goroutines এবং channels ব্যবহার করে খুব সহজে পরিচালনা করা যায়, যেখানে বিভিন্ন কাজ বা লোড সুষমভাবে worker goroutines মধ্যে ভাগ করা হয়।
  • Round-Robin Load Balancing: এই কৌশলে একে একে jobs worker goroutines এ পাঠানো হয়, যা সিস্টেমের উপর লোড evenly (সমানভাবে) বিতরণ করে।

Go তে Parallelism এবং Load Balancing কৌশল ব্যবহার করে আপনি আপনার সিস্টেমের কার্যকারিতা, পারফরম্যান্স এবং স্কেলেবিলিটি খুব সহজে উন্নত করতে পারেন।

Content added By
Promotion

Are you sure to start over?

Loading...