Rumah pembangunan bahagian belakang Golang golang Petua pengaturcaraan WebSocket: mengendalikan sambungan serentak

golang Petua pengaturcaraan WebSocket: mengendalikan sambungan serentak

Dec 18, 2023 am 10:54 AM
golang websocket sambungan serentak

golang WebSocket编程技巧:处理并发连接

Golang ialah bahasa pengaturcaraan yang berkuasa, dan penggunaannya dalam pengaturcaraan WebSocket semakin dihargai oleh pembangun. WebSocket ialah protokol berasaskan TCP yang membenarkan komunikasi dua hala antara klien dan pelayan. Dalam artikel ini, kami akan memperkenalkan cara menggunakan Golang untuk menulis pelayan WebSocket yang cekap yang mengendalikan berbilang sambungan serentak pada masa yang sama. Sebelum memperkenalkan teknik, mari kita pelajari dahulu apa itu WebSocket.

Pengenalan kepada WebSocket

WebSocket ialah protokol komunikasi dupleks penuh yang membolehkan sambungan berterusan diwujudkan antara pelanggan dan pelayan, membolehkan komunikasi dua hala masa nyata. Tidak seperti HTTP, sambungan WebSocket adalah dua arah, dan pelayan boleh secara proaktif menghantar mesej kepada pelanggan tanpa menunggu pelanggan meminta.

Dalam sambungan WebSocket, sebaik sahaja klien memulakan permintaan sambungan, pelayan boleh menggunakan sambungan TCP yang telah ditetapkan untuk menghantar data kepada klien. Pelanggan dan pelayan boleh mendengar dan memproses mesej dalam cara seperti peristiwa Apabila peristiwa dicetuskan, kedua-dua pelanggan dan pelayan boleh menerima data yang dihantar oleh pihak lain.

Petua Pengaturcaraan WebSocket Golang

Sekarang mari kita kaji cara menggunakan Golang untuk menulis pelayan WebSocket yang cekap yang mengendalikan berbilang sambungan serentak pada masa yang sama. Berikut ialah beberapa petua tentang pengaturcaraan Golang WebSocket:

  1. Sambungan Serentak

Semasa menulis pelayan WebSocket, kita perlu mempertimbangkan sambungan serentak. Kita perlu memastikan bahawa pelayan boleh mengendalikan berbilang pelanggan yang mewujudkan sambungan secara serentak sambil mengekalkan kebebasan setiap sambungan. Untuk mencapai matlamat ini, kita boleh menggunakan goroutine dan saluran dalam bahasa Go.

Berikut ialah contoh mudah yang menunjukkan cara menggunakan goroutin dan saluran untuk mengendalikan berbilang sambungan serentak:

package main

import (
    "fmt"
    "log"
    "net/http"
)

var clients = make(map[*websocket.Conn]bool) // connected clients
var broadcast = make(chan []byte)           // broadcast channel

// Configure the upgrader
var upgrader = websocket.Upgrader{}

func main() {
    // Create a simple file server
    fs := http.FileServer(http.Dir("public"))
    http.Handle("/", fs)

    // Configure websocket route
    http.HandleFunc("/ws", handleConnections)

    // Start listening for incoming chat messages
    go handleMessages()

    // Start the server on localhost:8000
    log.Println("http server started on :8000")
    err := http.ListenAndServe(":8000", nil)
    if err != nil {
        log.Fatal("ListenAndServe: ", err)
    }
}

func handleConnections(w http.ResponseWriter, r *http.Request) {
    // Upgrade initial GET request to a websocket
    ws, err := upgrader.Upgrade(w, r, nil)
    if err != nil {
        log.Fatal(err)
    }

    // Make sure we close the connection when the function returns
    defer ws.Close()

    // Register our new client
    clients[ws] = true

    for {
        // Read in a new message
        _, msg, err := ws.ReadMessage()
        if err != nil {
            log.Printf("error: %v", err)
            delete(clients, ws)
            break
        }

        // Send the newly received message to the broadcast channel
        broadcast <- msg
    }
}

