当前位置: 首页 > news >正文

备案网站名怎样制作网页视频

备案网站名,怎样制作网页视频,韩城市网站建设局电话,网站建设数据库多少钱Netty Netty初体验基础概念Reactor模型传统的阻塞IO模型基础Reactor模型多线程Reactor模型 为什么要使用Netty? (NIO的框架,用于解决高并发出现的问题) *BIO:同步且阻塞的IO NIO:同步且非阻塞的IO(不是说线程&#x…

Netty

  • Netty初体验
  • 基础概念
  • Reactor模型
    • 传统的阻塞IO模型
    • 基础Reactor模型
    • 多线程Reactor模型

为什么要使用Netty?
(NIO的框架,用于解决高并发出现的问题)

在这里插入图片描述

*BIO:同步且阻塞的IO
NIO:同步且非阻塞的IO(不是说线程)
AIO:异步且非阻塞的IO
还没有实现业务,光写整个流程就非常繁琐。NIO除了实现起来复杂之外,还存在一些需要解决的棘手问题,比如客户端断线重连如何实现,心跳处理(客户端在一定的时间内,不断的向服务器发送信息告诉服务器还在)、半包读写处理等等一些列问题,此时需要有这么一个框架,用于解决和优化NIO存在的问题,它就是Netty。

目的:客户端越来越多,随着客户端的增多,代码的复杂程度就变高,netty帮我们降低了编写nio的代码复杂程度*


Netty初体验

第一步:引入依赖

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

服务器端

public class NettyServer {public static void main(String[] args) throws Exception {//创建只处理连接请求的线程组EventLoopGroup bossGroup = new NioEventLoopGroup(10);//创建只处理客户端读写业务的线程组EventLoopGroup workGroup = new NioEventLoopGroup(10);//创建服务端启动对象ServerBootstrap bootstrap = new ServerBootstrap();//配置参数bootstrap.group(bossGroup,workGroup)//使用NioServerSocketChannel作为服务器的通道实现.channel(NioServerSocketChannel.class)//配置用于存放因没有空闲线程导致连接请求被暂存放到队列中的队列长度.option(ChannelOption.SO_BACKLOG,1024)//创建通道初始化的对象并配置该对象,向该对象中添加处理器来实现具体的业务.childHandler(new ChannelInitializer<SocketChannel>() {//初始化通道@Overrideprotected void initChannel(SocketChannel ch) throws Exception {//添加处理器,处理器里面是真正处理业务的ch.pipeline().addLast(new NettyServerHandler());}});//配置groupSystem.out.println("Netty服务器启动了");//同步阻塞地启动服务器ChannelFuture channelFuture = bootstrap.bind(9090).sync();//只要服务没关闭,该方法会一直阻塞channelFuture.channel().closeFuture().sync();System.out.println("================a");bossGroup.shutdownGracefully();workGroup.shutdownGracefully();}
}
public class NettyServerHandler extends ChannelInboundHandlerAdapter {//当有客户端发送数据来的时候该方法就会被调用@Overridepublic void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {ByteBuf buf = (ByteBuf) msg;System.out.println("客户端发送的数据:"+buf.toString(StandardCharsets.UTF_8));}//读完数据之后调用的方法:发送数据给客户端@Overridepublic void channelReadComplete(ChannelHandlerContext ctx) throws Exception {//创建携带的ByteBuf对象ByteBuf buf = Unpooled.copiedBuffer("hello client".getBytes(StandardCharsets.UTF_8));ctx.writeAndFlush(buf);}//异常捕获@Overridepublic void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {System.out.println(cause.getMessage());ctx.close();}
}

客户端

public class NettyClient {public static void main(String[] args) throws Exception {//创建一个线程组用于事件循环EventLoopGroup eventLoopGroup = new NioEventLoopGroup();//创建客户端启动对象Bootstrap bootstrap = new Bootstrap();//设置相关参数bootstrap.group(eventLoopGroup)//使用NioSocketChannel作为客户端的通道实现.channel(NioSocketChannel.class)//创建通道初始化对象并设置handler业务处理器.handler(new ChannelInitializer<SocketChannel>() {@Overrideprotected void initChannel(SocketChannel ch) throws Exception {//添加处理器,处理器里面是实现具体业务的ch.pipeline().addLast(new NettyClientHandler());}});System.out.println("Netty客户端启动了");//告知客户端的服务器的地址,并启动客户端ChannelFuture channelFuture = bootstrap.connect("127.0.0.1",9090).sync();channelFuture.channel().closeFuture().sync();//阻塞等待完成操作后关闭通道eventLoopGroup.shutdownGracefully();}
}
public class NettyClientHandler extends ChannelInboundHandlerAdapter {//当客户端完成连接服务器后调用该方法@Overridepublic void channelActive(ChannelHandlerContext ctx) throws Exception {ByteBuf buf = Unpooled.copiedBuffer("hello server".getBytes(StandardCharsets.UTF_8));ctx.writeAndFlush(buf);}//当通道有读事件发生时调用的方法:读取服务器返回的数据@Overridepublic void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {ByteBuf buf = (ByteBuf) msg;System.out.println("来自服务器"+ctx.channel().remoteAddress()+"的消息"+buf.toString(StandardCharsets.UTF_8));}
}

基础概念

NIO中实现多路复用的核心类是Selector,当多路复用器Selector调用select方法时,将会查找发生事件的
channel,问题是,该如何在多个注册到selector上的channel中找到哪些channel发生了事件,此时NIO不同的版本有不同的做法。
epoll函数
poll函数
select函数

在这里插入图片描述

Reactor模型

不同的线程决定了程序的性能,多线程是为了充分利用CPU

传统的阻塞IO模型

在这里插入图片描述
客户端连接服务端之后,会等客户端输入完之后,最后响应给客户端,才能紧接着为其它的客户端执行任务,因为等待会耗费大量时间,所以并没有把CPU用到极致

基础Reactor模型

在这里插入图片描述
可以执行完连接之后,让别的客户端来拿来处理自己的任务,各个操作之间是独立的,充分利用服务端之间的性能(可能是连接的,也可以是读的,也可以是写的)

多线程Reactor模型

在这里插入图片描述

http://www.yayakq.cn/news/677756/

相关文章:

  • 网站建设员是做什么的网站制作公司去哪找
  • 亚洲网站建设中湖南省建设厅易小林
  • 网站手机版怎么制作网站建设公司墨子网络
  • 专业建站公司的业务内容有哪些外贸做那种网站
  • 建设内网网站流程做网站 使用权 所有权
  • 建网站做淘宝客著名网站建设
  • 南通网站建设规划做网站卖什么软件
  • 网站seo优化主要有哪些手段vue做的网站域名汇总
  • 门户网站例子系统管理主要包括哪些内容
  • 阿里云备案网站服务内容怎么填深圳建站服务公司
  • 网站建设公司专业网站科技开发传媒大学附近网站建设公司
  • 最新款淘宝客源码整网站程序模板+后台带自动采集商品功能带文章永久免费个人域名注册
  • 游戏网站模板网新企业网站管理系统
  • 微信制作小程序流程百度搜索seo优化技巧
  • 专业移动微网站设计wordpress怎么添加注册
  • 做正规网站有哪些2022中国进入一级战备了吗
  • 如何建设好医院网站个人网站可以挂广告吗
  • wordpress主循环软件开发网站能做seo吗
  • 厦门网站建设优化引擎seo如何优化
  • 网站生成软件小程序登录入口官网网址
  • 湛江网站建设公司专业团队张益达图片
  • 有域名自己做网站吗代写平台
  • 青岛知名网站建设定制电脑自带的网页制作软件
  • 运城手机网站建设网站制作软件
  • 西安的商城网站amz123
  • 手表网站 海马300米潜水表用php做网站需要什么软件
  • 网站数据查询网站建设服务公司有哪些
  • 大鹏网络网站建设专业精准网络营销推广
  • 勒流网站建设企业网站免费模板
  • 浏览器怎么打开网站服务器下载app网站制作要多少费用