Rumah Java javaTutorial Menggunakan Netty5 untuk komunikasi TCP dalam pembangunan API Java

Menggunakan Netty5 untuk komunikasi TCP dalam pembangunan API Java

Jun 18, 2023 am 08:31 AM
netty java api komunikasi tcp

Dalam pembangunan API Java, komunikasi TCP ialah komponen yang sangat penting, dan Netty5 ialah rangka kerja komunikasi rangkaian berprestasi tinggi berdasarkan NIO, yang boleh mengendalikan tugas komunikasi rangkaian yang kompleks dengan sangat mudah. Artikel ini akan memperkenalkan cara menggunakan Netty5 untuk komunikasi TCP, termasuk komponen teras Netty5, pengenalan kepada API biasa dan kes aplikasi praktikal. Pada masa yang sama, artikel ini juga akan memperkenalkan cara menggunakan Netty5 untuk meningkatkan prestasi dan kebolehpercayaan komunikasi TCP.

1. Komponen teras Netty5

Komponen teras Netty5 termasuk Channel, EventLoop, Codec, Handler dan Bootstrap. Antaranya, Saluran mewakili sambungan terbuka yang boleh membaca dan menulis data. EventLoop ialah kumpulan benang yang digunakan untuk mengendalikan semua acara dalam Netty5. Codec ialah satu set codec yang bertanggungjawab untuk menukar data daripada bytecode kepada objek, dan objek kepada bytecode. Pengendali ialah salah satu komponen terpenting dalam Netty5, bertanggungjawab untuk mengendalikan status sambungan, acara baca dan tulis serta acara pengecualian. Akhir sekali, Bootstrap ialah kelas utama yang digunakan dalam Netty5 untuk mengkonfigurasi, memulakan dan mengurus Netty.

2. Pengenalan kepada API yang biasa digunakan

  1. Buat bahagian Pelayan
ServerBootstrap serverBootstrap = new ServerBootstrap();
NioEventLoopGroup bossGroup = new NioEventLoopGroup();
NioEventLoopGroup workGroup = new NioEventLoopGroup();

serverBootstrap.group(bossGroup, workGroup)
                .channel(NioServerSocketChannel.class)
                .localAddress(new InetSocketAddress(port))
                .childHandler(new ChannelInitializer<SocketChannel>() {
                    @Override
                    public void initChannel(SocketChannel socketChannel) {
                        socketChannel.pipeline().
                        addLast(new CodecHandler(Encoding.getEncoding()),new TcpServerHandler());
                    }
                });

ChannelFuture f = serverBootstrap.bind().sync();
Salin selepas log masuk
  1. Buat bahagian Klien
rreee
  1. Buat ChannelInboundHandlerAdapter
Bootstrap bootstrap = new Bootstrap();
bootstrap.group(new NioEventLoopGroup())
                .channel(NioSocketChannel.class)
                .remoteAddress(new InetSocketAddress(ip, port))
                .handler(new ChannelInitializer<SocketChannel>() {
                    @Override
                    public void initChannel(SocketChannel ch) throws Exception {

                        ch.pipeline().addLast(new CodecHandler(Encoding.getEncoding()),new TcpClientHandler());
                    }
                });

ChannelFuture f = bootstrap.connect().sync();
Salin selepas log masuk
  1. Buat ChannelOutboundHandlerAdapter
public class TcpServerHandler extends ChannelInboundHandlerAdapter {
    
        @Override
        public void channelRead(ChannelHandlerContext ctx, Object msg){
            //处理读事件
        }
    
        @Override
        public void channelReadComplete(ChannelHandlerContext ctx){
            ctx.flush();
        }
    
        @Override
        public void exceptionCaught(ChannelHandlerContext ctx,Throwable cause){
            //处理异常事件
        }
    }
Salin selepas log masuk

Kes aplikasi praktikal berikut

kes praktikal Untuk memperkenalkan cara menggunakan Netty5 untuk komunikasi TCP.

