Menulis pelayan TCP berprestasi tinggi di Java
Jul 30, 2025 am 01:42 AMUntuk membina pelayan Java TCP berprestasi tinggi, anda harus menggunakan kerangka Netty dan bukannya NIO asal; 1. Gunakan kumpulan gelung acara NETTY untuk menguruskan sambungan dan I/O; 2. Gunakan serialisasi yang cekap seperti protobuf untuk mengelakkan serialisasi asli Java; 3. Dayakan kawalan tekanan belakang untuk mengelakkan limpahan penampan melalui saluran.Swrtable (); 4. Menggunakan semula objek dan pooledByTebuFallocator untuk mengurangkan GC; 5. Konfigurasikan pilihan TCP seperti TCP_Nodelay dan saiz penampan yang sesuai untuk mengurangkan latensi; Menggabungkan ujian dan pemantauan tekanan untuk memastikan latency rendah dan throughput yang tinggi, dan akhirnya mencapai pemprosesan yang cekap puluhan ribu sambungan serentak.
Menulis pelayan TCP berprestasi tinggi di Java bukan sekadar menerima sambungan-ia secara efisien mengendalikan beribu-ribu pelanggan serentak dengan latency dan penggunaan sumber yang minimum. Walaupun Java menyediakan abstraksi pepejal untuk rangkaian, membina sesuatu yang berskala memerlukan pemahaman alat dan corak yang betul. Inilah cara melakukannya dengan betul.

Gunakan NIO dengan I/O yang tidak menyekat (java.nio)
Pelayan Java tradisional menggunakan java.net.ServerSocket
dan model satu thread-per-klien tidak skala melebihi beberapa ratus sambungan kerana overhead benang. Penyelesaiannya? Java Nio (tidak menyekat I/O).
NIO membolehkan benang tunggal untuk menguruskan pelbagai sambungan melalui multiplexing menggunakan soket Selector
, Channel
, dan bukan blok.

Komponen utama:
-
ServerSocketChannel
- mendengar sambungan TCP yang masuk. -
SocketChannel
- Mengendalikan pemindahan data untuk setiap pelanggan. -
Selector
- memantau pelbagai saluran untuk acara (menerima, membaca, menulis) tanpa menyekat. -
SelectionKey
- Mengesan keadaan saluran yang didaftarkan dengan pemilih.
Model ini membolehkan corak reaktor , di mana sebilangan kecil benang mengendalikan banyak sambungan.

