


Cara melaksanakan rangka kerja pengaturcaraan rangkaian konkurensi tinggi dalam bahasa Go
Dalam merealisasikan pengaturcaraan rangkaian konkurensi tinggi, rangka kerja Workerman bahasa PHP sentiasa terkenal dengan prestasi cemerlang dan kesederhanaan serta kemudahan penggunaan. Walau bagaimanapun, berbanding dengan bahasa PHP, Golang lebih sesuai untuk pembangunan sistem berkonkurensi tinggi dan teragih, jadi melaksanakan rangka kerja pekerja versi Golang telah menjadi usaha ramai pembangun. Dalam artikel ini, kami akan memperkenalkan cara menggunakan bahasa Golang untuk melaksanakan rangka kerja pengaturcaraan rangkaian serentak tinggi, serupa dengan Workerman.
1. Pengetahuan prasyarat
Sebelum kita mula, kita perlu menguasai beberapa pengetahuan asas:
1. Asas bahasa Golang: pembolehubah, fungsi, struktur, antara muka, dll. konsep.
2. Asas pengaturcaraan rangkaian: pengetahuan asas TCP/UDP, HTTP dan protokol lain.
3.Goroutine: Coroutine bahasa Golang boleh meningkatkan kecekapan pengaturcaraan serentak.
4.Saluran: Mekanisme komunikasi yang disediakan oleh bahasa Golang, yang boleh digunakan untuk penghantaran data dan penyegerakan antara coroutine yang berbeza.
5.Pilih: Mekanisme pemultipleksan yang disediakan oleh bahasa Golang, yang boleh memantau status berbilang Saluran dan meningkatkan kecekapan program.
2. Seni bina Rangka Kerja
Menurut pelaksanaan rangka kerja pekerja, kami boleh membahagikannya kepada tiga bahagian:
1.
2. Proses perniagaan digunakan untuk mengendalikan permintaan pelanggan.
3. Pantau status sambungan pelanggan dan kitar semula.
Dalam bahasa Golang, kita boleh menggunakan goroutine untuk melaksanakan ketiga-tiga bahagian di atas masing-masing.
1. Terima sambungan dan jana klien
Kita boleh menggunakan pakej "net" yang disertakan dengan bahasa Golang untuk mencipta pelayan TCP, dan pada masa yang sama membuka goroutine untuk memantau status sambungan pelanggan.
import ( "fmt" "net" ) func main() { listener, err := net.Listen("tcp", "127.0.0.1:8080") if err != nil { fmt.Println("failed to listen:", err) return } go func() { for { conn, err := listener.Accept() if err != nil { fmt.Println("failed to accept:", err) continue } // 生成客户端 } }() // 等待进程退出 select {} }
Selepas menerima sambungan pelanggan, kami perlu merangkum objek Pelanggan untuk mengendalikan semua permintaan dan respons untuk sambungan.
type Client struct { Conn net.Conn RespCh chan []byte } func NewClient(conn net.Conn) *Client { return &Client { Conn: conn, RespCh: make(chan []byte, 10), } }
2. Proses perniagaan yang digunakan untuk memproses permintaan pelanggan
Permintaan dan respons pelanggan dihantar terus melalui Saluran. Apabila sambungan baharu diterima, kami perlu memasukkannya ke dalam objek Klien dan membuka goroutine untuk mengendalikan sambungan. Goroutine ini akan mendengar semua permintaan yang dihantar oleh pelanggan melalui Saluran dan bertindak balas dengan sewajarnya.
Kami merangkum proses perniagaan ke dalam antara muka Pengendali.
type Handler interface { OnConnect(*Client) error OnMessage(*Client, []byte) error OnClose(*Client) error }
Permintaan dan respons pelanggan dihantar melalui atribut RespCh objek Pelanggan. Oleh itu, dalam antara muka Pengendali, kita perlu menentukan sifat RespCh untuk menerima respons daripada pelanggan.
type Handler interface { OnConnect(*Client) error OnMessage(*Client, []byte) error OnClose(*Client) error RespCh() chan []byte }
Kami boleh mencipta EchoHandler untuk melaksanakan antara muka Pengendali.
type EchoHandler struct { clients []*Client respChan chan []byte } func NewEchoHandler() *EchoHandler { return &EchoHandler{ clients: make([]*Client, 0), respChan: make(chan []byte, 10), } } func (h *EchoHandler) OnConnect(c *Client) error { h.clients = append(h.clients, c) return nil } func (h *EchoHandler) OnMessage(c *Client, data []byte) error { // 将客户端发送的数据广播给所有其他客户端,并将其存入respChan中 for _, client := range h.clients { if client == c { continue } client.RespCh <p>Selepas objek Pelanggan setiap pelanggan yang disambungkan disimpan dalam tatasusunan pelanggan, kami boleh menerima data yang dihantar oleh setiap pelanggan melalui atribut RespCh untuk menyiarkan maklumat yang dihantar oleh pelanggan lain . </p><p>3. Pantau status sambungan pelanggan dan kitar semula </p><p>Untuk versi lama rangka kerja Workerman, Workerman akan mengitar semula sambungan terbiar dalam tempoh masa tertentu. Versi baharu Workerman melaksanakan fungsi ini melalui TCP keepalive. </p><p>Apabila melaksanakan versi Golang workerman, kami juga boleh menyelesaikan masalah sambungan terbiar melalui TCP keepalive. Kita boleh memantau status soketnya dalam goroutine setiap pelanggan Jika pelanggan tidak menghantar data selepas 10 saat masa melahu, ia akan dianggap sebagai sambungan yang tidak sah dan soketnya akan ditutup. </p><pre class="brush:php;toolbar:false">func (c *Client) Process() { defer func() { c.Conn.Close() c.handler.OnClose(c) }() // 设置 socket keepalive tcpConn, ok := c.Conn.(*net.TCPConn) if ok { tcpConn.SetKeepAlive(true) tcpConn.SetKeepAlivePeriod(10 * time.Second) } // 进入读协程,接收客户端发送的所有数据 go func() { for { buf := make([]byte, 1024) n, err := c.Conn.Read(buf) if err != nil { if err != io.EOF { fmt.Println("failed to read:", err) } break } // 将客户端发送的消息交给Handler处理 c.handler.OnMessage(c, buf[:n]) } }() // 进入写协程,将respChan中的所有响应发送给当前客户端 go func() { for resp := range c.handler.RespCh() { _, err := c.Conn.Write(resp) if err != nil { fmt.Println("failed to write:", err) break } } }() // OnConnect err := c.handler.OnConnect(c) if err != nil { fmt.Println("failed to on connect:", err) return } // 在Worker进程退出时进行清理 select {} }
3. Laksanakan proses Pekerja
Selepas menyelesaikan tiga langkah di atas, kami perlu mencipta proses Pekerja untuk menguruskan semua sambungan pelanggan. Satu atau lebih Pengendali perlu dimuatkan dalam proses Pekerja untuk mengendalikan semua permintaan data yang dihantar oleh pelanggan.
type Worker struct { listener net.Listener handlers map[string]Handler } func NewWorker(addr string) (*Worker, error) { listener, err := net.Listen("tcp", addr) if err != nil { fmt.Println("failed to listen:", err) return nil, err } return &Worker{ listener: listener, handlers: make(map[string]Handler), }, nil } func (w *Worker) Register(name string, handler Handler) { w.handlers[name] = handler } func (w *Worker) Start() { go func() { for { conn, err := w.listener.Accept() if err != nil { fmt.Println("failed to accept:", err) continue } // 封装连接客户端为Client对象,用于后续的处理 client := NewClient(conn) client.handler = w.handlers["Echo"] // 开启客户端goroutine来处理该连接 go client.Process() } }() // 等待进程退出 select {} }
Dalam proses Worker, kita perlu menentukan atribut pengendali untuk menyimpan contoh Pengendali yang berbeza, dan memantau sambungan klien dalam fungsi Start() dan membuka goroutine baharu untuk mengendalikan permintaan pelanggan .
4. Ujian
Kami boleh menggunakan kod berikut untuk mencipta proses Pekerja dan mendaftarkan EchoHandler di dalamnya untuk mengendalikan semua permintaan pelanggan.
func main() { server, _ := NewWorker("127.0.0.1:8080") handler := NewEchoHandler() server.Register("Echo", handler) server.Start() }
Kami boleh menggunakan alat telnet untuk mensimulasikan berbilang pelanggan menghantar mesej ke pelayan dan melihat penerimaan mereka.
Kami menggunakan arahan berikut untuk menyambung ke pelayan:
telnet 127.0.0.1 8080
Kami boleh memasukkan teks berikut dalam telnet:
Hello workerman!
Kami boleh membuka berbilang tetingkap telnet pada masa yang sama, untuk mensimulasikan berbilang permintaan selari pelanggan.
Pada pelayan, kita dapat melihat output:
$ go run worker.go 服务器已启动... failed to read: read tcp 127.0.0.1:8080->127.0.0.1:56182: use of closed network connection
Ini kerana apabila kita menutup sambungan klien, ia membatalkan operasi mendengarnya, mengakibatkan ralat baca.
Selepas input telnet selesai, kita dapat melihat bahawa setiap tetingkap telnet akan menerima teks yang dikembalikan oleh pelayan.
5. Ringkasan
Dalam artikel ini, kami memperkenalkan cara menggunakan bahasa Golang untuk melaksanakan rangka kerja pengaturcaraan rangkaian konkurensi tinggi, serupa dengan workerman dalam bahasa PHP. Semasa proses pelaksanaan, kami menggunakan coroutine, mekanisme komunikasi dan mekanisme pemultipleksan dalam bahasa Golang, dan berjaya melaksanakan rangka kerja pengaturcaraan rangkaian konkurensi tinggi yang serupa dengan Workerman dengan merangkum objek Pelanggan dan antara muka Pengendali.
Malah, dalam pengaturcaraan harian, kami mengesyorkan terus menggunakan pakej net/http yang disediakan oleh bahasa Golang untuk melaksanakan pengaturcaraan rangkaian konkurensi tinggi, yang lebih ringkas dan mempunyai prestasi yang lebih baik daripada rangka kerja pekerja. Kami hanya perlu membuka pelayan http dan menggunakan goroutine untuk memproses setiap permintaan secara serentak untuk melaksanakan pengaturcaraan rangkaian konkurensi tinggi dengan mudah.
Atas ialah kandungan terperinci Cara melaksanakan rangka kerja pengaturcaraan rangkaian konkurensi tinggi dalam bahasa Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Golang dan C masing-masing mempunyai kelebihan sendiri dalam pertandingan prestasi: 1) Golang sesuai untuk kesesuaian tinggi dan perkembangan pesat, dan 2) C menyediakan prestasi yang lebih tinggi dan kawalan halus. Pemilihan harus berdasarkan keperluan projek dan tumpukan teknologi pasukan.

Golang sesuai untuk pembangunan pesat dan pengaturcaraan serentak, manakala C lebih sesuai untuk projek yang memerlukan prestasi yang melampau dan kawalan asas. 1) Model Concurrency Golang memudahkan pengaturcaraan konvensyen melalui goroutine dan saluran. 2) Pengaturcaraan templat C menyediakan kod generik dan pengoptimuman prestasi. 3) Koleksi sampah Golang adalah mudah tetapi boleh menjejaskan prestasi. Pengurusan memori C adalah rumit tetapi kawalannya baik -baik saja.

Goimpactsdevelopmentpositivielythroughspeed, efficiency, andsimplicity.1) Speed: goCompilesquicklyandrunsefficiently, idealforlargeproject.2) Kecekapan: ITSComprehensivestandardlibraryraryrarexternaldependencies, enhingdevelyficiency.

