Rumah > pembangunan bahagian belakang > Golang > Amalan terbaik untuk melaksanakan penyelesaian yang cekap untuk penjadualan tugas teragih dan pelaksanaan dengan Golang dan RabbitMQ

Amalan terbaik untuk melaksanakan penyelesaian yang cekap untuk penjadualan tugas teragih dan pelaksanaan dengan Golang dan RabbitMQ

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Lepaskan: 2023-09-27 18:37:48
asal
743 orang telah melayarinya

Amalan terbaik untuk melaksanakan penyelesaian yang cekap untuk penjadualan tugas teragih dan pelaksanaan dengan Golang dan RabbitMQ

Tajuk: Golang dan RabbitMQ melaksanakan amalan terbaik untuk penjadualan dan pelaksanaan tugas teragih

Pengenalan:
Dalam persekitaran pengkomputeran moden, penjadualan dan pelaksanaan tugas teragih merupakan teknologi yang sangat penting. Golang, sebagai bahasa pengaturcaraan yang berkuasa dan cekap, digabungkan dengan RabbitMQ sebagai sistem baris gilir mesej yang boleh dipercayai, boleh memberikan penyelesaian yang sangat baik. Artikel ini akan memperkenalkan cara menggunakan Golang dan RabbitMQ untuk mencapai penjadualan dan pelaksanaan tugas teragih yang cekap, serta menyediakan contoh kod khusus.

  1. Pengenalan latar belakang
    Dalam sistem penjadualan dan pelaksanaan tugas teragih biasa, nod penjadualan tugas menghantar tugas ke baris gilir mesej, dan kemudian nod pelaksanaan menerima tugas dan melaksanakannya. Selepas pelaksanaan tugas selesai, keputusan dikembalikan ke nod penjadualan tugas. Gabungan Golang dan RabbitMQ boleh menyampaikan tugas dan keputusan dengan cepat dan boleh dipercayai, serta menyediakan penjadualan tugas teragih dan fungsi pelaksanaan yang cekap.
  2. Pasang dan konfigurasi RabbitMQ
    Pertama, kita perlu memasang dan mengkonfigurasi RabbitMQ dalam sistem. Sila rujuk kepada dokumentasi RabbitMQ rasmi dan ikut arahan untuk pemasangan dan konfigurasi.
  3. Buat nod penjadualan tugas
    Kami menggunakan Golang untuk mencipta nod penjadualan tugas. Pertama, kita perlu mengimport perpustakaan klien RabbitMQ.
import (
    "fmt"
    "log"
    "github.com/streadway/amqp"
)
Salin selepas log masuk
Salin selepas log masuk

Seterusnya, kami mencipta fungsi sambungan untuk nod penjadualan tugas dan memulakan objek sambungan RabbitMQ dan objek saluran.

func createSchedulerConn() (*amqp.Connection, *amqp.Channel, error) {
    conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/") // RabbitMQ连接地址和认证信息
    if err != nil {
        return nil, nil, err
    }

    ch, err := conn.Channel()
    if err != nil {
        return nil, nil, err
    }

    return conn, ch, nil
}
Salin selepas log masuk

Kita kemudian boleh membuat sambungan dan saluran dengan memanggil fungsi di atas.

conn, ch, err := createSchedulerConn()
if err != nil {
    log.Fatalf("Failed to create scheduler connection and channel: %v", err)
}
defer conn.Close()
defer ch.Close()
Salin selepas log masuk

Seterusnya, kita perlu mencipta baris gilir penjadualan tugas dan baris gilir hasil.

queueName := "task_queue"
resultQueueName := "result_queue"

_, err = ch.QueueDeclare(
    queueName,
    true,
    false,
    false,
    false,
    nil,
)

_, err = ch.QueueDeclare(
    resultQueueName,
    true,
    false,
    false,
    false,
    nil,
)
Salin selepas log masuk

Pada masa ini, nod penjadualan tugasan sedia untuk menerima tugasan.

  1. Buat nod pelaksanaan
    Kami juga menggunakan Golang untuk mencipta nod pelaksanaan. Pertama, kita juga perlu mengimport perpustakaan klien RabbitMQ.