Pemilih pemilih = selector.Open (); Serverocketchannel serverChannel = serversocketchannel.open (); serverChannel.Bind (baru inetocketAddress (8080)); serverChannel.ConfigureBlocking (false); serverChannel.Register (pemilih, pilihanSey.OP_ACCEPT);
Sekarang satu thread boleh gelung ke atas selector.select()
, mengendalikan hanya acara siap.
Leverage Netty untuk Sistem Pengeluaran
Walaupun Raw Nio berkuasa, ia adalah tahap rendah dan rawan ralat. Bagi pelayan prestasi tinggi dunia, Netty adalah standard de facto.
Netty abstrak kerumitan NIO dan menyediakan:
- Kumpulan gelung acara (benang bos dan pekerja)
- Pengurusan penampan byte yang cekap
- Codec terbina dalam untuk protokol biasa
- Sokongan tekanan belakang
- Pengumpulan memori dan teknik sifar
Contoh pelayan Netty yang mudah:
EventLoopGroup BossGroup = nioEventLoopGroup baru (1); EventLoopGroup WorkerGroup = new NioEventLoOpGroup (); Cuba { ServerBootstrap b = new ServeBootStrap (); B.Group (Bossgroup, Kerja Kerja) .CHANNEL (nioserversocketchannel.class) .ChildHandler (New ChannelInitializer <SocketchAnnel> () { @Override dilindungi void initchannel (socketchannel ch) { ch.pipeline (). AddLast (new YourRequestHandler ()); } }); Channelfuture f = b.bind (8080) .sync (); f.Channel (). CloseFuture (). Sync (); } akhirnya { bossgroup.shutdowngraculy (); workerGroup.shutdowngraceLely (); }
Netty secara automatik mengendalikan threading, i/o multiplexing, dan peristiwa kitaran hayat - semua dioptimumkan untuk tekanan dan tekanan GC yang rendah.
Optimalkan untuk prestasi: Petua Utama
Walaupun dengan rangka kerja yang betul, prestasi bergantung pada cara anda menggunakannya.
1. Tune thread saiz kolam
- Gunakan satu kumpulan bos (benang penerima) - biasanya 1 atau 2.
- Thread pekerja sepadan dengan teras CPU yang ada (atau sedikit lebih jika melakukan I/O menunggu).
- Elakkan membuat benang baru setiap tugas; Gunakan semula gelung acara Netty.
2. Gunakan serialisasi yang cekap
- Elakkan format berat seperti Serialization Java.
- Lebih suka protokol binari: Protobuf , Kryo , atau MessagePack .
- Penggunaan semula buffer apabila mungkin (
ByteBuf
dalam netty).
3. Mengendalikan tekanan belakang
- Jangan biarkan pengeluar cepat mengatasi pengguna yang perlahan.
- Gunakan Kawalan Aliran: Jeda membaca dari soket apabila memproses barisan penuh.
-
Channel.isWritable()
membantu mengesan apabila penampan keluarnya dibebankan.
4. Minimize sampah
- Gunakan semula objek (misalnya, penampan decode, bekas mesej).
- Gunakan
PooledByteBufAllocator
Netty untuk mengurangkan GC. - Elakkan pembalakan setiap mesej dalam pengeluaran.
5. Tetapkan pilihan TCP yang betul
.ChildOption (channeloption.so_keepalive, benar) .ChildOption (channeloption.tcp_nodelay, true) // matikan algoritma Nagle untuk latensi rendah .ChildOption (channeloption.so_rcvbuf, 64 * 1024) .ChildOption (channeloption.so_sndbuf, 64 * 1024)
TCP_NODELAY
adalah kejam untuk aplikasi masa nyata-ia menghalang kelewatan paket kecil.
Memantau dan ujian tekanan
Pelayan berprestasi tinggi mesti disahkan:
- Gunakan alat seperti WRK , Jmeter , atau Gatling untuk ujian beban.
- Memantau:
- Peratusan latensi (p99, p999)
- Throughput (permintaan/saat)
- GC berhenti
- Perdebatan Thread
- Profil dengan Async-Profiler atau JFR (Java Flight Recorder) .
Malah hambatan kecil (seperti blok yang disegerakkan atau pembalakan) boleh prestasi tangki di bawah beban.
Pada asasnya, Raw Nio memberi anda kawalan, tetapi Netty memberi anda kelajuan, kestabilan, dan skalabilitas keluar dari kotak. Menggabungkannya dengan penalaan dan pemantauan pintar, dan anda mempunyai pelayan TCP yang boleh mengendalikan puluhan ribu sambungan dengan cekap.
Atas ialah kandungan terperinci Menulis pelayan TCP berprestasi tinggi di Java. 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)

Topik panas

Maven adalah alat standard untuk pengurusan dan pembinaan projek Java. Jawapannya terletak pada hakikat bahawa ia menggunakan pom.xml untuk menyeragamkan struktur projek, pengurusan pergantungan, automasi kitaran hayat pembinaan dan sambungan pemalam; 1. Gunakan pom.xml untuk menentukan kumpulan, artifactid, versi dan kebergantungan; 2. Perintah teras utama seperti mvnclean, penyusun, ujian, pakej, memasang dan menggunakan; 3. Gunakan DependencyManagement dan Pengecualian untuk Menguruskan Versi Ketergantungan dan Konflik; 4. Mengatur aplikasi besar melalui struktur projek multi-modul dan diuruskan secara seragam oleh POM induk; 5.

SetupaMaven/gradleprojectwithjax-rsdependencyiSejersey; 2.createarescresourceUsingAnnotationssuchas@pathand@get; 3.configuretheapplicationviaapplicationsubclassorweb.xml;

@Property Decorator digunakan untuk menukar kaedah ke dalam sifat untuk melaksanakan bacaan, penetapan dan kawalan penghapusan sifat. 1. Penggunaan Asas: Tentukan atribut baca sahaja melalui @property, seperti kawasan yang dikira berdasarkan radius dan diakses secara langsung; 2. Penggunaan Lanjutan: gunakan @name.setter dan @name.deleter untuk melaksanakan pengesahan tugasan atribut dan operasi penghapusan; 3. Aplikasi Praktikal: Melaksanakan pengesahan data dalam setter, seperti BankAccount untuk memastikan bahawa baki tidak negatif; 4. Penamaan Spesifikasi: Pembolehubah dalaman adalah prefixed, nama kaedah harta selaras dengan atribut, dan kawalan akses bersatu digunakan untuk meningkatkan keselamatan kod dan penyelenggaraan.

