Netty网络编程零基础入门

目录
  • OSI七层网络模型
  • Socket技术
  • TCP协议
  • Java语言创建socket应用
  • http协议

OSI七层网络模型

应用层:Http协议、文件服务器、邮件服务器

表示层:数据转换解决不同系统中间通讯的兼容问题

会话层:建立与应用程序的会话连接(socket)

传输层:提供端口号(区分不同的应用程序)和传输的协议(TCP和UDP)

网络层:为数据实现路由(路由器、交换机)

数据链路层:对传输的地址的帧以及错误的检测。

物理层:以二进制的形式在物理机器.上实现传输。(光纤、专线、各种物理介质实现)

Socket技术

属于传输层非常核心的内容任何的编程语言都是支持socket (网络编程技术) 技术开发,目的就是解决两个应用程序通讯的问题;注意: socket 不属于某种协议,只是网络编程技术。socket技术支持两种协议(TCP和UDP) 。

应用场景: http协议、rpc框架

TCP协议是一个可靠的协议,因为建立连接的时候必须通过三次握手才可以实现数据传输,所以数据不会丢失。

UDP协议面向无连接协议,UDP在通讯的时候不需要对方的存在,属于不可靠传输,可能存在数据丢包的问题。应用场景:聊天

TCP协议

三次握手:经过三次握手之后建立通讯才开始进行数据传输

白话文描述:

1、第一次握手:客户端会给服务端发送消息问:你在不在?

2、第二次握手:服务端收到了客户端咨询的(”你在不在?“),服务端就给客户端发送消息回复,就说:我在。

3、第三次握手:客户端收到服务端回复我在的呢”,客户端就会给服务端发送消息,开始传输数据。

三次握手成功之后,开始建立连接传输数据。

专业术语描述:

Syn (建立连接)、Ack (确认标记)、fin (终 止标记)

1.第一次握手:客户端会向服务器端发送代码syn=1, 随机会产生一-个数SEQ=x发送到我们的服务器端;

2.第二次握手:服务器端确认收到syn和X值,回复给客户端ack=x+1和seq = y (随机数)发送给客户端。

3.第三次握手:客户端接受syn、ack、y值之后向服务器发送ack=y+1,此包发送完毕之后就可以开始建立连接。

为什么要有三次握手,不是两次?

两次可能存在网络抖动的情况下,三次握手比较稳定。第三次握手也可以叫预传输数据,看看数据是否可以传输过去。

四次挥手:可靠关闭连接

关闭连接:

第一次挥手: 客户端向服务器端发送释放的报文,停止发送数据 fin=1、生成一个序列号seq=u;

第二次挥手: 服务器端接受到释放的报文后,发送ack=u+1;随机生成的seq=v给客户端;当前状态为关闭等待状态,客户端收到了服务器确认通知之后,此时客户端就会进入到终止状态,等待服务器端发送释放报文。

第三次挥手:服务器端最后数据发送完毕之后,就向客户端发送连接释放报文,FIN=1,ack=u+1 当前为半关闭状态,随机生成一个随机树w

第四次挥手,客户端必须发出确认,ACK=1,ack=w+1,而自己的序列号是seq=u+1,此时,客户端就进入了TIME-WAIT(时间等待)状态。注意此时TCP连接还没有释放,必须经过2∗∗MSL(最长报文段寿命)的时间后,当客户端撤销相应的TCB后,才进入CLOSED状态。

服务器只要收到了客户端发出的确认,立即进入CLOSED状态。同样,撤销TCB后,就结束了这次的TCP连接。可以看到,服务器结束TCP连接的时间要比客户端早一些。

白话文翻译四次挥手:

第一次挥手 客户端向服务端发送一个释放连接通知;

第二次挥手 服务端接受到释放通知之后,告诉给客户端说等待一下,因为可能存在有其他的数据没有发送完毕,等待数据全部传输完毕之后就开始 关闭连接;

第三次挥手 服务器端所有的数据发送完毕之后,就告诉客户端说现在可以释放连接了。

第四次挥手: 客户端确认是最终释放连接通知,ok 就开始 就向服务区端发送我们可以开始关闭连接啦;

Java语言创建socket应用

这里使用BIO 模型来实现

服务端

