


golang Petua pengaturcaraan WebSocket: mengendalikan sambungan serentak
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:
- 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) } } } }
- 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) }
- 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!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

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

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

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.

Gousessessmificlylantlylessmemorythanpythhenrunningwebservicesduetolanguagedesignandconcurrencymodeldifferences.1.go'sgoroutinesarelightweightwithminimalstackoverhead, membenarkanficienthandlingofthoushoushousle

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

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.

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

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.