func handleMessages() {
    for {
        // Grab the next message from the broadcast channel
        msg := <-broadcast

        // Send it out to every client that is currently connected
        for client := range clients {
            err := client.WriteMessage(websocket.TextMessage, msg)
            if err != nil {
                log.Printf("error: %v", err)
                client.Close()
                delete(clients, client)
            }
        }
    }
}
  1. Paket degupan jantung

Memandangkan sambungan WebSocket ialah sambungan berterusan, ia mungkin terganggu atas pelbagai sebab, seperti rangkaian Kegagalan atau pelayar dimulakan semula. Untuk mengelakkan perkara ini daripada berlaku, kami harus menghantar paket degupan jantung kepada pelanggan sekali-sekala untuk memastikan sambungan kekal aktif.

Berikut ialah contoh mudah yang menunjukkan cara menggunakan goroutine dan pemasa untuk melaksanakan paket degupan jantung:

package main

import (
    "github.com/gorilla/websocket"
    "time"
)

// Configure the upgrader
var upgrader = websocket.Upgrader{}

func handleConnection(ws *websocket.Conn) {
    // Set the read deadline for the connection
    ws.SetReadDeadline(time.Now().Add(5 * time.Second))

    for {
        // Read a message from the client
        _, _, err := ws.ReadMessage()
        if err != nil {
            if websocket.IsCloseError(err, websocket.CloseAbnormalClosure) ||
                websocket.IsCloseError(err, websocket.CloseGoingAway) {
                // The client has closed the connection
                return
            } else if netErr, ok := err.(net.Error); ok && netErr.Timeout() {
                // A timeout has occurred, send a ping message to the client
                ping(ws)
            } else {
                // Some other error has occurred
                log.Println(err)
                return
            }
        }
    }
}

// Send a PING message to the client
func ping(ws *websocket.Conn) {
    if err := ws.WriteMessage(websocket.PingMessage, []byte{}); err != nil {
        log.Println(err)
        ws.Close()
    }
}

// Start the server on localhost:8000
func main() {
    http.HandleFunc("/ws", func(w http.ResponseWriter, r *http.Request) {
        ws, err := upgrader.Upgrade(w, r, nil)
        if err != nil {
            log.Println(err)
            return
        }

        // Handle the connection using a goroutine
        go handleConnection(ws)
    })

    http.ListenAndServe(":8000", nil)
}
  1. Pemutus sambungan

Akhir sekali, kita perlu mempertimbangkan pemutusan sambungan WebSocket. Apabila melaksanakan pelayan WebSocket, kita perlu mengambil kira kitaran hayat sambungan supaya sanitasi yang betul berlaku apabila data dipindahkan antara klien dan pelayan.

Berikut ialah contoh mudah yang menunjukkan cara menggunakan pernyataan goroutine dan pilih untuk mencapai pemutusan sambungan WebSocket:

package main

import (
    "github.com/gorilla/websocket"
)

var clients = make(map[*websocket.Conn]bool)
var broadcast = make(chan Message)
var unregister = make(chan *websocket.Conn)

func main() {
    http.HandleFunc("/ws", handleConnections)

    go handleMessages()

    http.ListenAndServe(":8000", nil)
}

type Message struct {
    Type int    `json:"type"`
    Body string `json:"body"`
}

func handleConnections(w http.ResponseWriter, r *http.Request) {
    upgrader := websocket.Upgrader{}
    ws, err := upgrader.Upgrade(w, r, nil)
    if err != nil {
        log.Println(err)
        return
    }
    defer ws.Close()

    clients[ws] = true

    for {
        var msg Message
        err := ws.ReadJSON(&msg)
        if err != nil {
            if websocket.IsCloseError(err, websocket.CloseGoingAway) {
                unregister <- ws
                break
            }
            log.Printf("error: %v", err)
            continue
        }
        broadcast <- msg
    }
}

