Hadoop源码分析2: NIO Socket 分析

1.客户端

公司产品的客户端的使用阻塞式的Socket,并没有使用NIO,在Hadoop中遇到再议。

2.服务器端

2.1 阻塞式
例子程序

public class BIOServer {

  static class Hanlder extends Thread {
        privateSocket socket;

        publicHanlder(Socket socket) {
            this.socket= socket;
        }

    @Override
    public void run(){
    try {
        InputStream in = socket.getInputStream();
        BufferedReader brIn = new BufferedReader(newInputStreamReader(in));
        OutputStream out =socket.getOutputStream();
          out.write(("login:  " + new Date() + "\r\n").getBytes());
          while (true) {
          //线程在此阻塞,直到读到客户端新的数据
          String cmd =brIn. readLine();
          System.out.println("receive:" + cmd + "\r\n");
            out.write(("return:  " + cmd.toUpperCase() +"\r\n").getBytes());
            if("bye".equalsIgnoreCase(cmd)) {
              out.write(("logout:   " + newDate() + "\r\n").getBytes());
              break;
            }
          }
            socket.close();
      }catch (IOException e) {
            e.printStackTrace();
    }
    }
  }

            publicstatic void main(String[] args) {
            try {
              ServerSocket serverSocket = newServerSocket(7777);
              while (true) {
              //线程在此阻塞,直到收到新的连接
              Socket socket =serverSocket. accept();
              //对每个连接使用一个线程进行处理
              new Hanlder(socket).start();
              }
            } catch(IOException e) {
              e.printStackTrace();
          }
        }
}


2.2 非阻塞式
 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值