Jadual Kandungan
Fahami mesej baris gilir
Baris gilir mesej biasa
Kelebihan dan senario yang berkenaan menggunakan baris gilir mesej dalam Go
Pasang RabbitMQ
Rumah pembangunan bahagian belakang Golang Bagaimana untuk menggunakan baris gilir mesej dalam Go?

Bagaimana untuk menggunakan baris gilir mesej dalam Go?

May 11, 2023 pm 03:46 PM
pergi bahasa (golang) penggunaan baris gilir mesej

Baris gilir mesej ialah corak seni bina sistem biasa, yang memainkan peranan yang sangat penting dalam mengendalikan konkurensi tinggi dan pemprosesan tugas tak segerak. Dalam bahasa Go, menggunakan baris gilir mesej telah menjadi sangat mudah dan mudah melalui beberapa perpustakaan dan alatan baris gilir mesej sumber terbuka.

Artikel ini akan memperkenalkan cara menggunakan baris gilir mesej dalam Go, termasuk yang berikut:

  1. Memahami baris gilir mesej
  2. Baris gilir mesej biasa
  3. Kelebihan dan senario yang berkenaan menggunakan baris gilir mesej dalam Go
  4. Pustaka baris gilir mesej dalam bahasa Go
  5. Menggunakan contoh untuk menunjukkan cara menggunakan baris gilir mesej dalam Go
Fahami mesej baris gilir

Baris gilir mesej ialah corak seni bina yang menggunakan baris gilir untuk cache, menghantar dan menyimpan mesej secara tak segerak. Baris gilir mesej biasanya dibahagikan kepada tiga bahagian: pengeluar, pengguna dan baris gilir. Pengeluar menghantar mesej ke baris gilir, dan pengguna mengambil mesej dari baris gilir untuk diproses. Tujuan baris gilir mesej adalah untuk memisahkan kebergantungan masa dan ruang antara pengeluar dan pengguna dan melaksanakan pemprosesan tugas tak segerak.

Baris gilir mesej boleh cache data, melaksanakan pemprosesan tak segerak, pencukuran beban puncak (untuk menangani permintaan serentak yang tinggi dalam tempoh yang singkat) dan pengimbangan beban, dsb. Ia adalah bahagian penting untuk menyokong reka bentuk besar -sistem teragih berskala.

Baris gilir mesej biasa

Terdapat banyak perpustakaan baris gilir mesej dan alatan di pasaran yang menyokong pelbagai bahasa pengaturcaraan yang lebih biasa adalah yang berikut:

  1. RabbitMQ. : RabbitMQ ialah sistem baris gilir mesej sumber terbuka yang menyokong berbilang protokol dan bahasa pengaturcaraan, seperti AMQP, STOMP, MQTT, dll. Pembangun boleh mengaksesnya melalui pelbagai klien bahasa, seperti Go, Java, Python, dsb. RabbitMQ ditulis dalam bahasa Erlang dan digunakan secara meluas untuk menyokong senario pemprosesan masa nyata seperti IoT, sembang kumpulan dan pemantauan.
  2. Apache Kafka: Apache Kafka ialah sistem baris gilir mesej berdasarkan model terbitan/langgan, dibangunkan oleh LinkedIn, dan digunakan terutamanya untuk mengendalikan pemprosesan data penstriman berterusan. Kafka mengedarkan mesej melalui berbilang partition untuk menyokong daya pemprosesan yang tinggi dan kebolehskalaan yang tinggi.
  3. ActiveMQ: ActiveMQ ialah sistem baris gilir mesej berasaskan JMS yang popular yang menyokong protokol penghantaran berbilang dan akses bahasa pengaturcaraan, seperti AMQP, STOMP, Openwire, dsb.
  4. NSQ: NSQ ialah platform pemprosesan mesej teragih masa nyata, yang terdiri daripada dua komponen: nsq dan nsqd ialah pelayan proksi TCP untuk interaksi pelanggan, manakala nsqd ialah perkhidmatan untuk mesej dan baris gilir yang berterusan.
Kelebihan dan senario yang berkenaan menggunakan baris gilir mesej dalam Go

Bahasa Go menyokong coroutine secara asli, jadi menggunakan baris gilir mesej untuk mengendalikan tugas tak segerak adalah amat sesuai. Bahasa Go menyediakan banyak perpustakaan sumber terbuka dan alatan untuk baris gilir mesej, yang juga agak mudah digunakan.

