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

WBOY
WBOYasal
2023-09-27 18:37:48688semak imbas

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"
)

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
}

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()

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,
)

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"
)

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
}

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()

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)
}

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)
}

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))
}

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:
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