écriture d'un serveur TCP haute performance en Java
Jul 30, 2025 am 01:42 AMPour construire un serveur Java TCP haute performance, vous devez utiliser le netty framework au lieu du NIO d'origine; 1. Utilisez le groupe de boucle d'événements de Netty pour gérer les connexions et les E / S; 2. Utiliser une sérialisation efficace telle que le protobuf pour éviter la sérialisation native de Java; 3. Activer le contr?le de la contre-pression pour empêcher le débordement de tampon via channel.iswitable (); 4. Réutiliser les objets et le bytebufallocator avalé pour réduire GC; 5. Configurer des options TCP telles que TCP_NODELAY et la taille du tampon appropriée pour réduire la latence; Combinez les tests de contrainte et la surveillance pour assurer une faible latence et un débit élevé, et finalement obtenir un traitement efficace de dizaines de milliers de connexions simultanées.
L'écriture d'un serveur TCP haute performance dans Java ne concerne pas seulement les connexions - il s'agit de gérer efficacement des milliers de clients simultanés avec une latence et une utilisation des ressources minimes. Alors que Java fournit des abstractions solides pour le réseautage, la construction de quelque chose d'évolutivité nécessite de comprendre les bons outils et modèles. Voici comment faire les choses correctement.

Utilisez Nio avec des E / S non bloquantes (Java.Nio)
Les serveurs Java traditionnels utilisant java.net.ServerSocket
et les modèles à un thread par client n'évoluent pas au-delà de quelques centaines de connexions en raison de la surcharge du thread. La solution? Java Nio (E / S non bloquante).
Nio permet à un seul thread de gérer plusieurs connexions via le multiplexage à l'aide Selector
, Channel
et de sockets non bloquant.

Composants clés:
-
ServerSocketChannel
- écoute les connexions TCP entrantes. -
SocketChannel
- gère le transfert de données pour chaque client. -
Selector
- surveille plusieurs canaux pour les événements (accepter, lire, écrire) sans blocage. -
SelectionKey
- suit l'état d'un canal enregistré avec un sélecteur.
Ce modèle permet le motif du réacteur , où un petit nombre de threads gèrent de nombreuses connexions.

Sélecteur sélecteur = sélecteur.open (); Serversocketchannel ServerChannel = serversOCHANNELL.Open (); serverChannel.bind (new InetsocketAddress (8080)); serverChannel.ConfigureBlocking (false); ServerChannel.Register (Selector, SelectionKey.op_Accept);
Maintenant, un seul thread peut boucler sur selector.select()
, ne gérant que les événements prêts.
Tirez parti de Netty pour les systèmes de production
Bien que Raw Nio soit puissant, il est de bas niveau et sujet aux erreurs. Pour les serveurs à haute performance du monde réel, Netty est la norme de facto.
Netty résume la complexité du NIO et fournit:
- Groupes de boucle d'événements (threads de boss et de travailleurs)
- Gestion efficace du tampon d'octets
- Codecs intégrés pour les protocoles communs
- Assistance à la contre-pression
- Envoi de mémoire et techniques de copie zéro
Exemple d'un serveur de netty simple:
EventLoopGroup BossGroup = new NioEventloopGroup (1); EventLoopGroup WorkerGroup = new NioEventLoopGroup (); essayer { Serverbootstrap b = new serverbootstrap (); B.Group (BossGroup, WorkerGroup) .Channel (Nioserversocketchannel.class) .ChildHandler (New ChannelInitializer <Socketchannel> () { @Outrepasser VOID INITCHANNEL (SOCKETCHANNEL CH) { ch.pipeline (). addLast (new YourRequestHandler ()); } }); Channelfuture f = B.Bind (8080) .Sync (); F.Channel (). CloseFuture (). Sync (); } enfin { bossgroup.shutdowngracely (); workerGroup.shutdowngracely (); }
Netty gère automatiquement le filetage, le multiplexage des E / S et les événements de cycle de vie - tous optimisés pour le débit et la faible pression GC.
Optimiser pour les performances: conseils clés
Même avec le bon cadre, les performances dépend de la fa?on dont vous l'utilisez.
1. Taille de la piscine de réglage
- Utilisez un groupe de boss (threads accepteurs) - généralement 1 ou 2.
- Les fils de travailleur doivent correspondre aux noyaux de processeur disponibles (ou légèrement plus si les E / S attendent).
- évitez de créer de nouveaux fils par tache; Réutilisez les boucles d'événement de Netty.
2. Utilisez une sérialisation efficace
- évitez les formats lourds comme la sérialisation Java.
- Préférez les protocoles binaires: Protobuf , Kryo ou MessagePack .
- Réutiliser les tampons lorsque cela est possible (
ByteBuf
en netty).
3. Gérer la contre-pression
- Ne laissez pas les producteurs rapides submerger les consommateurs lents.
- Utilisez le contr?le du débit: la lecture de pause de la prise lorsque la file d'attente de traitement est pleine.
- NetTy's
Channel.isWritable()
aide à détecter le moment où le tampon sortant est surchargé.
4. Minimiser les ordures
- Réutiliser les objets (par exemple, tampons de décodage, conteneurs de messages).
- Utilisez Netty's
PooledByteBufAllocator
pour réduire GC. - évitez de journaliser chaque message de production.
5. Définir les options TCP appropriées
.ChildOption (ChannelOption.so_keepalive, true) .ChildOption (ChannelOption.tcp_Nodelay, true) // Désactiver l'algorithme de Nagle pour une faible latence .ChildOption (ChannelOption.SO_RCVBUF, 64 * 1024) .ChildOption (ChannelOption.SO_SNDBUF, 64 * 1024)
TCP_NODELAY
est cruel pour les applications en temps réel - elle empêche les petits retards de paquets.
Test de surveillance et de stress
Un serveur haute performance doit être validé:
- Utilisez des outils comme WRK , JMeter ou Gatling pour les tests de charge.
- Moniteur:
- Pourcentages de latence (P99, P999)
- Débit (demandes / sec)
- GC pauses
- Affirmation du fil
- Profil avec Async-Profiler ou JFR (Java Flight Recorder) .
Même un petit goulot d'étranglement (comme des blocs ou une journalisation synchronisés) peut réserver les performances sous charge.
Fondamentalement, Nio brut vous donne le contr?le, mais le réseau vous donne de la vitesse, de la stabilité et de l'évolutivité hors de la bo?te. Combinez-le avec un réglage et une surveillance intelligents, et vous avez un serveur TCP qui peut gérer efficacement des dizaines de milliers de connexions.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Maven est un outil standard pour la gestion et la construction de projet Java. La réponse réside dans le fait qu'il utilise pom.xml pour normaliser la structure du projet, la gestion des dépendances, l'automatisation du cycle de vie de la construction et les extensions de plug-in; 1. Utilisez pom.xml pour définir GroupID, Arfactive, version et dépendances; 2. Commandes Master Core telles que MvnClean, compiler, tester, package, installer et déploier; 3. Utiliser la fonction de dépendance et les exclusions pour gérer les versions et les conflits de dépendance; 4. Organisez de grandes applications via la structure du projet multi-modules et sont gérées uniformément par le POM parent; 5

Setupamaven / gradleprojectwithjax-rsDependces likejersey; 2.CreateArestResourceUsingannotationsSuchas @ pathand @ get; 3.ConfigureTheApplicationViaApplicationsUbclassorweb.xml; 4.AddjacksonforjsonBindingByCludingJersey-Media-Json-Jackson; 5.DeploEp

@Property Decorator est utilisé pour convertir les méthodes en propriétés pour implémenter le contr?le de lecture, de réglage et de suppression des propriétés. 1. Utilisation de base: définissez des attributs en lecture seule via @Property, tels que la zone calculée en fonction du rayon et accédé directement; 2. Utilisation avancée: utilisez @ name.setter et @ name.deleter pour implémenter les opérations de vérification et de suppression de l'attribut d'attribut; 3. Application pratique: effectuer la vérification des données dans les setters, tels que BankAccount pour s'assurer que le solde n'est pas négatif; 4. Spécification de dénomination: les variables internes sont préfixées, les noms de méthode de propriété sont cohérents avec les attributs et le contr?le d'accès unifié est utilisé pour améliorer la sécurité et la maintenabilité du code.

