Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Golang dan RabbitMQ melaksanakan sistem pemprosesan data berskala besar dipacu peristiwa

Golang dan RabbitMQ melaksanakan sistem pemprosesan data berskala besar dipacu peristiwa

王林
王林asal
2023-09-28 08:11:011435semak imbas

Golang dan RabbitMQ melaksanakan sistem pemprosesan data berskala besar dipacu peristiwa

Golang dan RabbitMQ melaksanakan sistem pemprosesan data berskala besar dipacu peristiwa

Abstrak:

#🎜🎜🎜🎜 hari ini data Pada era ini, pemprosesan data berskala besar telah menjadi keperluan bagi banyak perusahaan. Untuk mengendalikan data ini dengan cekap, corak seni bina dipacu peristiwa menjadi semakin popular. Golang, sebagai bahasa pengaturcaraan yang cekap dan boleh dipercayai, dan RabbitMQ, sebagai sistem baris gilir mesej yang boleh dipercayai, boleh digunakan untuk membina sistem pemprosesan data berskala besar dipacu peristiwa yang cekap. Artikel ini akan memperkenalkan cara menggunakan Golang dan RabbitMQ untuk membina sistem sedemikian dan memberikan contoh kod khusus.

    Pengenalan
Dengan perkembangan pesat Internet, sejumlah besar data terus muncul, dan banyak syarikat menghadapi cabaran pemprosesan data ini. Kaedah pemprosesan kelompok tradisional tidak lagi dapat memenuhi keperluan untuk masa nyata dan responsif, jadi model seni bina dipacu peristiwa semakin popular. Seni bina dipacu peristiwa boleh menangani cabaran pemprosesan data berskala besar dengan lebih baik dengan membahagikan sistem kepada komponen diskret, autonomi dan berkomunikasi melalui penghantaran mesej.

    Pengenalan kepada Golang dan RabbitMQ
Golang ialah bahasa pengaturcaraan peringkat tinggi yang dibangunkan oleh Google Ia mempunyai ciri-ciri keselarasan tinggi dan tinggi prestasi. Melalui Goroutine dan Channel, Golang boleh melaksanakan operasi serentak dan segerak dengan mudah, yang sangat sesuai untuk membina sistem dipacu peristiwa yang cekap.

RabbitMQ ialah sistem baris gilir mesej yang boleh dipercayai berdasarkan protokol AMQP (Advanced Message Qeuing Protocol), yang menyediakan mekanisme penghantaran mesej yang boleh dipercayai dan berskala. RabbitMQ boleh menghantar mesej daripada pengeluar kepada berbilang pengguna, membolehkan penyahgandingan dan kebolehskalaan mendatar.

    Membina sistem pemprosesan data dipacu peristiwa
Untuk menunjukkan cara membina sistem pemprosesan data dipacu peristiwa menggunakan Golang dan RabbitMQ, kami anggap bahawa kita mempunyai Keperluan: Baca fail dari folder dan lakukan pemprosesan yang berbeza mengikut jenis fail yang berbeza.

Pertama, kita perlu mencipta pengeluar untuk membaca fail dari folder dan menghantar maklumat fail ke baris gilir RabbitMQ. Berikut ialah contoh kod Golang:

package main

import (
    "io/ioutil"
    "log"
    "os"
    "path/filepath"

    "github.com/streadway/amqp"
)

func main() {
    conn, _ := amqp.Dial("amqp://guest:guest@localhost:5672/")
    defer conn.Close()

    ch, _ := conn.Channel()
    defer ch.Close()

    files, _ := ioutil.ReadDir("./folder")
    for _, file := range files {
        filePath := filepath.Join("./folder", file.Name())

        data, _ := ioutil.ReadFile(filePath)

        msg := amqp.Publishing{
            ContentType: "text/plain",
            Body:        data,
        }
        
        ch.Publish(
            "",           // exchange
            "file_queue", // routing key
            false,        // mandatory
            false,        // immediate
            msg,
        )
        
        log.Printf("Sent file: %q", filePath)
    }
}

