Netty入门之WebSocket初体验

本文介绍了Netty作为高性能、事件驱动的网络应用框架,适用于高性能和多线程并发场景。通过讲解BIO、NIO和AIO的通信模型,深入理解Netty的IO基础。接着展示了如何使用Netty实现WebSocket服务器,包括maven依赖、启动类、自定义处理类和全局配置,并提供了客户端测试的方法。最后,强调了WebSocket的持久连接特性,使得服务端断开连接时客户端能接收到通知。
摘要由CSDN通过智能技术生成

什么是Netty

  • 高性能 事件驱动、异步非阻塞
  • 基于NIO的客户端、服务端编程框架
  • 稳定性和伸缩性

Netty使用场景

  • 高性能领域
  • 多线程并发领域
  • 异步通信领域

IO通信

BIO通信

同步阻塞IO

  • 一个线程负责连接
  • 一个请求一应答
  • 缺乏弹性伸缩能力
    BIO通信模型
    典型的就是tomcat
    在这里插入图片描述

伪异步IO通信

同步阻塞IO

  • 线程池负责连接
  • M请求N连接
  • 线程池阻塞
    伪异步IO通信模型
    在这里插入图片描述

NIO模型

同步非阻塞IO

  • M请求1连接
  • 缓冲区Buffer
  • 通道Channel
  • 多路复用器Selector

AIO通信

异步非阻塞IO

  • 连接注册读写事件和回调函数
  • 读写方法异步
  • 主动通知程序

Netty实现WebSocket

项目地址: https://github.com/ghostKang/netty-study

maven依赖

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

启动类

import handler.MyWebSocketChannelHandler;
import io.netty.bootstrap.ServerBootstrap;
import io.netty.channel.Channel;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.nio.NioServerSocketChannel;

/**
 * 程序的入口,负责启动应用
 *
 * Created by Yuk on 2019/1/2.
 */
public class Main {

    public static void main(String[] args) {
        EventLoopGroup boosGroup = new NioEventLoopGroup();
        EventLoopGroup workGroup = new NioEventLoopGroup();

        try {
            ServerBootstrap b = new ServerBootstrap();
            b.group(boosGroup,workGroup);
            b.channel(NioServerSocketChannel.class);
            b.childHandler(new MyWebSocketChannelHandler());// 调用自己封装的处理类
            System.out.println("服务端开启等待客户端连接...");
            Channel ch = b.bind(9998).sync().channel();
            ch.closeFuture().sync();

        }catch (Exception e){
            e.printStackTrace();
        }finally {
            // 优雅地退出程序
      
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值