Netty从入门到精通到放弃

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

第一课:传统IO的特色。socket

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,以下:ide

肯定,而后快捷键CTRL+],而后输入send hellospa

 java控制台就会收到hello,能够多连几个客户端。.net

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

相关文章
相关标签/搜索