Netty入门指南(上)

news/2024/5/21 21:25:05 标签: java, 网络, Netty

概述

Nettyjava网络编程框架,一个NIO客户端/服务端框架,并发高,传输快,封装好。它大大简化和简化了网络编程,如TCP和UDP套接字服务器。
Netty是Reactor模式的实现: Reactor中的组件:
a) Reactor:是IO事件的派发者。将事件分发给绑定该事件的Handler处理;相当于有分发功能的Selector。
b) Acceptor:用于接受client连接,建立对应client的Handler,并向Reactor注册此Handler。相当于NIO中建立连接的那个判断分支。
c) Handler:事件处理器,绑定了某类事件。是和一个client通讯的实体,实现业务的处理。相当于消息读写处理等操作类。

Netty_8">1. 第一个Netty程序

官方推荐的demo,使用Netty实现一个Discard服务端(Discard协议是抛弃协议,服务端收到消息后不做任何处理。在此我们用它测试服务端和客户端是否连接成功。)
引入jar包:

<dependency>
    <groupId>io.netty</groupId>
    <artifactId>netty-all</artifactId>
    <version>4.1.32.Final</version>
</dependency>

1.1 服务端

消息处理器:

java">import io.netty.buffer.ByteBuf;
import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelInboundHandlerAdapter;
import io.netty.util.CharsetUtil;

public class DiscardHandler extends ChannelInboundHandlerAdapter {
    //读取客户端发送的信息
    @Override
    public void channelRead(ChannelHandlerContext ctx, Object msg) {
        ByteBuf in = (ByteBuf) msg;
        System.out.println("Server received: " + in.toString(CharsetUtil.UTF_8));
        //读取完不处理,直接释放
        in.release();
    }

    //有异常的时候
    @Override
    public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) {
        cause.printStackTrace();
        ctx.close();//关闭连接
    }
}

ChannelHandler用来实现服务端的逻辑,ChannelInboundHandler接口用来定义入站事件的方法。ChannelInboundHandlerAdapter中提供了默认ChannelInboundHandler的实现。所以继承这个类,并重写几个方法即可。
启动类:

java">import io.netty.bootstrap.ServerBootstrap;
import io.netty.channel.ChannelFuture;
import io.netty.channel.ChannelInitializer;
import io.netty.channel.ChannelOption;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.SocketChannel;
import io.netty.channel.socket.nio.NioServerSocketChannel;

public class NettyServer {
    public static void main(String[] args) {
        EventLoopGroup bossGroup = new NioEventLoopGroup(); // (1)
        EventLoopGroup workerGroup = new NioEventLoopGroup();
        try {
            ServerBootstrap b = new ServerBootstrap(); // (2)
            b.group(bossGroup, workerGroup)
                    .channel(NioServerSocketChannel.class) // (3)
                    .childHandler(new ChannelInitializer<SocketChannel>() { // (4)
                        @Override
                        public void initChannel(SocketChannel ch) throws Exception {
                            ch.pipeline().addLast(new DiscardHandler());
                        }
                    })
                    .option(ChannelOption.SO_BACKLOG, 128)          // (5)
                    .childOption(ChannelOption.SO_KEEPALIVE, true); // (6)

            // 绑定端口
            ChannelFuture f = b.bind(8000).sync(); // (7)

            // 等待,直到服务端关闭
            // 在这个示例中这里不会运行到,但当需要关闭的时候,可以这样执行
            f.channel().closeFuture().sync();
        } catch (InterruptedException e) {
            e.printStackTrace();
        } finally {
            workerGroup.shutdownGracefully();
            bossGroup.shutdownGracefully();
        }
    }
}

(1) NioEventLoopGroup是一个处理I/O操作的多线程循环。Netty为不同种类的传输提供了多种EventLoopGroup。此处实现了一个服务端的应用程序。通常服务端需要两个NioEventLoopGroup,第一个称作boos,boos用来接收进来的连接。另一个是worker,worker用来处理已经被接收的连接,一旦boss接收到连接,就会把连接信息注册到worker上。使用多少线程以及如何将它们映射到创建的通道取决于EventLoopGroup实现,可以通过构造函数进行配置。
(2) ServerBootstrap是一个设置服务端的工具类。
(3) 指定使用NioServerSocketChannel实例化传入的连接。
(4) 当一个新的连接被接受,一个新的子Channel将被创建,ChannelInitializer会添加ChannelHandler的实例(自定义的DiscardHandler)到Channel的ChannelPipeline。ChannelHandler用于处理消息。如果有入站信息,这个Handler(处理器)将被通知。
(5) 可以设置Channel的参数,这里写的是TCP/IP服务器,所以可以设置套接字选项。SO_BACKLOG是服务端接受连接的队列长度,如果队列已满,客户端连接将被拒绝,windows默认值就是128。
(6) option()选项是提供给NioServerSocketChannel接收进来的连接,也就是boos线程。childOption()选项提供给由父管道接收来的连接,也就是worker线程。SO_KEEPALIVE默认是false,启用该功能,TCP会主动探测空闲连接的有效性,相当于心跳机制,默认心跳间隔是7200s。
(7) 绑定端口。