Tout d'abord, utilisez JavaScript pour obtenir les préférences du système utilisateur et les paramètres de thème stockés localement et initialiser le thème de la page; 1. La structure HTML contient un bouton pour déclencher la commutation du sujet; 2. CSS utilise: Root pour définir des variables de thème brillantes, la classe de mode. Dark définit les variables de thème sombres et applique ces variables via var (); 3. JavaScript détecte préfère-Color-Scheme et lit LocalStorage pour déterminer le thème initial; 4. Communiquez la classe en mode noir sur l'élément HTML lorsque vous cliquez sur le bouton et enregistre l'état actuel vers LocalStorage; 5. Tous les changements de couleur sont accompagnés d'une animation de transition de 0,3 seconde pour améliorer l'utilisateur

Comprendre les composants centraux de la blockchain, y compris les blocs, les hachages, les structures de cha?ne, les mécanismes de consensus et l'immuabilité; 2. Créez une classe de bloc qui contient des données, des horodatages, un hachage et nonce précédent, et implémentez le calcul du hachage SHA-256 et la preuve de l'exploitation de travail; 3. Construisez une classe de blockchain pour gérer les listes de blocs, initialiser le bloc Genesis, ajouter de nouveaux blocs et vérifier l'intégrité de la cha?ne; 4. écrivez la blockchain de test principal, ajoutez des blocs de données de transaction à son tour et à l'état de la cha?ne de sortie; 5. Les fonctions d'amélioration facultatives incluent la prise en charge des transactions, le réseau P2P, la signature numérique, la restapi et la persistance des données; 6. Vous pouvez utiliser des bibliothèques Java Blockchain telles que Hyperledgerfabric, Web3J ou Corda pour l'ouverture au niveau de la production

Pour générer des valeurs de hachage à l'aide de Java, il peut être implémenté via la classe MessagediGest. 1. Obtenez une instance de l'algorithme spécifié, tel que MD5 ou SHA-256; 2. Appelez la méthode .update () à transmettre les données à chiffrer; 3. Appelez la méthode .digest () pour obtenir un tableau d'octets de hachat; 4. Convertir le tableau d'octets en une cha?ne hexadécimale pour la lecture; Pour les entrées telles que les fichiers gros, lisez dans des morceaux et appelez .Update () plusieurs fois; Il est recommandé d'utiliser SHA-256 au lieu de MD5 ou SHA-1 pour assurer la sécurité.

Oui, un menu déroulant CSS commun peut être implémenté via Pure HTML et CSS sans JavaScript. 1. Utilisez des ul imbriqués et Li pour construire une structure de menu; 2. Utilisez le: Hover Pseudo-Class pour contr?ler l'affichage et la cachette du contenu déroulant; 3. Position définie: relative pour le parent li, et le sous-menu est positionné en utilisant la position: absolue; 4. Le sous-menu défaut par défaut: Aucun, qui devient affichage: Block lorsqu'il a survolé; 5. Le tir-down à plusieurs niveaux peut être réalisé grace à la nidification, combinée à la transition, et à l'ajout d'animations fondues, et adaptées aux terminaux mobiles avec des requêtes multimédias. La solution entière est simple et ne nécessite pas de prise en charge JavaScript, qui convient au grand

Utilisez dateTime.Strptime () pour convertir les cha?nes de date en objet DateTime. 1. Utilisation de base: Parse "2023-10-05" comme objet DateTime via "% y-% m-% d"; 2. prend en charge plusieurs formats tels que "% m /% d /% y" pour analyser les dates américaines, "% d /% m /% y" pour analyser les dates britanniques, "% b% d,% y% i:% m% p" pour analyser le temps avec AM / PM; 3. Utilisez dateUtil.parser.parse () pour déduire automatiquement les formats inconnus; 4. Utiliser .d
