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

Golang dan RabbitMQ melaksanakan sistem pemprosesan data berskala besar dipacu peristiwa

Sep 28, 2023 am 08:11 AM
golang rabbitmq dipacu acara

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)
    }
}
Salin selepas log masuk

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</code > dalam barisan. <p><code>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: 处理未知文件类型的逻辑
        }
    }
}
Salin selepas log masuk

在上述代码中,我们同样使用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 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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk membaca dan menulis fail dengan selamat menggunakan Golang? Bagaimana untuk membaca dan menulis fail dengan selamat menggunakan Golang? Jun 06, 2024 pm 05:14 PM

Membaca dan menulis fail dengan selamat dalam Go adalah penting. Garis panduan termasuk: Menyemak kebenaran fail Menutup fail menggunakan tangguh Mengesahkan laluan fail Menggunakan tamat masa konteks Mengikuti garis panduan ini memastikan keselamatan data anda dan keteguhan aplikasi anda.

Bagaimana untuk mengkonfigurasi kolam sambungan untuk sambungan pangkalan data Golang? Bagaimana untuk mengkonfigurasi kolam sambungan untuk sambungan pangkalan data Golang? Jun 06, 2024 am 11:21 AM

Bagaimana untuk mengkonfigurasi pengumpulan sambungan untuk sambungan pangkalan data Go? Gunakan jenis DB dalam pakej pangkalan data/sql untuk membuat sambungan pangkalan data untuk mengawal bilangan maksimum sambungan serentak;

Persamaan dan Perbezaan antara Golang dan C++ Persamaan dan Perbezaan antara Golang dan C++ Jun 05, 2024 pm 06:12 PM

Golang dan C++ masing-masing adalah sampah yang dikumpul dan bahasa pengaturcaraan pengurusan memori manual, dengan sistem sintaks dan jenis yang berbeza. Golang melaksanakan pengaturcaraan serentak melalui Goroutine, dan C++ melaksanakannya melalui benang. Pengurusan memori Golang adalah mudah, dan C++ mempunyai prestasi yang lebih kukuh. Dalam kes praktikal, kod Golang adalah lebih ringkas dan C++ mempunyai kelebihan prestasi yang jelas.

Seberapa curam keluk pembelajaran seni bina rangka kerja golang? Seberapa curam keluk pembelajaran seni bina rangka kerja golang? Jun 05, 2024 pm 06:59 PM

Keluk pembelajaran seni bina rangka kerja Go bergantung pada kebiasaan dengan bahasa Go dan pembangunan bahagian belakang serta kerumitan rangka kerja yang dipilih: pemahaman yang baik tentang asas bahasa Go. Ia membantu untuk mempunyai pengalaman pembangunan bahagian belakang. Rangka kerja yang berbeza dalam kerumitan membawa kepada perbezaan dalam keluk pembelajaran.

Bagaimana untuk menjana elemen rawak dari senarai di Golang? Bagaimana untuk menjana elemen rawak dari senarai di Golang? Jun 05, 2024 pm 04:28 PM

Cara menjana unsur rawak senarai dalam Golang: gunakan rand.Intn(len(senarai)) untuk menjana integer rawak dalam julat panjang senarai gunakan integer sebagai indeks untuk mendapatkan elemen yang sepadan daripada senarai.

Perbandingan kebaikan dan keburukan rangka kerja golang Perbandingan kebaikan dan keburukan rangka kerja golang Jun 05, 2024 pm 09:32 PM

Rangka kerja Go menyerlah kerana kelebihan prestasi tinggi dan konkurensinya, tetapi ia juga mempunyai beberapa kelemahan, seperti agak baharu, mempunyai ekosistem pembangun yang kecil dan kekurangan beberapa ciri. Selain itu, perubahan pantas dan keluk pembelajaran boleh berbeza dari rangka kerja ke rangka kerja. Rangka kerja Gin ialah pilihan popular untuk membina API RESTful kerana penghalaan yang cekap, sokongan JSON terbina dalam dan pengendalian ralat yang berkuasa.

Apakah amalan terbaik untuk pengendalian ralat dalam rangka kerja Golang? Apakah amalan terbaik untuk pengendalian ralat dalam rangka kerja Golang? Jun 05, 2024 pm 10:39 PM

Amalan terbaik: Cipta ralat tersuai menggunakan jenis ralat yang ditakrifkan dengan baik (pakej ralat) Sediakan lebih banyak butiran Log ralat dengan sewajarnya Sebarkan ralat dengan betul dan elakkan menyembunyikan atau menyekat ralat Balut seperti yang diperlukan untuk menambah konteks

arahan penggunaan dokumen rangka kerja golang arahan penggunaan dokumen rangka kerja golang Jun 05, 2024 pm 06:04 PM

Bagaimana untuk menggunakan dokumentasi rangka kerja Go? Tentukan jenis dokumen: tapak web rasmi, repositori GitHub, sumber pihak ketiga. Fahami struktur dokumentasi: permulaan, tutorial mendalam, manual rujukan. Cari maklumat seperti yang diperlukan: Gunakan struktur organisasi atau fungsi carian. Fahami istilah dan konsep: Baca dengan teliti dan fahami istilah dan konsep baharu. Kes praktikal: Gunakan Beego untuk mencipta pelayan web mudah. Dokumentasi rangka kerja Go yang lain: Gin, Echo, Buffalo, Fiber.

See all articles