Perihalan kes: Katakan terdapat sistem peperiksaan dalam talian yang perlu menggunakan protokol TCP untuk menyampaikan jawapan peperiksaan kepada pelayan.

    Kod sisi pelayan:
  1. public class TcpClientHandler extends ChannelOutboundHandlerAdapter {
        
            @Override
            public void write(ChannelHandlerContext ctx, Object msg,
                    ChannelPromise promise) {
                //处理写事件
            }
        
            @Override
            public void exceptionCaught(ChannelHandlerContext ctx,Throwable cause){
                //处理异常事件
            }
        }
    Salin selepas log masuk
    Kod sisi pelanggan:
  1. public class ExamServer {
        public static void main(String[] args) throws InterruptedException {
            int port = 8080;
            if (args.length > 0){
                port = Integer.parseInt(args[0]);
            }
            ServerBootstrap serverBootstrap = new ServerBootstrap();
            NioEventLoopGroup bossGroup = new NioEventLoopGroup();
            NioEventLoopGroup workGroup = new NioEventLoopGroup();
            serverBootstrap.group(bossGroup, workGroup)
                    .channel(NioServerSocketChannel.class)
                    .localAddress(new InetSocketAddress(port))
                    .childHandler(new ChannelInitializer<SocketChannel>() {
                        @Override
                        public void initChannel(SocketChannel socketChannel) {
                            socketChannel.pipeline()
                            .addLast(new CodecHandler(Encoding.getEncoding()),new TcpServerHandler());
                        }
                    });
            ChannelFuture f = serverBootstrap.bind().sync();
            //等待服务器监听端口关闭
            f.channel().closeFuture().sync();
        }
    }
    Salin selepas log masuk
    Membaca dan menulis ujian data
  1. public class ExamClient {
        public static void main(String[] args) throws InterruptedException {
            String host = "localhost";
            int port = 8080;
    
            Bootstrap bootstrap = new Bootstrap();
            bootstrap.group(new NioEventLoopGroup())
                    .channel(NioSocketChannel.class)
                    .remoteAddress(new InetSocketAddress(host, port))
                    .handler(new ChannelInitializer<SocketChannel>() {
                        @Override
                        public void initChannel(SocketChannel ch) throws Exception {
                            ch.pipeline()
                            .addLast(new CodecHandler(Encoding.getEncoding()),new TcpClientHandler());
                        }
                    });
            ChannelFuture f = bootstrap.connect().sync();
            //一直等到channel关闭
            f.channel().closeFuture().sync();
        }
    }
    Salin selepas log masuk
    rrree4. Pengoptimuman prestasi Netty5

    Selain fungsi hebat Netty5, prestasinya juga merupakan perbezaan terbesar antaranya dan rangka kerja komunikasi rangkaian yang lain. Dalam aplikasi praktikal, kita biasanya perlu mempertimbangkan cara untuk meningkatkan lagi prestasi Netty5. Berikut ialah beberapa kaedah pengoptimuman prestasi Netty5 yang biasa digunakan.

      Pengoptimuman kumpulan benang
    EventLoop Netty5 ialah kumpulan benang untuk pemprosesan acara, jadi saiz kumpulan benang secara langsung mempengaruhi prestasi Netty5. Jika kolam benang terlalu besar, ia akan membawa kepada pembaziran sumber CPU yang berlebihan, sekali gus menjejaskan prestasi sebaliknya, jika kolam benang terlalu kecil, kecekapan pemprosesan serentak mungkin terjejas dengan serius; Adalah disyorkan untuk melaraskan saiz kumpulan benang dengan sewajarnya mengikut senario aplikasi dan konfigurasi perkakasan pelayan.

      Pemprosesan paket mesej
    Memandangkan komunikasi TCP berorientasikan aliran, iaitu, paket data boleh dibahagikan kepada beberapa paket kecil untuk penghantaran. Untuk memastikan integriti dan ketepatan data, kami perlu mensubkontrakkan mesej tersebut. Dalam Netty5, anda boleh menggunakan LengthFieldBasedFrameDecoder untuk pemprosesan paket mesej.

      Pengoptimuman Cache
    Netty5 menyokong strategi caching tersuai, yang boleh dioptimumkan mengikut senario aplikasi dan keperluan perniagaan. Sebagai contoh, anda boleh menetapkan saiz cache dan masa tamat tempoh yang sesuai berdasarkan saiz dan kekerapan kandungan cache untuk mengelakkan kemerosotan prestasi yang disebabkan oleh saiz cache atau tamat tempoh yang berlebihan.

    Kesimpulan

    Artikel ini memperkenalkan cara menggunakan Netty5 untuk komunikasi TCP, termasuk komponen teras Netty5, pengenalan kepada API biasa dan kes aplikasi praktikal. Pada masa yang sama, ia juga memperkenalkan cara menggunakan Netty5 untuk meningkatkan prestasi dan kebolehpercayaan komunikasi TCP. Saya berharap pembaca dapat memahami Netty5 dengan lebih baik melalui kajian artikel ini dan menggunakannya secara fleksibel dalam projek sebenar.

    Atas ialah kandungan terperinci Menggunakan Netty5 untuk komunikasi TCP dalam pembangunan API Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

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.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Menggunakan Imgscalr untuk pemprosesan imej dalam pembangunan API Java Menggunakan Imgscalr untuk pemprosesan imej dalam pembangunan API Java Jun 18, 2023 am 08:40 AM

