服务器nio协议,NIO TCP/IP协议 网络通信

解释:NIO → non-blocking input output(非阻塞式的输入和输出)

使用场景:一般用于高并发场景下;请求 (客户端)、响应 (服务端)两方,约定好使用TCP/IP通信;双方约定好报文格式 (报文头+报文体)及编码格式 (这里用UTF-8),报文头内容 (约定好长度比如8位,不够前面补零)里面内容为报文体长度,再根据报文头内容,获取后面的报问体的内容。

例如:报文示例: 00000007aaaaaaa;报文体内容为7个a,所以报文头长度为7不够八位前面补零。

一、 服务端

NioServerThread: nio的服务类(selector、buffer、channel)

ServerThreadOperate: 新线程用来处理客户端请求

/**

* selector轮询线程的开启并绑定channel通道

* @author zhb

*/

public class NioServerThread {

private static int count = 0;

// 事件轮询器

private static Selector selector;

// 服务通道

private static ServerSocketChannel serverSocketChannel;

// 开启一个服务线程

public void action() throws IOException, InterruptedException{

// 开启服务端的事件轮询器,只有这一个线程

selector = Selector.open();

// 开通服务端的socket通道

serverSocketChannel = ServerSocketChannel.open();

// socket为非阻塞

serverSocketChannel.configureBlocking(false);

// 绑定端口

serverSocketChannel.socket().bind(new InetSocketAddress(Constant.serverSocketPort));

// channel和socket绑定,注册可以接入事件

serverSocketChannel.register(selector,SelectionKey.OP_ACCEPT);

System.err.println("---------------------线程开启-----------------------");

handerSelector();

}

/**

* 处理轮询事件

* @throws IOException

*/

private void handerSelector() throws IOException {

while(true){

//多长时间轮询一次

// selector.select(1000);

selector.select();

//事件轮询器,查出的kernel中的所有的事件标识

Set selectedKeys = selector.selectedKeys();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值