func handleMessages() {
    for {
        select {
        case msg := <-broadcast:
            for client := range clients {
                err := client.WriteJSON(msg)
                if err != nil {
                    log.Printf("error: %v", err)
                    unregister <- client
                    break
                }
            }
        case client := <-unregister:
            delete(clients, client)
        }
    }
}

Ringkasan

Dalam artikel ini, kami memperkenalkan beberapa petua tentang pengaturcaraan Golang WebSocket. Kami mempelajari cara menggunakan goroutin dan saluran untuk mengendalikan sambungan serentak, cara menghantar paket degupan jantung untuk memastikan sambungan kekal sah dan cara melakukan operasi pembersihan yang sesuai apabila sambungan diputuskan. Kami berharap petua ini membantu anda dalam menulis pelayan WebSocket yang cekap.

Atas ialah kandungan terperinci golang Petua pengaturcaraan WebSocket: mengendalikan sambungan serentak. 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

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

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.

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!

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 PHP
1517
276
Strategi untuk mengintegrasikan perkhidmatan golang dengan infrastruktur python sedia ada Strategi untuk mengintegrasikan perkhidmatan golang dengan infrastruktur python sedia ada Jul 02, 2025 pm 04:39 PM

TointegrategoLanggerviceswithexistingpythoninfrastructure, userestapisorgrpcforinter-serviceCommunication, membolehkangoandpythonappstointeractseamlythroughtroughtroughtroughtroughtroughtrotocols.1.usereSestaS (ViaframeworksLikeGineGinpyton)

Memahami Perbezaan Prestasi antara Golang dan Python untuk API Web Memahami Perbezaan Prestasi antara Golang dan Python untuk API Web Jul 03, 2025 am 02:40 AM

GolangoffersSuperiorperformance, NativeConCurrencyViagoroutine, andefficientResourceusage, makeitidealforhigh-traffic, rendah latencyapis;

Bagaimana untuk membuat Dockerfile untuk aplikasi Golang asas? Bagaimana untuk membuat Dockerfile untuk aplikasi Golang asas? Jun 25, 2025 pm 04:48 PM

Untuk menulis Dockerfile untuk aplikasi Golang asas, anda perlu memahami tiga langkah teras: memilih imej yang sesuai, membina aplikasi, dan membungkus persekitaran operasi. 1. Gunakan pembinaan pelbagai peringkat untuk mengurangkan jumlah. Pada peringkat pertama, gunakan Golang: 1.21 imej untuk menyusun dan menjana fail yang boleh dilaksanakan. Pada peringkat kedua, hanya salin hasil kompilasi dan jalankannya. 2. Tetapkan CGO_Enabled = 0 Untuk mengelakkan kebergantungan perpustakaan C, menyatukan direktori kerja seperti /APP dan gunakan arahan salinan untuk menyalin kod. Adalah disyorkan untuk bekerjasama dengan .dockerignore untuk mengecualikan fail yang tidak relevan; 3. Tentukan versi GO tertentu seperti Golang: 1.21 dan bukannya terkini untuk memastikan versi yang dikawal dan meningkatkan konsistensi dan keserasian CI/CD.

Perbandingan Jejak Memori: Menjalankan beban kerja perkhidmatan web yang sama di Golang dan Python Perbandingan Jejak Memori: Menjalankan beban kerja perkhidmatan web yang sama di Golang dan Python Jul 03, 2025 am 02:32 AM

Gousessessmificlylantlylessmemorythanpythhenrunningwebservicesduetolanguagedesignandconcurrencymodeldifferences.1.go'sgoroutinesarelightweightwithminimalstackoverhead, membenarkanficienthandlingofthoushoushousle

Keadaan Perpustakaan Pembelajaran Mesin: Tawaran Golang vs Ekosistem Python yang luas Keadaan Perpustakaan Pembelajaran Mesin: Tawaran Golang vs Ekosistem Python yang luas Jul 03, 2025 am 02:00 AM