Selain itu, kerana baris gilir mesej memproses mesej secara tidak segerak, tugasan boleh dipunggah untuk mengelakkan konkurensi tinggi pada satu mesin. Oleh itu, baris gilir mesej boleh digunakan dalam senario berikut:

  1. Pemprosesan sejumlah besar data: seperti pemprosesan sejumlah besar data pelayan dalam log tapak web, ujian tekanan, dsb.;
  2. Pemprosesan tak segerak dan pengagihan tugas: Seperti penghantaran e-mel, pemberitahuan SMS, dll.; senario serentak pengguna: seperti jualan kilat e-dagang, ulasan serentak tinggi, dsb.;
  3. Penyahgandingan dan pengembangan aplikasi: seperti menyepadukan pemberitahuan perkhidmatan mesej luaran dan mengasingkan interaksi data antara sistem.
  4. Pustaka baris gilir mesej dalam bahasa Go
  5. Dalam bahasa Go, terdapat banyak perpustakaan baris gilir mesej sumber terbuka tersedia, seperti:
Pelanggan RabbitMQ AMQP perpustakaan: https://github.com/streadway/amqp;

Pustaka pelanggan Apache Kafka: https://github.com/confluentinc/confluent-kafka-go; : https://github.com/nsqio/go-nsq.
  1. Menggunakan perpustakaan sumber terbuka ini boleh menyambung dengan mudah ke sistem baris gilir mesej yang berbeza, membolehkan pembangun menumpukan lebih pada pembangunan logik pada barisan perniagaan, meningkatkan kecekapan pembangunan dan kebolehbacaan kod.
  2. Tunjukkan cara menggunakan baris gilir mesej dalam Go through contoh
  3. Di bawah ini kami akan tunjukkan cara menggunakan baris gilir mesej dalam Go through contoh mudah.

Andaikan kita ingin merangkak data imej daripada sesetengah tapak web dan menyimpannya secara setempat. Kita boleh menggunakan go untuk melengkapkan program ini. Untuk mencapai muat turun tak segerak beberapa gambar, kami menggunakan RabbitMQ sebagai baris gilir mesej dan melengkapkan langkah berikut dalam Go:

Pasang RabbitMQ

Pasang RabbitMQ, alamat muat turun laman web rasmi: https://www.rabbitmq.com/download.html;

Konfigurasikan RabbitMQ Selepas pemasangan, masukkan direktori bin (sila abaikan akhiran .bat untuk platform bukan Windows) dan jalankan: ./rabbitmqctl start. untuk memulakan RabbitMQ;

Buat hos maya MQ dan jalankan: ./rabbitmqctl add_vhost test; p test test ".
    " ".
  1. " ".*";
  2. Mulakan antara muka pengurusan web RabbitMQ, jalankan: ./rabbitmq-plugins enable rabbitmq_management, masukkan alamat http:// localhost:15672 dalam pelayar untuk memasuki antara muka Pengurusan.
  3. Menulis kod
  4. Kita boleh menggunakan perpustakaan github.com/streadway/amqp untuk berinteraksi dengan RabbitMQ. Di bawah ialah kod.
  5. Mula-mula tulis kod perangkak untuk merangkak alamat imej yang perlu dimuat turun dan hantar ke RabbitMQ:
  6. func main() {
        spider()
    }
    
    func spider() {
        url := "https://www.example.com"
        doc, _ := goquery.NewDocument(url)
        doc.Find(".img_wrapper img").Each(func(i int, s *goquery.Selection) {
            imgUrl, _ := s.Attr("src")
            publishToMQ(imgUrl)
        })
    }
    
    func publishToMQ(msg string) {
        conn, err := amqp.Dial("amqp://test:test@localhost:5672/test")
        failOnError(err, "Failed to connect to RabbitMQ")
        defer conn.Close()
    
        ch, err := conn.Channel()
        failOnError(err, "Failed to open a channel")
        defer ch.Close()
    
        q, err := ch.QueueDeclare(
            "image_downloader", // name
            true,               // durable
            false,              // delete when unused
            false,              // exclusive
            false,              // no-wait
            nil,                // arguments
        )
        failOnError(err, "Failed to declare a queue")
    
        err = ch.Publish(
            "",     // exchange
            q.Name, // routing key
            false,  // mandatory
            false,  // immediate
            amqp.Publishing{
                ContentType: "text/plain",
                Body:        []byte(msg),
            })
        failOnError(err, "Failed to publish a message")
    
        log.Printf(" [x] Sent %s", msg)
    }
    Salin selepas log masuk

    Kemudian tulis pemuat turun imej. Dengan mendengar baris gilir mesej RabbitMQ, muat turun imej tak segerak dicapai:

    func main() {
        consumeMQ()
    }
    
    func consumeMQ() {
        conn, err := amqp.Dial("amqp://test:test@localhost:5672/test")
        failOnError(err, "Failed to connect to RabbitMQ")
        defer conn.Close()
    
        ch, err := conn.Channel()
        failOnError(err, "Failed to open a channel")
        defer ch.Close()
    
        q, err := ch.QueueDeclare(
            "image_downloader", // name
            true,               // durable
            false,              // delete when unused
            false,              // exclusive
            false,              // no-wait
            nil,                // arguments
        )
        failOnError(err, "Failed to declare a queue")
    
        msgs, err := ch.Consume(
            q.Name, // queue
            "",     // consumer
            true,   // auto-ack
            false,  // exclusive
            false,  // no-local
            false,  // no-wait
            nil,    // args
        )
        failOnError(err, "Failed to register a consumer")
    
        forever := make(chan bool)
    
        go func() {
            for d := range msgs {
                log.Printf("Received a message: %s", d.Body)
                downloadImage(string(d.Body))
            }
        }()
    
        log.Printf(" [*] Waiting for messages. To exit press CTRL+C")
        <-forever
    }
    
    func downloadImage(url string) {
        resp, err := http.Get(url)
        if err != nil {
            log.Fatal(err)
        }
        defer resp.Body.Close()
    
        file, err := os.Create(uuid.New().String() + ".jpg")
        if err != nil {
            log.Fatal(err)
        }
        defer file.Close()
    
        _, err = io.Copy(file, resp.Body)
        if err != nil {
            log.Fatal(err)
        }
    
        log.Printf("Downloaded an image: %s", url)
    }
    Salin selepas log masuk

    Dalam kod di atas, kami mencipta baris gilir kerja "pemuat turun imej". ia menghantarnya ke baris gilir kerja. Pengguna akan mendengar baris gilir kerja, dan selepas menerima mesej, hubungi fungsi muat turunImej untuk memuat turun fail imej.

    Contoh di atas ialah kes penggunaan mudah menggunakan RabbitMQ. Menggunakan perpustakaan baris gilir mesej lain adalah serupa, anda hanya perlu melaksanakan sambungan dan operasi melalui API yang berbeza.

    Ikhtisar

    Dalam artikel ini kami memperkenalkan dan menerangkan maksud baris gilir mesej Dalam sejumlah besar senario pemprosesan data, penggunaan tak segerak adalah penting. Bahasa Go menjadikan pemprosesan tugas tak segerak mudah dan cekap kerana mekanisme coroutinenya sendiri. Ditambah dengan perpustakaan sumber terbuka yang kaya dengan bahasa Go itu sendiri, menjadi sangat mudah untuk menggunakan baris gilir mesej untuk melaksanakan pemprosesan mesej tak segerak.

    Melalui contoh di atas, kita dapat melihat bahawa apabila melaksanakan pemprosesan tugas asynchronous, menggunakan baris gilir mesej boleh meningkatkan kecekapan pemprosesan dengan sangat baik dan menggunakan baris gilir mesej dalam bahasa Go juga sangat mudah. Dalam projek, adalah disyorkan untuk menggunakan perpustakaan baris gilir mesej sumber terbuka, seperti RabbitMQ atau Apache Kafka.

Atas ialah kandungan terperinci Bagaimana untuk menggunakan baris gilir mesej dalam Go?. 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

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

<🎜>: Bubble Gum Simulator Infinity - Cara Mendapatkan dan Menggunakan Kekunci Diraja
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Sistem Fusion, dijelaskan
3 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)

Topik panas

Tutorial Java
1664
14
Tutorial PHP
1268
29
Tutorial C#
1248
24
Bolehkah golang digunakan sebagai front-end? Bolehkah golang digunakan sebagai front-end? Jun 06, 2023 am 09:19 AM

Golang boleh digunakan sebagai front-end Golang adalah bahasa pengaturcaraan yang sangat serba boleh yang boleh digunakan untuk membangunkan pelbagai jenis aplikasi, termasuk aplikasi front-end Dengan menggunakan Golang untuk menulis front-end, anda boleh menyingkirkan a siri masalah yang disebabkan oleh bahasa seperti JavaScript Contohnya, masalah seperti keselamatan jenis yang lemah, prestasi rendah dan sukar untuk mengekalkan kod.

Adakah golang sesuai untuk menulis program desktop? Adakah golang sesuai untuk menulis program desktop? Jun 06, 2023 pm 01:38 PM

Golang tidak sesuai untuk menulis program desktop Fungsinya tidak selancar dan berkuasa seperti C# dan C++ Selain itu, pustaka GUI Go tidak semudah C# dan C/C++ dipertingkatkan dalam masa terdekat Lagipun, Go digunakan untuk membangunkan program desktop.

Cara menggunakan fungsi caching dalam rangka kerja Yii Cara menggunakan fungsi caching dalam rangka kerja Yii Jul 29, 2023 pm 10:42 PM

