博客
关于我
Netty+SpringBoot+FastDFS+Html5实现聊天App详解(一)
阅读量:792 次
发布时间:2023-02-14

本文共 1153 字,大约阅读时间需要 3 分钟。

Netty学习

Netty结合SpringBoot、FastDFS和Html5实现聊天应用项目

Netty+SpringBoot+FastDFS+Html5实现聊天App,项目介绍

Netty+SpringBoot+FastDFS+Html5实现聊天App,项目github链接

本章练习完整代码链接

IO编程与NIO编程

传统IO编程性能分析

传统IO编程模型在客户端较少的情况下运行良好,但当业务需要支持成千上万的客户端连接时,传统IO模型可能不再适用。传统IO模型的关键问题在于每个连接创建后需要一个独立的线程来处理,这样会导致线程资源受限、线程切换效率低下以及IO读写效率不高的问题。

  • 线程资源受限:大量线程处于阻塞状态会造成资源浪费
  • 线程切换效率低下:固定CPU核数下频繁线程切换导致性能下降
  • IO效率不高:以字节为单位读写效率较低
  • NIO编程的优势

    NIO通过selector批量处理连接,减少线程数量,提升效率。

  • 线程资源优化:避免为每个连接创建独立线程,而是将连接绑定到固定的线程
  • 线程切换效率提升:线程数量大幅减少,切换更高效
  • IO效率提升:以字节块为单位读写,提升处理效率
  • Hello Netty

    服务器端实现

  • 定义主从线程组:bossGroup用于接受连接,workerGroup处理业务
  • 服务器启动类ServerBootstrap:配置主从线程、通道类型和子处理器
  • 绑定端口并启动服务:绑定8088端口并同步启动
  • 关闭优雅 Shutdown:关闭主从线程组
  • 初始化器实现

  • 创建子处理器:HelloServerInitializer继承ChannelInitializer
  • 注册编解码器:HttpServerCodec用于处理HTTP协议
  • 自定义助手类:CustomHandler处理响应
  • 消息处理逻辑:读取客户端消息并返回固定响应
  • Netty聊天小练习

    服务器端实现

  • 定义主从线程组:创建mainGroup和subGroup
  • 服务器启动:使用ServerBootstrap配置通道和子处理器
  • WebSocket协议支持:HttpServerCodec、ChunkedWriteHandler和HttpObjectAggregator
  • 路由配置:WebSocketServerProtocolHandler指定路由
  • 自定义消息处理:ChatHandler处理TextWebSocketFrame
  • 客户端实现

  • WebSocket连接:客户端连接ws://192.168.1.4:8088/ws
  • 消息发送和接收:通过JavaScript实现发送消息和接收消息
  • 消息显示:动态更新用户界面显示消息
  • 测试

    通过浏览器访问localhost:8088,验证服务器响应"hello netty~"

    转载地址:http://kccfk.baihongyu.com/

    你可能感兴趣的文章
    Navicat for MySQL 命令列 执行SQL语句 历史日志
    查看>>
    Navicat for MySQL 查看BLOB字段内容
    查看>>
    Navicat for MySQL笔记1
    查看>>
    Navicat for MySQL(Ubuntu)过期解决方法
    查看>>
    Navicat Premium 12 卸载和注册表的删除
    查看>>
    Navicat 导入sql文件
    查看>>
    navicat 添加外键1215错误
    查看>>
    navicat 系列软件一点击菜单栏就闪退
    查看>>
    navicat 自动关闭_干掉Navicat!MySQL官方客户端到底行不行?
    查看>>
    Navicat 设置时间默认值(当前最新时间)
    查看>>
    navicat 连接远程mysql
    查看>>
    navicat:2013-Lost connection to MySQL server at ‘reading initial communication packet解决方法
    查看>>
    Navicate for mysql 数据库设计-数据库分析
    查看>>
    Navicat下载和破解以及使用
    查看>>
    Navicat中怎样将SQLServer的表复制到MySql中
    查看>>
    navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
    查看>>
    Navicat可视化界面导入SQL文件生成数据库表
    查看>>
    Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
    查看>>
    Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
    查看>>
    Navicat如何连接MySQL
    查看>>