I/O系列篇(一)同步阻塞式I/O(BIO)

一、模型说明

image.png

采用BIO通信模型的服务端,通常由一个独立的Acceptor线程负责监听来自客户端的连接,接收到客户端请求后产生一个新的线程进行链路处理,处理完毕后通过输出流返回给客户端,线程销毁。
该模型最大的问题就是缺乏弹性伸缩能力,当访问量上升之后,服务端的线程数和客户端的访问数呈1:1的正比关系。



二、代码

1、服务端代码

public class TimeServer {

    public static void main(String[] args) throws IOException {
        int port = 8080;

        ServerSocket server = null;
        try {

            server = new ServerSocket(port);

            System.out.println("the time server is start in port : " + port);

            Socket socket = null;

            while (true){
                socket = server.accept();
                new Thread(new TimeServerHandler(socket)).start();
            }
        }catch (Exception e){
            e.printStackTrace();
        }finally {
            if (server!=null){
                server.close();
                server = null;
            }
        }
    }
}
public class TimeServerHandler implements Runnable{
    private Socket socket;

    public TimeServerHandler(Socket socket){
        this.socket = socket;
    }

    @Override
    public void run() {
        BufferedReader in = null;
        PrintWriter out = null;
        try {
            in = new BufferedReader(new InputStreamReader(this.socket.getInputStream()));
            out = new PrintWriter(this.socket.getOutputStream(), true);
            String body = null;

            while (true) {
                body = in.readLine();

                if(body==null){
                    break;
                }

                System.out.println("the time server receive msg : " + body);

                String responseStr = "now time is : " + System.currentTimeMillis();

                out.println(responseStr);
            }
        }catch (Exception e){
            e.printStackTrace();
        }finally {
            if (in!=null){
                try {
                    in.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
            if (out!=null){
                out.close();
                out = null;
            }
            if (this.socket!=null){
                try {
                    this.socket.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
                this.socket = null;
            }
        }
    }
}


2、客户端代码

public class TimerClient {

    public static void main(String[] args) {
        int port = 8080;
        Socket socket = null;
        BufferedReader in = null;
        PrintWriter out = null;
        try {
            socket = new Socket("127.0.0.1", port);

            in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
            out = new PrintWriter(socket.getOutputStream(), true);

            out.println("what time is now ?");

            System.out.println("the time client send msg succeed");

            String responsStr = in.readLine();

            System.out.println("the time server response --- " + responsStr);

        }catch (Exception e){
            e.printStackTrace();
        }finally {
            if (out!=null){
                out.close();
                out = null;
            }
            if (in!=null){
                try {
                    in.close();
                    in = null;
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
            if (socket!=null){
                try {
                    socket.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
                socket = null;
            }
        }
    }
}



三、运行结果

1、服务端

the time server is start in port : 8080
the time server receive msg : what time is now ?

2、客户端端

the time client send msg succeed
the time server response --- now time is : 1528517383573

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,010评论 19 139
  • 1.ios高性能编程 (1).内层 最小的内层平均值和峰值(2).耗电量 高效的算法和数据结构(3).初始化时...
    欧辰_OSR阅读 29,656评论 8 265
  • 奶奶家楼下是我上了六年的中学,隔了条窄窄的巷子,相对而望。每天早晨上学,奶奶都会站在窗前看着我走进校门,直至背影消...
    Sprina阅读 601评论 11 10
  • 新得画,山山水水秋。笛箫兼冷雨,更添愁!往事随风新入酒,伴心游!
    寒渠生阅读 178评论 0 2
  • 这两年一直在学习心理学,不间断的参加心理学沙龙,其实都是本着一个目的,不断的丰盈自己,给处于叛逆期的儿子 有言传身...
    缘起结夏阅读 467评论 0 0