有时间想记录一下关于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缺点就是消耗的资源比较多,只适合做为短链接,不适合做为长链接。线程