Maison > développement back-end > tutoriel php > Développement backend Java : Implémentation d'un serveur API hautes performances à l'aide de Netty

Développement backend Java : Implémentation d'un serveur API hautes performances à l'aide de Netty

WBOY
Libérer: 2023-06-17 11:20:02
original
1841 Les gens l'ont consulté

Ces dernières années, avec le développement rapide de la technologie Internet, les exigences en matière de hautes performances, de haute concurrence et de haute disponibilité côté serveur sont de plus en plus élevées en tant que communication réseau hautes performances, asynchrone et non bloquante. framework, Netty devient de plus en plus populaire Attention et utilisation par la majorité des développeurs.

Cet article présentera comment utiliser le framework Netty pour implémenter un serveur API hautes performances.

1. Qu'est-ce que Netty

Netty est un framework d'application réseau asynchrone piloté par événements basé sur Java NIO, utilisé pour développer rapidement des programmes de communication réseau hautes performances et haute fiabilité , comme le client et le serveur.

Ses composants principaux incluent Buffer, Channel, EventLoop, Codec, etc. Buffer est le composant tampon de Netty, Channel fournit une interface de communication réseau abstraite, EventLoop est le modèle événementiel de Netty et Codec est un codec. Grâce à ces composants, le framework Netty peut fournir des capacités de communication réseau hautes performances, à haute concurrence et à faible latence.

2. Utilisation basique de Netty

Tout d'abord, nous devons introduire les dépendances de Netty :

<dependency>
    <groupId>io.netty</groupId>
    <artifactId>netty-all</artifactId>
    <version>4.1.42.Final</version>
</dependency>
Copier après la connexion

Ensuite, nous devons créer un objet Bootstrap, through Cet objet est utilisé pour démarrer notre serveur Netty :

EventLoopGroup bossGroup = new NioEventLoopGroup(); 
EventLoopGroup workerGroup = new NioEventLoopGroup(); 
try{
    ServerBootstrap bootstrap = new ServerBootstrap();
    bootstrap.group(bossGroup, workerGroup)
             .channel(NioServerSocketChannel.class)
             .childHandler(new ChannelInitializer<SocketChannel>() {
                 @Override
                 public void initChannel(SocketChannel ch) throws Exception {
                     ChannelPipeline pipeline = ch.pipeline();
                     pipeline.addLast(new HttpServerCodec());
                     pipeline.addLast(new HttpObjectAggregator(65536));
                     pipeline.addLast(new ChunkedWriteHandler());
                     pipeline.addLast(new HttpServerHandler());
                  }
              });
    ChannelFuture future = bootstrap.bind(port).sync();
    future.channel().closeFuture().sync();
}finally{
      bossGroup.shutdownGracefully();
      workerGroup.shutdownGracefully();
}
Copier après la connexion

Dans le code ci-dessus, nous avons créé deux objets EventLoopGroup, l'un est le bossGroup utilisé pour recevoir les demandes des clients et l'autre est utilisé pour gérer les demandes des clients. . groupe de travailleurs. Configurez les paramètres du serveur Netty via l'objet ServerBootstrap, y compris le protocole de communication (NioServerSocketChannel), le processeur (Handler), l'initialisation du canal et d'autres opérations.

Nous pouvons également voir que dans le code ci-dessus, nous avons ajouté les composants HttpServerCodec et HttpObjectAggregator pour implémenter l'encodage, le décodage et l'agrégation des requêtes et réponses HTTP. Dans le même temps, nous avons également ajouté ChunkedWriteHandler pour traiter les flux de Big Data.

Enfin, nous lions le port et démarrons le serveur Netty via la méthode bootstrap.bind, bloquons le thread principal et attendons que le serveur Netty s'arrête via future.channel().closeFuture( .sync() méthode.

3. Utilisez Netty pour implémenter un serveur API hautes performances

Pour un serveur API, nous devons généralement gérer un grand nombre de requêtes et de réponses tout en garantissant une disponibilité et une haute disponibilité du système. -temps de réponse des performances.

Ici, nous prenons comme exemple la mise en œuvre d'un serveur API simple pour présenter comment utiliser le framework Netty pour implémenter un serveur API hautes performances.

1. Définition de l'interface

Définissons d'abord une interface API simple, qui permet d'implémenter la fonction d'obtention d'informations utilisateur :

GET /user/{id} HTTP/1.1
Host: localhost:8888
Copier après la connexion

Où {id} est le numéro d'identification de l'utilisateur. Nous devons interroger les informations de l'utilisateur en fonction de ce numéro d'identification et les renvoyer au client.

2. Traitement métier

Ensuite, nous devons implémenter le traitement de la logique métier, c'est-à-dire interroger les informations de l'utilisateur en fonction du numéro d'identification dans la demande du client et renvoyer la requête résultats au client.