Menggunakan Imgscalr untuk pemprosesan imej dalam pembangunan API Java Dengan perkembangan Internet mudah alih dan populariti pengiklanan Internet, imej telah menjadi elemen yang amat diperlukan dalam banyak aplikasi. Sama ada ia memaparkan produk, membina kalangan sosial atau meningkatkan pengalaman pengguna, imej memainkan peranan penting. Dalam aplikasi, selalunya perlu untuk melakukan operasi seperti pemangkasan, penskalaan dan pemutaran imej, yang memerlukan penggunaan beberapa alat pemprosesan imej. Imgscalr ialah imej yang sangat biasa digunakan dalam pembangunan JavaAPI.

Apakah tapak web antara muka API percuma? Apakah tapak web antara muka API percuma? Jan 05, 2024 am 11:33 AM

Laman web antara muka api percuma: 1. UomgAPI: platform yang menyediakan perkhidmatan API percuma yang stabil dan pantas, dengan lebih daripada 100 antara muka API 2. api percuma: menyediakan pelbagai antara muka API percuma 3. API JSON: menyediakan antara muka API data percuma; . Platform Terbuka AutoNavi: Menyediakan antara muka API yang berkaitan dengan peta; 5. Pengecaman muka Muka++: Menyediakan antara muka API yang berkaitan dengan pengecaman muka: Menyediakan lebih seratus antara muka API percuma, sesuai untuk pelbagai keperluan sumber; 7. Data agregat, dsb.

Cara menulis kod komunikasi TCP Modbus menggunakan PHP Cara menulis kod komunikasi TCP Modbus menggunakan PHP Jul 18, 2023 am 10:17 AM

Cara menggunakan PHP untuk menulis kod komunikasi ModbusTCP Modbus ialah protokol komunikasi yang digunakan dalam bidang automasi industri dan digunakan secara meluas untuk penghantaran data antara PLC (pengawal logik boleh atur cara) dan peralatan automasi lain. ModbusTCP ialah varian protokol Modbus yang menggunakan susunan protokol TCP/IP sebagai lapisan pengangkutan untuk membenarkan komunikasi jauh melalui rangkaian. Artikel ini akan memperkenalkan cara menulis kod komunikasi ModbusTCP menggunakan PHP dan menyediakan beberapa contoh kod. Pasang PHP

Bagaimana untuk melaksanakan kod pengesahan imej dalam pembangunan API Java Bagaimana untuk melaksanakan kod pengesahan imej dalam pembangunan API Java Jun 18, 2023 am 09:22 AM

