Netty从入门到精通到放弃

有时间想记录一下关于Netty的知识。

第一课:传统IO的特点。

package com.example.aimei.controller;

import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
 * @author yuanzipeng
 * @date 2018/11/21
 */
public class OioServer {

    public static void main(String[] args) throws Exception {
        //加线程
        ExecutorService threadPool = Executors.newCachedThreadPool();
        //创建ServerSocket服务
        ServerSocket serverSocket = new ServerSocket(5566);
        System.out.println("服务端启动!");
        while (true) {
            //获取一个套接字(阻塞)
            Socket socket = serverSocket.accept();
            System.out.println("来一个客户端!");
            threadPool.execute(new Runnable() {
                @Override
                public void run() {
                    //业务处理
                    handle(socket);
                }
            });
        }
    }

    public static void handle(Socket socket) {
        try {
            byte[] bytes = new byte[1024];
            InputStream inputStream = socket.getInputStream();
            while (true) {
                //读取数据(阻塞)
                int read = inputStream.read(bytes);
                if (read != -1) {
                    System.out.println(new String(bytes, 0, read));
                } else {
                    break;
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            System.out.println("Socke关闭!");
            try {
                socket.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}

运行上面的代码启动服务端,用DOS命令窗口作为客户端,命令为:telnet 127.0.0.1 5566,如下:

确定,然后快捷键CTRL+],然后输入send hello

 java控制台就会收到hello,可以多连几个客户端。

从上面的代码可以知道传统的IO在获取套接字和读取数据的时候分别有一次阻塞。如果不用线程一个ServerSocket服务只能连一个客户端,用了线程处理相当于一个ServerSocket服务中的一个线程只能连接一个客户端。相对于NIO缺点就是消耗的资源比较多,只适合作为短连接,不适合作为长连接。

猜你喜欢

转载自www.cnblogs.com/yuanzipeng/p/9997756.html