Tout d'abord, créons un processeur HttpServerHandler. Ce processeur hérite de SimpleChannelInboundHandler. Nous pouvons implémenter notre logique métier dans ce processeur.

public class HttpServerHandler extends SimpleChannelInboundHandler<FullHttpRequest> {
    @Override
    protected void channelRead0(ChannelHandlerContext ctx, FullHttpRequest msg) throws Exception {
        HttpServerRoute route = HttpServerRoute.builder()
                .addRoute("/user/{id}", new GetUserHandler())
                .build();
        HttpServerRequest request = new HttpServerRequest(msg);
        HttpServerResponse response = new HttpServerResponse(ctx, msg);
        route.route(request, response);
    }
}
Copier après la connexion

Comme vous pouvez le voir, dans le code ci-dessus, nous implémentons la correspondance de route via l'objet HttpServerRoute. Lors de la réception d'une demande client, nous convertirons la demande en un objet HttpServerRequest, y envelopperons l'objet de réponse HttpServerResponse, puis utiliserons l'objet HttpServerRoute pour faire correspondre les règles de routage et distribuer la demande au processeur correspondant pour traitement.

Nous devons implémenter le processeur GetUserHandler, qui est utilisé pour interroger les informations utilisateur en fonction de l'ID utilisateur :

public class GetUserHandler implements HttpServerHandlerInterface {
    @Override
    public void handle(HttpServerRequest request, HttpServerResponse response) throws Exception {
        String id = request.getPathParam("id");
        //查询用户信息
        User user = UserService.getUserById(id);
        if (user != null) {
            JSONObject json = new JSONObject();
            json.put("id", user.getId());
            json.put("name", user.getName());
            response.sendJSON(HttpResponseStatus.OK, json.toJSONString());
        } else {
            response.sendError(HttpResponseStatus.NOT_FOUND);
        }
    }
}
Copier après la connexion

Dans le code ci-dessus, nous interrogerons en fonction de l'ID numéro dans les informations utilisateur de la demande, et utilisez JSONObject pour construire les données de chaîne JSON de la réponse à la demande, et enfin renvoyer les résultats de la requête au client.

Nous devons également implémenter la classe UserService pour fournir la fonction d'interrogation des informations utilisateur :

public class UserService {
    public static User getUserById(String id) {
        //查询数据库中的用户信息
    }
}
Copier après la connexion

3 Test de performances

Enfin, testons. il Le temps de réponse et le QPS (nombre de requêtes simultanées par seconde) du serveur API hautes performances Netty que nous avons implémenté.

Grâce à l'outil Apache ab, nous pouvons simuler plusieurs requêtes simultanées de clients et collecter des statistiques sur les temps de réponse et les informations QPS. Utilisez la commande suivante :

ab -n 10000 -c 100 -k http://localhost:8888/user/1
Copier après la connexion

Description du paramètre :

-n : Indique le nombre total de requêtes

-c : Indique le nombre de requêtes simultanées requêtes

-k : Indique l'activation des connexions Keep-alive

Grâce aux tests, nous pouvons obtenir le temps de réponse et les informations QPS :

Server Software:
Server Hostname:        localhost
Server Port:            8888

Document Path:          /user/1
Document Length:        36 bytes

Concurrency Level:      100
Time taken for tests:   3.777 seconds
Complete requests:      10000
Failed requests:        0
Keep-Alive requests:    10000
Total transferred:      1460000 bytes
HTML transferred:       360000 bytes
Requests per second:    2647.65 [#/sec] (mean)
Time per request:       37.771 [ms] (mean)
Time per request:       0.378 [ms] (mean, across all concurrent requests)
Transfer rate:          377.12 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    2   1.2      2      10
Processing:     3   32  11.3     32      84
Waiting:        3   32  11.3     32      84
Total:          6   34  11.2     34      86

Percentage of the requests served within a certain time (ms)
  50%     34
  66%     38
  75%     40
  80%     42
  90%     49
  95%     55
  98%     64
  99%     71
 100%     86 (longest request)
Copier après la connexion

Vous pouvez voyez que notre serveur API Lors du test, il a été capable de gérer efficacement les simulations de 100 requêtes simultanées et il a pu gérer 2 647,65 requêtes par seconde, avec un temps de réponse moyen de seulement 37,771 millisecondes.

4. Résumé

Grâce à l'introduction et aux étapes ci-dessus, nous avons appris à utiliser Netty comme cadre de communication réseau et à l'utiliser pour développer des serveurs API hautes performances. L'utilisation du framework Netty peut considérablement améliorer les performances du serveur, ce qui confère à notre serveur une concurrence élevée, une fiabilité élevée, une faible latence et d'autres caractéristiques. Dans le même temps, le framework Netty présente également une évolutivité et une flexibilité élevées et peut être facilement intégré à n'importe quelle application.

Dans le cadre de la stack technologique de développement back-end Java, l'utilisation du framework Netty fait également partie des compétences qu'il faut maîtriser.

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal