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

兰州seo外包公司网站搜索排名优化价格

兰州seo外包公司,网站搜索排名优化价格,网站优化内容,美工零基础的从哪开始学说明 使用Netty框架构建的socket服务端在处理客户端请求时,每接到一个客户端的连接请求,服务端会分配一个channel处理跟该客户端的交互。如果处理该channel数据的ChannelHandler抛出异常没有捕获,那么该channel会关闭。但服务端和其它客户端…

说明

使用Netty框架构建的socket服务端在处理客户端请求时,每接到一个客户端的连接请求,服务端会分配一个channel处理跟该客户端的交互。如果处理该channel数据的ChannelHandler抛出异常没有捕获,那么该channel会关闭。但服务端和其它客户端的通信不受影响。

代码示例

该示例验证场景:
服务端和客户端建立了正常的连接,服务端给该客户端分配了一个channel。从该channel读取数据的ChannelHandler抛出异常,没有被捕获,导致该channel被关闭,服务端和该客户端的通信中断。但服务端和其它客户端的通信不受影响。

服务端代码片段

package com.thb.power.server;import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;import io.netty.bootstrap.ServerBootstrap;
import io.netty.channel.ChannelFuture;
import io.netty.channel.ChannelOption;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.nio.NioServerSocketChannel;
import io.netty.handler.logging.LogLevel;
import io.netty.handler.logging.LoggingHandler;/*** 服务端的主函数* @author thb**/
public class MainStation {private static final Logger logger = LogManager.getLogger();static final int PORT = Integer.parseInt(System.getProperty("port", "22335"));public static void main(String[] args) throws Exception {logger.traceEntry();// 配置服务器EventLoopGroup bossGroup = new NioEventLoopGroup();EventLoopGroup workerGroup = new NioEventLoopGroup();try {ServerBootstrap b =  new ServerBootstrap();b.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class).option(ChannelOption.SO_BACKLOG, 100).handler(new LoggingHandler(LogLevel.INFO)).childHandler(new MainStationInitializer());// 启动服务端ChannelFuture f = b.bind(PORT).sync();// 等待直到server socket关闭f.channel().closeFuture().sync();} finally {// 关闭所有event loops以便终止所有的线程bossGroup.shutdownGracefully();workerGroup.shutdownGracefully();}logger.traceExit();}}
package com.thb.power.server;import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;import com.thb.power.constant.PowerConstants;
import com.thb.power.handler.VerifyChecksumHandler;import io.netty.buffer.Unpooled;
import io.netty.channel.ChannelInitializer;
import io.netty.channel.ChannelPipeline;
import io.netty.channel.socket.SocketChannel;
import io.netty.handler.codec.DelimiterBasedFrameDecoder;
import io.netty.handler.logging.LogLevel;
import io.netty.handler.logging.LoggingHandler;public class MainStationInitializer extends ChannelInitializer<SocketChannel> {private static final Logger logger = LogManager.getLogger();@Overridepublic void initChannel(SocketChannel ch) throws Exception {logger.traceEntry();ChannelPipeline p = ch.pipeline();		 p.addLast(new LoggingHandler(LogLevel.INFO));// 用报文开头的字符、结尾的字符作为分隔符,解析成完整的报文	p.addLast(new DelimiterBasedFrameDecoder(PowerConstants.SOCKET_MAX_BYTES_PER_PACKET, true, Unpooled.wrappedBuffer(new byte[] {PowerConstants.SOCKET_END_MARK}),Unpooled.wrappedBuffer(new byte[] {PowerConstants.SOCKET_START_MARK})));	p.addLast(new VerifyChecksumHandler());logger.traceExit();}
}
package com.thb.power.handler;import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;import io.netty.buffer.ByteBuf;
import io.netty.buffer.ByteBufUtil;
import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelInboundHandlerAdapter;
import io.netty.handler.codec.CorruptedFrameException;
import io.netty.util.ReferenceCounted;/*** 验证接收的报文的校验和* @author thb**/
public class VerifyChecksumHandler extends ChannelInboundHandlerAdapter {private static final Logger logger = LogManager.getLogger();@Overridepublic void channelRead(ChannelHandlerContext ctx, Object msg) {logger.traceEntry();		if (msg instanceof ByteBuf) {ByteBuf m = (ByteBuf)msg;logger.info("msg reference count: {}", m.refCnt());// 此处人为构造场景,以便验证抛出异常的情况。将引用计数减少1,执行后,引用计数变为0,读数据会抛异常m.release();m.readByte();logger.info("readableBytes: " + m.readableBytes());		// 将收到的报文的每个字节转换为十六进制打印出来			logger.info(ByteBufUtil.prettyHexDump(m));			} else {// 这个数据不需要向后传递,因为数据已经错误了// 传入的对象msg如果实现了ReferenceCounted接口,那么显式就释放if (msg instanceof ReferenceCounted) {((ReferenceCounted)msg).release();}throw new CorruptedFrameException("received illegal data: not ByteBuf type");}logger.traceExit();}@Overridepublic void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) {cause.printStackTrace();ctx.close();}
}
package com.thb.power.constant;/*** 保存了一些常数* @author thb**/
public final class PowerConstants {/*** 定义了私有构造函数,防止被外部实例化*/private PowerConstants() {}/*** 通信报文的起始符*/public static final byte SOCKET_START_MARK = (byte)0x68;/*** 通信报文的的结束符*/public static final byte SOCKET_END_MARK = (byte)0x16;/*** 每个报文的最大字节数*/public static final short SOCKET_MAX_BYTES_PER_PACKET = 1024;
}

启动服务端

在这里插入图片描述

启动客户端,并向服务端发送数据

在这里插入图片描述
在这里插入图片描述

服务端的ChannelHandler处理数据时抛出了异常,断开了和该客户端的连接

在这里插入图片描述
在这里插入图片描述
从输出可以看出,服务端处理客户端channel数据的ChannelHandler抛出了异常,服务端终止了和该客户端的连接。

观察客户端的输出

在这里插入图片描述
从输出可以看出,客户端终止了和服务端的连接。

服务端可以继续接受新的客户端连接

在这里插入图片描述
从输出可以看出,服务端可以正常接受新的客户端的连接

http://www.dinnco.com/news/21994.html

相关文章:

  • 邯郸做移动网站报价线上推广方式
  • 网站设计公司有用吗如何制作网址
  • 做棋牌网站建设多少钱泉州网站seo外包公司
  • 手机网站什么技术开发媒体宣传推广方案
  • 万网归一什么时候启动seo工具有哪些
  • 个人备案网站可以做论坛吗百度竞价点击神器下载安装
  • 机械网站建设公司推荐线上推广平台
  • 网站建设咨询公司朋友圈推广文案
  • wordpress 体育主题公园海口seo快速排名优化
  • 爱ppt网站云优化seo
  • 中国建设人才服务信息网是不是正规网站杭州百度代理公司
  • 高端营销型网站建设seo经理招聘
  • 做阀门销售在哪个网站上做好百度seo关键词排名优化教程
  • 网站迁移到别的服务器要怎么做网页优化
  • 利用免费网站做SEO百度推广优化怎么做
  • 网站建设个人信息英文翻译百度关键字优化
  • 石家庄做网站的公司哪个好台湾新闻最新消息今天
  • 张家界企业网站制作武汉网络广告推广服务
  • erp系统华为qq群排名优化软件
  • 深圳网站建设微信开发凡科官网免费制作小程序
  • 杭州企业网站制作哪家好如何制作一个网页
  • 香港公司黄页百度seo优化关键词
  • 台州做网站联系方式广西壮族自治区人民医院
  • 做调查问卷赚钱哪个网站好提升seo排名的方法
  • 网站推广的优缺点线上推广平台有哪些
  • 网站建设 自助建站友情链接英文翻译
  • 化妆品网站建设报告今日的重大新闻
  • 网站开发设网页制作平台有哪些
  • 免费网站导航建设西安百度公司
  • 眉山政府网站建设上海网站建设方案