1.2 客户端

java">import io.netty.bootstrap.Bootstrap;
import io.netty.channel.Channel;
import io.netty.channel.ChannelInitializer;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.nio.NioSocketChannel;
import io.netty.handler.codec.string.StringEncoder;

import java.util.Date;

public class NettyClient {
    public static void main(String[] args) throws InterruptedException {
        Bootstrap bootstrap = new Bootstrap();
        NioEventLoopGroup group = new NioEventLoopGroup();

        bootstrap.group(group)
                .channel(NioSocketChannel.class)
                .handler(new ChannelInitializer<Channel>() {
                    @Override
                    protected void initChannel(Channel ch) {
                        ch.pipeline().addLast(new StringEncoder());
                    }
                });

        Channel channel = bootstrap.connect("127.0.0.1", 8000).channel();

        while (true) {//每隔两秒发一条信息
            channel.writeAndFlush(new Date() + ": hello world!");
            Thread.sleep(2000);
        }
    }
}

先启动服务端,再启动客户端,服务端运行结果如下:

在这里插入图片描述


http://www.niftyadmin.cn/n/177124.html

相关文章

论文阅读 | Squeeze-and-Excitation Networks (SENet)

前言&#xff1a;经典重温&#xff0c;不怎么加参数提升性能的模块SENet 代码&#xff1a;【here】 Squeeze-and-Excitation Networks 引言 神经网络中每一层的卷积实际就是一组卷积核作用在带着通道的空间局部区域上&#xff0c;一起融合有着感受野的空间信息和通道信息 At…

玩转Mybatis高级特性:让你的数据操作更上一层楼

文章目录动态SQL缓存机制插件机制自定义类型转换总结Mybatis高级特性能够帮助我们更加灵活地操作数据库&#xff0c;包括动态SQL、缓存机制、插件机制、自定义类型转换等。学习这些特性可以让我们更好地利用Mybatis&#xff0c;提高数据操作的效率和质量。未来的道路由自己抉择…

分段插值方法和code,cubic spline, cubic hermite spline

文章目录0. 引入1.Cubic Spline Interpolation2. 多项式插值3. 分段插值4. scipy.interpolate中的插值方法4.1 cubic hermite spline插值类4.2 cubic spline插值类4.3 示例和代码&#xff1a;0. 引入 在 Non-Rigid Dense Correspondence with Applications for Image Enhancem…

机器视觉检测技术在检测产品表面缺陷的应用

产品表面缺陷检测属于机器视觉技术的一种&#xff0c;就是利用机器视觉模拟人类视觉的功能&#xff0c;从具体的实物进行图像的采集处理、计算、最终进行实际检测、控制和应用。当今消费类电子产品的消费者们都期待开箱看到完美无瑕的产品。有划痕、凹凸不平和带有其他瑕疵的产…

【Spring Cloud Alibaba Nacos】Nacos心跳机制实现快速上下线

文章目录前言Metadata元数据ClassMetadataSpring中常见的一些元注解Nacos心跳时间自定义配置Ribboon 的ServerListRefreshInterval总结前言 我们都知道Spring Cloud Alibaba Nacos是通过客户端和服务端的心跳机制&#xff0c;来实现服务的注册和下线的&#xff0c;Nacos的心跳…

Spring Security 6.0系列【1】基础篇之概述及入门案例

有道无术&#xff0c;术尚可求&#xff0c;有术无道&#xff0c;止于术。 本系列Spring Boot版本3.0.4 源码地址&#xff1a;https://gitee.com/pearl-organization/study-spring-security-demo 文章目录导读安全框架Spring Security概述发展历史入门案例1. 创建工程2. 运行3.…

CAPL计算ICMP校验和Checksum

文章目录 前言一、ICMP校验和计算1.计算方法:2.案例:3.CANoe计算结果二、CAPL实现1.代码2.CAPL执行结果前言 随着全球智能电动汽车的普及,车载以太网也越来越多应用到汽车网络中,而ICMP协议也是常用的协议,如:Ping,ICMP校验和计算方法在网上的资料也比较多,如:Python、…

Linux安装Kafka2.5.1(超详细)

一、环境准备 首先你要在你的电脑上安装一台CentOS的虚拟机&#xff0c;然后配置好桥接模式&#xff08;参考链接&#xff1a;https://blog.csdn.net/Sumuxi9797926/article/details/129701355?spm1001.2014.3001.5502&#xff09; 或者 有一台云服务器&#xff0c;其次你要在…