Cara menggunakan fungsi caching dalam rangka kerja Yii Caching ialah kaedah pengoptimuman prestasi biasa yang boleh meningkatkan kelajuan tindak balas tapak web atau aplikasi dengan ketara. Rangka kerja Yii menyediakan fungsi caching yang berkuasa yang boleh membantu kami memudahkan penggunaan cache dan proses pengurusan. Artikel ini akan memperkenalkan cara menggunakan fungsi caching dalam rangka kerja Yii dan memberikan beberapa contoh kod. 1. Komponen Caching dalam rangka kerja Yii Fungsi caching dalam rangka kerja Yii terdiri daripada komponen yang dipanggil komponen caching (Cac

Berapa banyak kata kunci yang terdapat dalam golang? Berapa banyak kata kunci yang terdapat dalam golang? Jun 05, 2023 pm 02:50 PM

Terdapat 25 kata kunci, iaitu: 2. lalai; pergi; 12. peta 13. struct;

Pembangunan Websocket bahasa Go: cara mengendalikan sejumlah besar sambungan serentak Pembangunan Websocket bahasa Go: cara mengendalikan sejumlah besar sambungan serentak Dec 14, 2023 pm 01:47 PM

Pembangunan Websocket bahasa Go: Cara mengendalikan sejumlah besar sambungan serentak Websocket ialah protokol komunikasi dupleks penuh Ia mewujudkan sambungan berterusan antara penyemak imbas dan pelayan, membolehkan pelayan menghantar mesej secara aktif kepada klien, dan klien boleh. juga gunakan Sambungan menghantar mesej kepada pelayan. Disebabkan oleh kecekapan masa nyata dan tingginya, Websocket telah digunakan secara meluas dalam komunikasi masa nyata, sembang segera dan senario lain. Walau bagaimanapun, dalam aplikasi sebenar, selalunya perlu untuk mengendalikan sejumlah besar sambungan serentak. dalam proses pembangunan

Adakah golang bahasa peringkat tinggi? Adakah golang bahasa peringkat tinggi? Jun 06, 2023 pm 12:02 PM

Golang ialah bahasa peringkat tinggi Ia adalah pengaturcaraan yang lebih dekat dengan bahasa semula jadi dan formula matematik Ia pada asasnya dipisahkan daripada sistem perkakasan mesin dan menulis program dengan cara yang lebih mudah untuk difahami oleh orang menyelesaikan masalah praktikal dalam proses pembangunan sistem besar dan menyokong concurrency , spesifikasi bersatu, ringkas dan elegan, dan prestasi yang berkuasa adalah untuk "mempunyai kedua-dua kelajuan pembangunan bahasa dinamik seperti Python dan prestasi dan keselamatan bahasa yang disusun seperti C/C++."

Bagaimana untuk menggunakan pemprosesan rentetan dalam Go? Bagaimana untuk menggunakan pemprosesan rentetan dalam Go? May 11, 2023 pm 04:21 PM

Go, sebagai bahasa pengaturcaraan yang berkuasa, menyediakan banyak fungsi dan kaedah pemprosesan rentetan. Untuk kita menguasai pengetahuan ini dengan lebih baik, artikel ini akan memperkenalkan jenis rentetan dan fungsi pemprosesan rentetan asas dalam Go, termasuk penciptaan rentetan, penyambungan, pemotongan, perbandingan dan carian. Jenis rentetan Dalam Go, jenis rentetan ditakrifkan sebagai jujukan aksara baca sahaja, rentetan taip. Nilai rentetan terdiri daripada jujukan aksara yang disertakan dengan sepasang petikan berganda, contohnya: str:="Hello,

Analisis perbandingan baris gilir mesej PHP dan komunikasi pelbagai proses Analisis perbandingan baris gilir mesej PHP dan komunikasi pelbagai proses Jul 09, 2023 pm 01:57 PM

Analisis perbandingan baris gilir mesej PHP dan komunikasi berbilang proses Semasa membangunkan aplikasi, kita sering perlu mempertimbangkan cara melaksanakan komunikasi antara proses. Sebagai bahasa skrip yang popular, PHP menyediakan pelbagai cara untuk melaksanakan komunikasi antara proses, termasuk baris gilir mesej dan komunikasi berbilang proses. Artikel ini akan menjalankan analisis perbandingan kedua-dua kaedah ini dan menyediakan contoh kod yang berkaitan. 1. Baris Mesej Baris gilir mesej ialah mekanisme komunikasi berdasarkan penghantaran mesej, yang membolehkan proses berkomunikasi dengan menghantar dan menerima mesej. PHP menyediakan pelbagai sambungan baris gilir mesej

See all articles