Pythonisthedominantlanguageagefinhinelearningduetoitsmatureecosystem, wheengoofferslightweighttoolssuitedforspecificusecases.pythonexcelswithlibrariesliketensorflow, pytorch, scikitshipships, danpandalshoorshoorshoade.pherdoShardsoStoShoStoStoSoShoStoSoShoStoShoStoShoStoSoShoSt

Memahami Perbezaan Pengurusan Memori: Golang's GC vs Python's Rujukan Mengira Memahami Perbezaan Pengurusan Memori: Golang's GC vs Python's Rujukan Mengira Jul 03, 2025 am 02:31 AM

Perbezaan teras antara GO dan Python dalam pengurusan memori adalah mekanisme pengumpulan sampah yang berbeza. GO menggunakan pelepasan tanda serentak (Markandsweep) GC, yang secara automatik menjalankan dan melaksanakan secara serentak dengan logik program, dengan berkesan menangani rujukan bulat. Ia sesuai untuk senario konvensional yang tinggi, tetapi tidak dapat mengawal masa kitar semula dengan tepat; manakala Python terutamanya bergantung kepada pengiraan rujukan, dan rujukan objek segera dikeluarkan apabila sifar. Kelebihannya ialah mereka adalah kitar semula segera dan pelaksanaan yang mudah, tetapi terdapat masalah rujukan pekeliling, jadi mereka perlu menggunakan modul GC untuk membantu pembersihan. Dalam pembangunan sebenar, GO lebih sesuai untuk program pelayan berprestasi tinggi, manakala Python sesuai untuk kelas skrip atau aplikasi dengan keperluan prestasi yang rendah.

Bagaimana untuk menunggu semua goroutine selesai di Golang menggunakan Waitgroup? Bagaimana untuk menunggu semua goroutine selesai di Golang menggunakan Waitgroup? Jun 28, 2025 am 01:48 AM

Kaedah teras menggunakan Sync.WaitGroup dalam pergi untuk menunggu semua goroutine untuk menyelesaikan tugas adalah: 1. Inisialisasi Waitgroup dan Call Add (1) sebelum memulakan setiap goroutine; 2. Gunakan deferwg.done () di dalam setiap goroutine untuk memastikan kiraan dikurangkan oleh satu selepas tugas selesai; 3. Coroutine utama memanggil wg.wait () untuk menyekat dan menunggu semua tugas selesai. Mekanisme ini sesuai untuk senario di mana tugas -tugas dilaksanakan secara serentak dan hasilnya diringkaskan, seperti pemprosesan batch atau permintaan serentak. Nota Apabila menggunakan: Tambah hendaklah dipanggil di coroutine utama, yang dilakukan mesti digunakan dengan menangguhkan, Waitgroup harus diluluskan dalam penunjuk untuk mengelakkan penyalinan nilai atau kuali

Bangunan Alat baris arahan: Kelebihan Golang Over Python untuk Pengedaran Bangunan Alat baris arahan: Kelebihan Golang Over Python untuk Pengedaran Jul 02, 2025 pm 04:24 PM

Apabila membina alat baris arahan untuk diedarkan, Golang lebih sesuai daripada Python. Sebab -sebabnya termasuk: 1. Pengedaran mudah, dan satu fail binari statik tunggal dihasilkan selepas penyusun GO, tanpa ketergantungan tambahan; 2. Kelajuan permulaan yang cepat, penggunaan sumber yang rendah, GO adalah bahasa yang disusun, kecekapan pelaksanaan yang tinggi dan penggunaan memori kecil; 3. Menyokong kompilasi silang platform, tiada alat pembungkusan tambahan diperlukan, dan fail yang boleh dilaksanakan dari platform yang berbeza boleh dihasilkan dengan arahan mudah. Sebaliknya, Python memerlukan pemasangan perpustakaan runtime dan pergantungan, yang lambat bermula, proses pembungkusan yang kompleks, dan terdedah kepada keserasian dan positif palsu, jadi ia tidak sebaik dari segi pengalaman penggunaan dan kos penyelenggaraan.

See all articles