Socket,NIO,Netty介绍

本文介绍了Socket网络编程的基础,包括Socket的概述、整体流程及代码实现。接着深入探讨了I/O模型,如BIO、NIO、AIO的原理、特点及适用场景。详细讲解了Java NIO的核心组件,如Buffer、Channel和Selector,并通过代码示例解释了其使用。最后,文章简要剖析了Netty框架的优势,指出其在解决原生NIO问题上的贡献,以及Netty的线程模型和反应器模式。
摘要由CSDN通过智能技术生成

1. Socket回顾与I/0模型

1.1 Socket网络编程回顾

1.1.1 Socket概述

Socket,套接字就是两台主机之间逻辑连接的端点。TCP/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据。
Socket是通信的基石,是支持TCP/IP协议的网络通信的基本操作单元。
它是网络通信过程中端点的抽象表示,包含进行网络通信必须的五种信息:连接使用的协议、本地主机的IP地址、本地进程的协议端口、远程主机的IP地址、远程进程的协议端口

1.1.2 Socket整体流程

Socket编程主要涉及到客户端和服务端两个方面,首先是在服务器端创建一个服务器套接字(ServerSocket),并把它附加到一个端口上,服务器从这个端口监听连接。端口号的范围是0到65536,但是0到1024是为特权服务保留的端口号,可以选择任意一个当前没有被其他进程使用的端口。

客户端请求与服务器进行连接的时候,根据服务器的域名或者IP地址,加上端口号,打开一个套接字。当服务器接受连接后,服务器和客户端之间的通信就像输入输出流一样进行操作。
Socket通信

1.1.3 代码实现

  1. 服务器端代码实现
    服务器端实现用的是 new ServerSocket(port);
    package com.work.server;
    
    import java.io.IOException;
    import java.io.InputStream;
    import java.io.OutputStream;
    import java.net.ServerSocket;
    import java.net.Socket;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    
    public class ServerDemo {
         
    	public static void main(String[] args) throws Exception {
         
    		//1.创建一个线程池,如果有客户端连接就创建一个线程, 与之通信
    		ExecutorService executorService = Executors.newCachedThreadPool();
    		//2.创建 ServerSocket 对象
    		ServerSocket serverSocket = new ServerSocket(9999);
    		System.out.println("服务器已启动");
    		while (true) {
         
    			//3.监听客户端
    			Socket socket = serverSocket.accept();
    			System.out.println("有客户端连接");
    			//4.开启新的线程处理
    			executorService.execute(new Runnable() {
         
    				@Override
    				public void run() {
         
    					handle(socket);
    				}
    			});
    		}
    	}
    	
    	public static void handle(Socket socket) {
         
    		try {
         
    			System.out.println("线程ID:" + Thread.currentThread().getId() + " 线程名称:" + Thread.currentThread().getName());
    			//从连接中取出输入流来接收消息
    			InputStream is = socket.getInputStream();
    			byte[] b = new byte[1024];
    			int read = is.read(b);
    			System.out.println("客户端:" + new String(b, 0, read));
    			//连接中取出输出流并回话
    			OutputStream os = socket.getOutputStream();
    			os.write("没钱".getBytes());
    		} catch (Exception e) {
         
    			e.printStackTrace();
    		} finally {
         
    			try {
         
    				//关闭连接
    				socket.close();
    			} catch (IOException e) {
         
    				e.printStackTrace();
    			}
    		}
    	}
    }
    
  2. 客户端实现
    客户端实现用的是new Socket(ip, port)
    package com.work.client;
    
    import java.io.InputStream;
    import java.io.OutputStream;
    import java.net.Socket;
    import java.util.Scanner;
    
    public class ClientDemo {
         
    	public static void main(String[] args) throws Exception {
         
    		while (true) {
         
    			//1.创建 Socket 对象
    			Socket s = new Socket("127.0.0.1", 9999);
    			//2.从连接中取出输出流并发消息
    			OutputStream os = s.getOutputStream();
    			System.out.println("请输入:");
    			Scanner sc = new Scanner(System.in);
    			String msg = sc.nextLine();
    			os.write(msg.getBytes());
    			//3.从连接中取出输入流并接收回话
    			InputStream is = s.getInputStream();
    			byte[] b = new byte[1024];
    			int read = is.read
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值