Dalam kod di atas, kami menggunakan pakej klien RabbitMQ's Go github.com/streadway/amqp untuk mencipta pelayan dengan sambungan RabbitMQ dan mencipta saluran untuk komunikasi dengan pelayan. Kemudian, kami menggunakan fungsi ioutil.ReadDir untuk membaca fail dalam folder dan fungsi ioutil.ReadFile untuk membaca kandungan fail. Selepas itu, kami merangkum kandungan fail ke dalam badan mesej amqp.Publishing dan menggunakan fungsi ch.Publish untuk menghantar mesej kepada RabbitMQ bernama file_queue dalam barisan.

github.com/streadway/amqp来创建一个与RabbitMQ服务器的连接,并创建一个通道用于与服务器通信。然后,我们使用ioutil.ReadDir函数读取文件夹中的文件,并使用ioutil.ReadFile函数读取文件内容。之后,我们将文件内容封装成消息体amqp.Publishing,并使用ch.Publish函数将消息发送到名为file_queue的RabbitMQ队列中。

然后,我们需要创建一个消费者,用于接收RabbitMQ队列中的消息,并根据文件类型进行不同的处理。以下是一个示例的Golang代码:

package main

import (
    "log"

    "github.com/streadway/amqp"
)

func main() {
    conn, _ := amqp.Dial("amqp://guest:guest@localhost:5672/")
    defer conn.Close()

    ch, _ := conn.Channel()
    defer ch.Close()

    msgs, _ := ch.Consume(
        "file_queue", // queue
        "",           // consumer
        true,         // auto-ack
        true,         // exclusive
        false,        // no-local
        false,        // no-wait
        nil,          // args
    )
    
    for msg := range msgs {
        // 根据文件类型处理消息
        fileContentType := msg.ContentType
        switch fileContentType {
        case "text/plain":
            // 处理文本文件
            log.Printf("Processing text file: %q", string(msg.Body))
        case "image/jpeg":
            // 处理图片文件
            log.Printf("Processing image file")
            // TODO: 处理图片文件的逻辑
        default:
            // 处理其他文件类型
            log.Printf("Processing unknown file type")
            // TODO: 处理未知文件类型的逻辑
        }
    }
}

在上述代码中,我们同样使用RabbitMQ的Go客户端包github.com/streadway/amqp来创建一个与RabbitMQ服务器的连接,并创建一个通道用于与服务器通信。然后,我们使用ch.Consume函数进行消费消息的订阅,并使用for msg := range msgsKemudian, kita perlu mencipta pengguna untuk menerima mesej daripada baris gilir RabbitMQ dan melakukan pemprosesan yang berbeza berdasarkan jenis fail. Berikut ialah contoh kod Golang:

rrreee
    Dalam kod di atas, kami juga menggunakan pakej klien RabbitMQ's Go github.com/streadway/amqp untuk mencipta sambungan RabbitMQ A ke pelayan dan mencipta saluran untuk komunikasi dengan pelayan. Kemudian, kami menggunakan fungsi ch.Consume untuk melanggan mesej pengguna dan menggunakan gelung for msg := range msgs untuk menerima mesej. Semasa memproses mesej, kami menentukan jenis fail dengan menyemak ContentType mesej dan melaksanakan logik pemprosesan yang sepadan berdasarkan jenis fail yang berbeza.
Ringkasan

Artikel ini memperkenalkan cara menggunakan Golang dan RabbitMQ untuk membina sistem pemprosesan data berskala besar dipacu peristiwa. Melalui keselarasan tinggi dan ciri prestasi tinggi Golang dan mekanisme pemesejan RabbitMQ yang boleh dipercayai, kami boleh membina sistem pemprosesan data yang cekap dan boleh dipercayai dengan mudah. Bukan itu sahaja, Golang dan RabbitMQ juga boleh memenuhi keperluan masa nyata dan responsif apabila memproses data berskala besar. Artikel ini menyediakan contoh kod khusus berdasarkan Golang dan RabbitMQ untuk membantu pembaca memahami cara menggunakan corak seni bina ini dalam projek sebenar.

    Rujukan:
  • laman web rasmi Golang: https://golang.org/
  • RabbitMQ laman web rasmi: https:// golang.org/ /www.rabbitmq.com/
RabbitMQ’s Go pakej pelanggan: https://github.com/streadway/amqp#🎜🎜##🎜🎜#

Atas ialah kandungan terperinci Golang dan RabbitMQ melaksanakan sistem pemprosesan data berskala besar dipacu peristiwa. 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