cari
Rumahpembangunan bahagian belakangGolangCara 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!

Kenyataan
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
Perlumbaan Prestasi: Golang vs CPerlumbaan Prestasi: Golang vs CApr 16, 2025 am 12:07 AM

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 vs C: Contoh kod dan analisis prestasiGolang vs C: Contoh kod dan analisis prestasiApr 15, 2025 am 12:03 AM

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.

Impak Golang: Kelajuan, Kecekapan, dan KesederhanaanImpak Golang: Kelajuan, Kecekapan, dan KesederhanaanApr 14, 2025 am 12:11 AM

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

C dan Golang: Apabila prestasi sangat pentingC dan Golang: Apabila prestasi sangat pentingApr 13, 2025 am 12:11 AM

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 dalam Tindakan: Contoh dan aplikasi dunia nyataGolang dalam Tindakan: Contoh dan aplikasi dunia nyataApr 12, 2025 am 12:11 AM

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.

Golang: bahasa pengaturcaraan Go dijelaskanGolang: bahasa pengaturcaraan Go dijelaskanApr 10, 2025 am 11:18 AM

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.

Tujuan Golang: Membina sistem yang cekap dan berskalaTujuan Golang: Membina sistem yang cekap dan berskalaApr 09, 2025 pm 05:17 PM

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.

Kenapa keputusan pesanan oleh pernyataan dalam penyortiran SQL kadang -kadang kelihatan rawak?Kenapa keputusan pesanan oleh pernyataan dalam penyortiran SQL kadang -kadang kelihatan rawak?Apr 02, 2025 pm 05:24 PM

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" ...

See all articles

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)
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

DVWA

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

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),