Dengan perkembangan pesat teknologi Internet, untuk memastikan keselamatan sistem, kod pengesahan telah menjadi bahagian penting dalam setiap sistem. Antaranya, kod pengesahan gambar digemari oleh pembangun kerana kemudahan penggunaan dan keselamatannya. Artikel ini akan memperkenalkan kaedah khusus untuk melaksanakan kod pengesahan imej dalam pembangunan JavaAPI. 1. Apakah itu kod pengesahan gambar? Kod pengesahan gambar ialah cara pengesahan mesin manusia melalui gambar. Ia biasanya terdiri daripada gabungan gambar rawak yang mengandungi nombor, huruf, simbol, dsb., yang meningkatkan keselamatan sistem. Prinsip kerjanya termasuk

Menggunakan GreenMail untuk ujian e-mel dalam pembangunan API Java Menggunakan GreenMail untuk ujian e-mel dalam pembangunan API Java Jun 18, 2023 pm 02:22 PM

Java API ialah bahasa pembangunan yang digunakan secara meluas untuk membangunkan aplikasi web, aplikasi desktop, aplikasi mudah alih, dsb. Dalam pembangunan API Java, ujian e-mel adalah penting kerana komunikasi e-mel adalah salah satu kaedah komunikasi utama dalam masyarakat moden. Oleh itu, pembangun perlu menggunakan beberapa alat untuk menguji sama ada e-mel mereka berfungsi dengan baik. Artikel ini akan memperkenalkan perisian sumber terbuka yang dipanggil GreenMail, yang boleh digunakan dalam pembangunan JavaAPI untuk ujian e-mel. hijau

Apakah protokol biasa untuk pengaturcaraan rangkaian Java? Apakah protokol biasa untuk pengaturcaraan rangkaian Java? Apr 15, 2024 am 11:33 AM

Protokol yang biasa digunakan dalam pengaturcaraan rangkaian Java termasuk: TCP/IP: digunakan untuk penghantaran data dan pengurusan sambungan yang boleh dipercayai. HTTP: digunakan untuk penghantaran data web. HTTPS: Versi HTTP selamat yang menggunakan penyulitan untuk menghantar data. UDP: Untuk pemindahan data yang cepat tetapi tidak stabil. JDBC: digunakan untuk berinteraksi dengan pangkalan data hubungan.

Pembangunan Java: Cara menggunakan Netty untuk pengaturcaraan rangkaian berprestasi tinggi Pembangunan Java: Cara menggunakan Netty untuk pengaturcaraan rangkaian berprestasi tinggi Sep 20, 2023 pm 02:09 PM

Pembangunan Java: Cara menggunakan Netty untuk pengaturcaraan rangkaian berprestasi tinggi Ringkasan: Netty ialah rangka kerja pengaturcaraan rangkaian dipacu peristiwa berprestasi tinggi yang memudahkan proses pembangunan aplikasi rangkaian. Artikel ini akan memperkenalkan ciri utama Netty dan cara menggunakan Netty untuk pengaturcaraan rangkaian berprestasi tinggi. Pada masa yang sama, kami juga akan menyediakan beberapa contoh kod Java khusus untuk membantu pembaca memahami dan menggunakan Netty dengan lebih baik. 1. Pengenalan kepada Netty Netty ialah kotak pengaturcaraan rangkaian berasaskan JavaNIO

JAX-RS lwn. Spring MVC: Pertempuran antara gergasi RESTful JAX-RS lwn. Spring MVC: Pertempuran antara gergasi RESTful Feb 29, 2024 pm 05:16 PM

Pengenalan API RESTful telah menjadi sebahagian daripada aplikasi WEB moden. Mereka menyediakan pendekatan piawai untuk mencipta dan menggunakan perkhidmatan Web, dengan itu meningkatkan kemudahalihan, kebolehskalaan dan kemudahan penggunaan. Dalam ekosistem Java, JAX-RS dan springmvc ialah dua rangka kerja yang paling popular untuk membina API RESTful. Artikel ini akan melihat secara mendalam kedua-dua rangka kerja, membandingkan ciri, kelebihan dan keburukannya untuk membantu anda membuat keputusan termaklum. JAX-RS: JAX-RSAPI JAX-RS (JavaAPI untuk Perkhidmatan Web RESTful) ialah JAX-RSAPI standard yang dibangunkan oleh JavaEE untuk membangunkan REST

See all articles