cari
RumahJavajavaTutorialMenggunakan Netty5 untuk komunikasi TCP dalam pembangunan API Java

Menggunakan Netty5 untuk komunikasi TCP dalam pembangunan API Java

Jun 18, 2023 am 08:31 AM
nettyjava apikomunikasi 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();
  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();
  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){
            //处理异常事件
        }
    }

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){
                //处理异常事件
            }
        }
    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();
        }
    }
    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();
        }
    }
    rrree
4. 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
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
Mengapa Java adalah pilihan yang popular untuk membangunkan aplikasi desktop silang platform?Mengapa Java adalah pilihan yang popular untuk membangunkan aplikasi desktop silang platform?Apr 25, 2025 am 12:23 AM

Javaispopularforcross-platformdesktopapplicationsduetoits "writeOnce, runanywhere" falsafah.1) itusesBytecodethatrunsonanyjvm-equippedplatform.2) LibrariesLikeswingandjavafxhelpcreatenativeS.3) ITseShipBareSivaryS

Bincangkan situasi di mana menulis kod khusus platform di Java mungkin diperlukan.Bincangkan situasi di mana menulis kod khusus platform di Java mungkin diperlukan.Apr 25, 2025 am 12:22 AM

Alasan untuk menulis kod khusus platform di Java termasuk akses kepada ciri sistem operasi tertentu, berinteraksi dengan perkakasan tertentu, dan mengoptimumkan prestasi. 1) Gunakan JNA atau JNI untuk mengakses Windows Registry; 2) Berinteraksi dengan pemandu perkakasan khusus Linux melalui JNI; 3) Gunakan logam untuk mengoptimumkan prestasi permainan pada macOS melalui JNI. Walau bagaimanapun, menulis kod khusus platform boleh menjejaskan mudah alih kod, meningkatkan kerumitan, dan berpotensi menimbulkan risiko overhead dan keselamatan.

Apakah trend masa depan dalam pembangunan Java yang berkaitan dengan kemerdekaan platform?Apakah trend masa depan dalam pembangunan Java yang berkaitan dengan kemerdekaan platform?Apr 25, 2025 am 12:12 AM

Java akan meningkatkan lagi kemerdekaan platform melalui aplikasi awan asli, penempatan pelbagai platform dan interoperabilitas silang bahasa. 1) Aplikasi asli awan akan menggunakan GraalVM dan Quarkus untuk meningkatkan kelajuan permulaan. 2) Java akan diperluaskan ke peranti tertanam, peranti mudah alih dan komputer kuantum. 3) Melalui Graalvm, Java akan mengintegrasikan dengan lancar dengan bahasa seperti Python dan JavaScript untuk meningkatkan interoperabilitas silang bahasa.

Bagaimanakah menaip Java yang kuat menyumbang kepada kemerdekaan platform?Bagaimanakah menaip Java yang kuat menyumbang kepada kemerdekaan platform?Apr 25, 2025 am 12:11 AM

Sistem taip kuat Java memastikan kemerdekaan platform melalui keselamatan jenis, penukaran jenis bersatu dan polimorfisme. 1) Jenis Keselamatan Melakukan pemeriksaan jenis pada masa penyusunan untuk mengelakkan kesilapan runtime; 2) peraturan penukaran jenis bersatu adalah konsisten di semua platform; 3) Polimorfisme dan mekanisme antara muka membuat kod berkelakuan secara konsisten pada platform yang berbeza.

Terangkan bagaimana antara muka asli Java (JNI) boleh menjejaskan kebebasan platform.Terangkan bagaimana antara muka asli Java (JNI) boleh menjejaskan kebebasan platform.Apr 25, 2025 am 12:07 AM

JNI akan memusnahkan kemerdekaan platform Java. 1) JNI memerlukan perpustakaan tempatan untuk platform tertentu, 2) Kod tempatan perlu disusun dan dihubungkan pada platform sasaran, 3) versi sistem operasi atau JVM yang berbeza mungkin memerlukan versi perpustakaan tempatan yang berbeza, 4) Kod tempatan boleh memperkenalkan kelemahan keselamatan atau menyebabkan kemalangan program.

Adakah terdapat teknologi baru yang mengancam atau meningkatkan kemerdekaan platform Java?Adakah terdapat teknologi baru yang mengancam atau meningkatkan kemerdekaan platform Java?Apr 24, 2025 am 12:11 AM

Teknologi yang muncul menimbulkan ancaman dan meningkatkan kemerdekaan platform Java. 1) Teknologi pengkomputeran awan dan kontena seperti Docker meningkatkan kemerdekaan platform Java, tetapi perlu dioptimumkan untuk menyesuaikan diri dengan persekitaran awan yang berbeza. 2) WebAssembly menyusun kod Java melalui GraalVM, memperluaskan kemerdekaan platformnya, tetapi ia perlu bersaing dengan bahasa lain untuk prestasi.

Apakah pelaksanaan JVM yang berbeza, dan adakah mereka semua menyediakan tahap kemerdekaan platform yang sama?Apakah pelaksanaan JVM yang berbeza, dan adakah mereka semua menyediakan tahap kemerdekaan platform yang sama?Apr 24, 2025 am 12:10 AM

Pelaksanaan JVM yang berbeza dapat memberikan kemerdekaan platform, tetapi prestasi mereka sedikit berbeza. 1. OracleHotspot dan OpenJDKJVM melakukan sama seperti kemerdekaan platform, tetapi OpenJDK mungkin memerlukan konfigurasi tambahan. 2. IBMJ9JVM melakukan pengoptimuman pada sistem operasi tertentu. 3. Graalvm menyokong pelbagai bahasa dan memerlukan konfigurasi tambahan. 4. AzulzingJVM memerlukan pelarasan platform tertentu.

Bagaimanakah kebebasan platform mengurangkan kos pembangunan dan masa?Bagaimanakah kebebasan platform mengurangkan kos pembangunan dan masa?Apr 24, 2025 am 12:08 AM

Kemerdekaan platform mengurangkan kos pembangunan dan memendekkan masa pembangunan dengan menjalankan set kod yang sama pada pelbagai sistem operasi. Khususnya, ia ditunjukkan sebagai: 1. Mengurangkan masa pembangunan, hanya satu set kod yang diperlukan; 2. Mengurangkan kos penyelenggaraan dan menyatukan proses ujian; 3. Penyebaran cepat dan kerjasama pasukan untuk memudahkan proses penempatan.

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

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual