zoukankan      html  css  js  c++  java
  • netty学习记录

    什么是netty?

    • 是一个高性能 事件驱动、异步非堵塞的io开源框架;
    • 基于NIO的客户端,服务器端编程框架;
    • 稳定性和伸缩性;

    (BIO(Blocking I/O)同步阻塞I/O、NIO (New I/O) 同步非阻塞I/O、AIO (Asynchronous I/O) 异步非阻塞I/O;)

    其中nio1.0为同步非阻塞,nio2.0为aio;

    netty使用场景

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

    BIO通信

    • 一个线程负责连接
    • 一请求一应答
    • 缺乏弹性伸缩能力

    伪异步IO通信

    • 线程池负责连接
    • M请求N应答
    • 线程池阻塞

    NIO通信

    • 缓冲区Buffer:读写数据都放在缓冲区,通过缓冲区操作
    • 通道Channel:双向通道,inputStream,outStream都是单向的,所以channel可以进行同时进行读和写
    • 多路复用器Selector:循环Channel

    AIO通信

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

    什么是WebSocket?

    • H5协议规范
    • 握手机制
    • 解决客户端与服务端时事通行而产生的技术(基于TCP协议)

    WebSocket的优点

    • 节省通信开销
    • 服务器主动传送数据给客户端
    • 实时通信

    WebSocket建立连接

    • 客户端发起握手请求
    • 服务端响应请求
    • 连接建立

    WebSocket生命周期 

    • 打开事件
    • 消息事件
    • 错误事件
    • 关闭事件

    WebSocket关闭连接

    • 服务器关闭底层TCP连接
    • 客户端发起TCP Close
  • 相关阅读:
    【转】卡特兰数四个公式(简单)
    【基础算法-ST表】入门 -C++
    【题解】[Nwerc 2006]escape -C++
    C#高级编程第11版
    C#高级编程第11版
    C#高级编程第11版
    C#高级编程第11版
    C#高级编程第11版
    109th LeetCode Weekly Contest Knight Dialer
    109th LeetCode Weekly Contest Number of Recent Calls
  • 原文地址:https://www.cnblogs.com/zhengyuanyuan/p/9232751.html
Copyright © 2011-2022 走看看