C lebih sesuai untuk senario di mana kawalan langsung sumber perkakasan dan pengoptimuman prestasi tinggi diperlukan, sementara Golang lebih sesuai untuk senario di mana pembangunan pesat dan pemprosesan konkurensi tinggi diperlukan. Kelebihan 1.C terletak pada ciri-ciri perkakasan dan keupayaan pengoptimuman yang tinggi, yang sesuai untuk keperluan berprestasi tinggi seperti pembangunan permainan. 2. Kelebihan Golang terletak pada sintaks ringkas dan sokongan konvensional semulajadi, yang sesuai untuk pembangunan perkhidmatan konvensional yang tinggi.

Golang cemerlang dalam aplikasi praktikal dan terkenal dengan kesederhanaan, kecekapan dan kesesuaiannya. 1) Pengaturcaraan serentak dilaksanakan melalui goroutine dan saluran, 2) Kod fleksibel ditulis menggunakan antara muka dan polimorfisme, 3) memudahkan pengaturcaraan rangkaian dengan pakej bersih/HTTP, 4) Membina crawler serentak yang cekap, 5) Debugging dan mengoptimumkan melalui alat dan amalan terbaik.

Ciri -ciri teras GO termasuk pengumpulan sampah, penyambungan statik dan sokongan konvensional. 1. Model keseragaman bahasa GO menyedari pengaturcaraan serentak yang cekap melalui goroutine dan saluran. 2. Antara muka dan polimorfisme dilaksanakan melalui kaedah antara muka, supaya jenis yang berbeza dapat diproses secara bersatu. 3. Penggunaan asas menunjukkan kecekapan definisi fungsi dan panggilan. 4. Dalam penggunaan lanjutan, kepingan memberikan fungsi saiz semula dinamik yang kuat. 5. Kesilapan umum seperti keadaan kaum dapat dikesan dan diselesaikan melalui perlumbaan getest. 6. Pengoptimuman prestasi menggunakan objek melalui sync.pool untuk mengurangkan tekanan pengumpulan sampah.

Pergi bahasa berfungsi dengan baik dalam membina sistem yang cekap dan berskala. Kelebihannya termasuk: 1. Prestasi Tinggi: Disusun ke dalam Kod Mesin, Kelajuan Berjalan Cepat; 2. Pengaturcaraan serentak: Memudahkan multitasking melalui goroutine dan saluran; 3. Kesederhanaan: sintaks ringkas, mengurangkan kos pembelajaran dan penyelenggaraan; 4. Cross-Platform: Menyokong kompilasi silang platform, penggunaan mudah.

Keliru mengenai penyortiran hasil pertanyaan SQL. Dalam proses pembelajaran SQL, anda sering menghadapi beberapa masalah yang mengelirukan. Baru-baru ini, penulis membaca "Asas Mick-SQL" ...


Alat AI Hot

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

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

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Dreamweaver Mac版
Alat pembangunan web visual

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

SublimeText3 versi Inggeris
Disyorkan: Versi Win, menyokong gesaan kod!

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),