public class Server {
    private static int port = 8585;
    public static void main(String[] args) {
        ServerSocket serverSocket = null;
        try {
            serverSocket = new ServerSocket(port);
            //开始监听
            System.out.println("服务器开始监听,监听端口:" + port);
            while(true) {
                Socket socket = serverSocket.accept();//阻塞  等待客戶端連接
                System.out.println("接受一个客户端的请求.....");
                InputStream in = socket.getInputStream();
                int len = -1;
                byte[] buff = new byte[1024];
                while ((len = in.read(buff)) != -1) {//阻塞   等待客戶端發送数据
                    String str = new String(buff, 0, len);
                    System.out.println("读取到客户端的输入字符:" + str);
                }
                in.close();
                socket.close();
            }
        } catch (IOException e) {
            e.printStackTrace();
        }finally {
            try {
                serverSocket.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}

客户端

public class Client {
    private static int port = 8585;
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入客户端编号:");
        String no = sc.next();
        Socket socket = null;
        try {
            System.out.println("客户端"+no+"开始连接服务器..");
           socket = new Socket("127.0.0.1",port);
           if(socket!=null){
               System.out.println("客户端:"+no+"连接服务器成功!");
           }
            OutputStream out = socket.getOutputStream();
           while(true){
               System.out.println("客户端"+no+"请输入要发送字符(输入quit表示结束):");
               String str = sc.next();
               if(str.trim().equalsIgnoreCase("quit"))
                   break;
               out.write((no+":"+str).getBytes());
           }
            System.out.println("客户端"+no+"连接中断");
           out.close();
           socket.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

http协议

Http协议是一种超文本传输的协议,基于TCP/IP协议实现的包装,img、css、html

Http协议 默认端口号80 明文传输

Https协议 443 加密传输

Https 比http协议安全 ssl+证书实现传输

Http协议特征:

  • 无状态 没有记忆的会话 token、jwt、Session
  • 请求(req)与响应模型(resp)
  • 简单快捷
  • 灵活可以传输任何类型

Http协议版本

Http协议1.0:规定客户端与服务器端传输完成之后,立马关闭连接;短连接

Http协议1.1 :长连接

长连接与短连接

长连接:客户端与服务器端建立连接之后,不会立马关闭连接,会保持一定复用机制,默认情况下在300s空闲情况下自动断开连接;

短连接:客户度与服务器端发送消息之后,立马关闭连接 如果频繁发送Http请求,可能消耗服务器端资源;

到此这篇关于Netty网络编程零基础入门的文章就介绍到这了,更多相关Netty网络编程内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Netty学习教程之基础使用篇

    什么Netty? Netty是由JBOSS提供的一个java开源框架.Netty提供异步的.事件驱动的网络应用程序框架和工具,用以快速开发高性能.高可靠性的网络服务器和客户端程序. 也就是说,Netty 是一个基于NIO的客户.服务器端编程框架,使用Netty 可以确保你快速和简单的开发出一个网络应用,例如实现了某种协议的客户,服务端应用.Netty相当简化和流线化了网络应用的编程开发过程,例如,TCP和UDP的socket服务开发. 我们下面编写四个类 1.用于接收数据的服务器端Socket

  • Netty序列化深入理解与使用

    目录 序列化与反序列化 序列化模式 其他对象序列化方式 使用json协议实现对象的传输 MessagePack编码器 在Netty框架中使用 序列化与反序列化 序列化:把对象转换成字节的过程,称为对象序列化 反序列化:把字节恢复成对象的过程,称为反序列化 对象的持久化概念:把字节保存的硬盘上永久的存放 网络传输对象概念:客户端将对象序列化为字节(序列化),变成二进制的形式发送到服务器端端,服务器端接受到字节对象后,反序列化成对象 注意序列化的类必须要实现 Serializable 接口, tra

  • Netty与NIO超详细讲解

    目录 Linux下的五种I/O模型 阻塞IO的流程 IO复用 信号驱动I/O 异步IO NIO I0多路复用 NIO核心组件 使用Java原生API实现NIO操作 Redis为什么支持高并发 Linux下的五种I/O模型 1)阻塞I/O(blocking I/O) 2)非阻塞I/O (nonblocking I/O) 3) I/O复用(select 和poll) (I/O multiplexing) 4)信号驱动I/O (signal driven I/O (SIGIO)) 5)异步I/O (a

  • Netty粘包拆包及使用原理详解

    目录 为什么使用Netty框架 Netty框架介绍 Netty实战 Netty编写服务器端 Netty客户端 粘包与拆包 为什么使用Netty框架 NIO的类库和API繁杂,使用麻烦,你需要熟练掌握Selector.ServerSocketChannel.SocketChannel.ByteBuffer等. 需要具备其他的额外技能做铺垫,例如熟悉Java多线程编程.这是因为NIO编程涉及到 Reactor 模式,你必须对多线程和网路编程非常熟悉,才能编写出高质量的NIO程序. 可靠性能力补齐,工

  • Netty网络编程零基础入门

    目录 OSI七层网络模型 Socket技术 TCP协议 Java语言创建socket应用 http协议 OSI七层网络模型 应用层:Http协议.文件服务器.邮件服务器 表示层:数据转换解决不同系统中间通讯的兼容问题 会话层:建立与应用程序的会话连接(socket) 传输层:提供端口号(区分不同的应用程序)和传输的协议(TCP和UDP) 网络层:为数据实现路由(路由器.交换机) 数据链路层:对传输的地址的帧以及错误的检测. 物理层:以二进制的形式在物理机器.上实现传输.(光纤.专线.各种物理介质

  • VUE零基础入门axios的使用

    目录 一.axios是什么 二.axios的特点 三.axios怎么安装 四.在VUE全局挂载 导入 挂载 使用 五.axios便捷方法 六.axios基础方法 七.axios执行结果 八.config axios 配置 九.restFul 九.如何审查元素 一.axios是什么 axios是一款ajax请求工具,是一个用于发送ajax请求的HTTP库,本质上是对AJAX的封装.而且Axios支持 Promise操作, 让我们无需再使用传统callback方式来进行异步编程.(Promise 是

  • C++中的STL中map用法详解(零基础入门)

    目录 一.什么是 map ? 二.map的定义 2.1 头文件 2.2 定义 2.3 方法 三.实例讲解 3.1 增加数据 3.2 删除数据 3.3 修改数据 3.4 查找数据 3.5 遍历元素 3.6 其它方法 四.总结 map 在编程中是经常使用的一个容器,本文来讲解一下 STL 中的 map,赶紧来看下吧! 一.什么是 map ? map 是具有唯一键值对的容器,通常使用红黑树实现. map 中的键值对是 key value 的形式,比如:每个身份证号对应一个人名(反过来不成立哦!),其中

  • PyTorch零基础入门之构建模型基础

    目录 一.神经网络的构造 二.神经网络中常见的层 2.1 不含模型参数的层 2.2 含模型参数的层 (1)代码栗子1 (2)代码栗子2 2.3 二维卷积层 stride 2.4 池化层 三.LeNet模型栗子 三点提醒: 四.AlexNet模型栗子 Reference 一.神经网络的构造 PyTorch中神经网络构造一般是基于 Module 类的模型来完成的,它让模型构造更加灵活.Module 类是 nn 模块里提供的一个模型构造类,是所有神经网络模块的基类,我们可以继承它来定义我们想要的模型.

  • PyTorch零基础入门之逻辑斯蒂回归

    目录 学习总结 一.sigmoid函数 二.和Linear的区别 三.逻辑斯蒂回归(分类)PyTorch实现 Reference 学习总结 (1)和上一讲的模型训练是类似的,只是在线性模型的基础上加个sigmoid,然后loss函数改为交叉熵BCE函数(当然也可以用其他函数),另外一开始的数据y_data也从数值改为类别0和1(本例为二分类,注意x_data和y_data这里也是矩阵的形式). 一.sigmoid函数 logistic function是一种sigmoid函数(还有其他sigmo

  • Spring零基础入门IOC

    目录 1.HelloSpring 2.IOC创建对象方式 2.1.通过无参构造方法来创建 2.2.通过有参构造方法来创建 1.HelloSpring 导入Jar包 <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.2.0.RELEASE</version> </de

  • Bootstrap零基础入门教程(三)

    什么是 Bootstrap? Bootstrap 是一个用于快速开发 Web 应用程序和网站的前端框架.Bootstrap 是基于 HTML.CSS.JAVASCRIPT 的. 历史 Bootstrap 是由 Twitter 的 Mark Otto 和 Jacob Thornton 开发的.Bootstrap 是 2011 年八月在 GitHub 上发布的开源产品. 写到这里,这篇从零开始学Bootstrap(3)我想写以下几个内容: 1. 基于我对Bootstrap的理解,做一个小小的总结.

  • Bootstrap零基础入门教程(二)

    什么是 Bootstrap? Bootstrap 是一个用于快速开发 Web 应用程序和网站的前端框架.Bootstrap 是基于 HTML.CSS.JAVASCRIPT 的. 历史 Bootstrap 是由 Twitter 的 Mark Otto 和 Jacob Thornton 开发的.Bootstrap 是 2011 年八月在 GitHub 上发布的开源产品. 本文重点给大家介绍Bootstrap零基础入门教程(二),具体详情如下所示: 过程中会频繁查阅资料的网站: http://www.

  • Django零基础入门之调用漂亮的HTML前端页面

    引言:    Django如何调用HTML前端页面呢? Django怎样去调用漂亮的HTML前端页面呢? 就直接使用render方法即可! render方法是django封装好用来调用HTML前端模板的方法! 1.模板放在哪? 在主目录下创建一个templates目录用来存放所有的html的模板文件.(如果是使用pycharm创建django项目的话,默认就会自动创建这个目录哦!但是用命令创建django项目的话是没有此目录的!) templates目录里面再新建各个以app名字命名的目录来存放

  • Django零基础入门之路由path和re_path详解

    目录 urls.py文件中的path和re_path 1.path的基本规则: 2.默认支持的转换器有: 3.re_path正则匹配: Django中实战使用path和re_path 1.urls.py文件: 2.views.py视图函数文件: 3.效果: 假设现在有个需求:   需要通过URL进行参数传递,我们该怎么做呢?     其中有个方法就是本文要讲的内容--path和进阶版的re_path. urls.py文件中的path和re_path 1.path的基本规则: path('test

随机推荐