Netty权威指南——入门篇1 Netty入门应用 备份

本文详细介绍了使用Netty进行服务端和客户端开发的过程,包括配置ServerSocketChannel、Selector、NioEventLoopGroup,以及如何处理ChannelInbound和ChannelOutbound事件。着重展示了NIO的非阻塞I/O模型和ByteBuf的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 1 Netty服务端开发

        在开始使用Netty开发TimeServer之前,先回顾一下使用NIO进行访问端开发的步骤。

        1、创建ServerSocketChannel,配置为非阻塞模式。

        2、绑定监听,配置TCP参数。

        3、创建一个独立的I/O线程,用于轮询多路复用器Selector。

        4、创建Selector,将之前创建的ServerSocketChannel注册到Selector上,监听SelectionKye.ACCEPT。

        5、启动I/O线程,在循环体中执行Selector.select()方法,轮询就绪状态的Channel。

        6、当轮询到了处于就绪状态的Channel时,需要对其进行判断,如果是OP_ACCEPT状态,说明是新的客户端接入,则调用ServerSocketChannel.accept()方法,接受新的客户端。

        7、设置新接入的客户端链路SocketChannel为非阻塞模式,配置其他的一些TCP参数。

        8、将SocketChannel注册到Selector,监听OP_READ操作位。

        9、如果轮询的Channel位OP_READ,则说明SocketChannel中有新就绪的数据包需要读取,则构造ByteBuffer对象,读取数据包。

        10、如果轮询的Channel位OP_WRITE,说明还有数据没有发送完成,需要继续发送。

        一个简单的NIO服务端程序,如果我们直接使用JDK的NIO类库进行开发,至少需要以上10个步骤才能完成最基本的消息读取和发送。

        TimeServerNetty.java 代码

public class TimeServerNetty {
    public static void main(String[] args) {
        int port = 8080;
        new TimeServerNetty().bind(port);
    }
    public void bind(int port){
        //配置服务端的NIO线程组
        EventLoopGroup bossGroup = new NioEventLoopGroup();
        EventLoopGroup workerGroup = new NioEventLoopGroup();
        try {
            ServerBootstrap bootstrap = new ServerBootstrap();
            bootstrap.group(bossGroup,workerGroup)
                    .channel(NioServerSocketChannel.class)
       
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

geminigoth

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值