Pertama, gunakan JavaScript untuk mendapatkan pilihan sistem pengguna dan tetapan tema yang disimpan di dalam negara, dan memulakan tema halaman; 1. Struktur HTML mengandungi butang untuk mencetuskan Topik Switching; 2. CSS menggunakan: Root untuk menentukan pembolehubah tema yang cerah, kelas mod-mode mentakrifkan pembolehubah tema gelap, dan menggunakan pembolehubah ini melalui VAR (); 3. JavaScript mengesan lebih suka skema-skema dan membaca LocalStorage untuk menentukan tema awal; 4. Tukar kelas mod gelap pada elemen HTML apabila mengklik butang, dan menjimatkan keadaan semasa ke LocalStorage; 5. Semua perubahan warna disertakan dengan animasi peralihan 0.3 saat untuk meningkatkan pengguna

Memahami komponen teras blockchain, termasuk blok, hash, struktur rantai, mekanisme konsensus dan kebolehubahan; 2. Buat kelas blok yang mengandungi data, cap waktu, hash dan nonce sebelumnya, dan melaksanakan pengiraan hash SHA-256 dan bukti perlombongan kerja; 3. Membina kelas blockchain untuk menguruskan senarai blok, memulakan blok Kejadian, menambah blok baru dan sahkan integriti rantai; 4. Tulis blockchain ujian utama, tambah blok data transaksi pada giliran dan status rantai output; 5. Fungsi peningkatan pilihan termasuk sokongan transaksi, rangkaian P2P, tandatangan digital, Restapi dan ketekunan data; 6. Anda boleh menggunakan perpustakaan blok Java seperti Hyperledgerfabric, Web3J atau Corda untuk pembukaan peringkat pengeluaran

Untuk menjana nilai hash menggunakan Java, ia boleh dilaksanakan melalui kelas MessageDigest. 1. Dapatkan contoh algoritma yang ditentukan, seperti MD5 atau SHA-256; 2. Panggil kaedah .Update () untuk lulus dalam data untuk disulitkan; 3. Panggil kaedah .digest () untuk mendapatkan pelbagai hash byte; 4. Tukar array byte ke dalam rentetan heksadesimal untuk membaca; Untuk input seperti fail besar, baca dalam ketulan dan panggilan .Update () beberapa kali; Adalah disyorkan untuk menggunakan SHA-256 dan bukannya MD5 atau SHA-1 untuk memastikan keselamatan.

Ya, menu drop-down CSS biasa boleh dilaksanakan melalui HTML dan CSS tulen tanpa JavaScript. 1. Gunakan UL dan Li bersarang untuk membina struktur menu; 2. Gunakan: Hover pseudo-Class untuk mengawal paparan dan menyembunyikan kandungan tarik-turun; 3. Tetapkan Kedudukan: Relatif untuk Ibu Bapa Li, dan submenu diletakkan menggunakan kedudukan: mutlak; 4. Submenu mungkir untuk memaparkan: Tiada, yang menjadi paparan: blok apabila melayang; 5. Multi-level pull-down boleh dicapai melalui bersarang, digabungkan dengan peralihan, dan menambah animasi pudar, dan disesuaikan dengan terminal mudah alih dengan pertanyaan media. Penyelesaian keseluruhannya mudah dan tidak memerlukan sokongan JavaScript, yang sesuai untuk besar

Gunakan DateTime.StrpTime () untuk menukar rentetan tarikh ke dalam objek DateTime. 1. Penggunaan Asas: Parse "2023-10-05" sebagai objek DateTime melalui "%y-%m-%d"; 2. Menyokong pelbagai format seperti "%m/%d/%y" untuk menghuraikan tarikh Amerika, "%d/%m/%y" untuk menghuraikan tarikh British, "%b%d,%y%i:%m%p" untuk menghuraikan masa dengan am/pm; 3. Gunakan dateUtil.parser.parse () untuk secara automatik menyimpulkan format yang tidak diketahui; 4. Gunakan .D