import (
    "fmt"
    "log"
    "github.com/streadway/amqp"
)
Salin selepas log masuk
Salin selepas log masuk

Seterusnya, kami mencipta fungsi sambungan yang melaksanakan nod dan memulakan sambungan dan saluran.

func createWorkerConn() (*amqp.Connection, *amqp.Channel, error) {
    conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/") // RabbitMQ连接地址和认证信息
    if err != nil {
        return nil, nil, err
    }

    ch, err := conn.Channel()
    if err != nil {
        return nil, nil, err
    }

    return conn, ch, nil
}
Salin selepas log masuk

Kita kemudian boleh membuat sambungan dan saluran dengan memanggil fungsi di atas.

conn, ch, err := createWorkerConn()
if err != nil {
    log.Fatalf("Failed to create worker connection and channel: %v", err)
}
defer conn.Close()
defer ch.Close()
Salin selepas log masuk

Pada ketika ini, nod pelaksanaan bersedia untuk menerima tugas dan melaksanakannya.

  1. Terbitkan tugasan
    Dalam nod penjadualan tugas, kami boleh menghantar tugasan ke baris gilir penjadualan tugas dengan memanggil kod berikut.
body := "Hello, world!"
err = ch.Publish(
    "",
    queueName,
    false,
    false,
    amqp.Publishing{
        ContentType:  "text/plain",
        Body:         []byte(body),
    })
if err != nil {
    log.Fatalf("Failed to publish task: %v", err)
}
Salin selepas log masuk

Pada masa ini, tugasan telah diposkan ke baris gilir penjadualan tugas.

  1. Terima tugas dan laksanakannya
    Dalam nod pelaksanaan, kita perlu menggunakan kod berikut untuk menerima tugas dan melaksanakannya.
msgs, err := ch.Consume(
    queueName,
    "",
    false,
    false,
    false,
    false,
    nil,
)
if err != nil {
    log.Fatalf("Failed to register a consumer: %v", err)
}

for msg := range msgs {
    // 处理任务
    result := processTask(msg.Body)

    // 将结果发送到结果队列中
    err = ch.Publish(
        "",
        resultQueueName,
        false,
        false,
        amqp.Publishing{
            ContentType:  "text/plain",
            Body:         []byte(result),
        })
    if err != nil {
        log.Fatalf("Failed to publish result: %v", err)
    }

    // 确认任务已完成
    msg.Ack(false)
}
Salin selepas log masuk

Melalui kod di atas, nod pelaksanaan boleh terus menerima tugasan dan melaksanakannya, dan kemudian menerbitkan keputusan ke baris gilir hasil.

  1. Dapatkan hasil tugasan
    Dalam nod penjadualan tugas, kami menggunakan kod berikut untuk mendapatkan hasil pelaksanaan tugas.
msgs, err := ch.Consume(
    resultQueueName,
    "",
    true,
    false,
    false,
    false,
    nil,
)
if err != nil {
    log.Fatalf("Failed to register a consumer: %v", err)
}

for msg := range msgs {
    // 处理结果
    fmt.Println(string(msg.Body))
}
Salin selepas log masuk

Melalui kod di atas, nod penjadualan tugas boleh mendapatkan hasil pelaksanaan tugas.

  1. Ringkasan
    Artikel ini memperkenalkan cara menggunakan Golang dan RabbitMQ untuk mencapai penjadualan dan pelaksanaan tugas teragih yang cekap. Melalui contoh kod, kami menunjukkan cara membuat nod penjadualan tugas dan nod pelaksanaan, serta menunjukkan proses penerbitan, penerimaan dan pelaksanaan tugas. Penyelesaian yang menggabungkan Golang dan RabbitMQ ini boleh dengan cepat dan pasti melaksanakan fungsi penjadualan tugas dan pelaksanaan teragih, menyediakan penyelesaian yang cekap untuk persekitaran pengkomputeran teragih.

Rujukan:

  • Dokumentasi rasmi RabbitMQ: https://www.rabbitmq.com/documentation.html

Atas ialah kandungan terperinci Amalan terbaik untuk melaksanakan penyelesaian yang cekap untuk penjadualan tugas teragih dan pelaksanaan dengan Golang dan RabbitMQ. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan