【JavaEE网络】网络编程及其应用概述

news2024/12/25 12:24:12

目录

        • 面向字节流
          • 粘包问题
        • TCP异常情况
        • TCP/UDP对比
      • 网络层重点协议
        • IP协议
        • IP地址


面向字节流
粘包问题

在面向字节流的情况下,会产生一些其他的问题:粘包问题,这里“粘”的是“应用层数据报”,通过TCP read/write的数据,都是TCP报文的载荷,也就是应用层数据。
发送方一次性是可以发送多个应用层数据报的,但是接受的时候,如何区分,从哪里到哪里是一个完整的应用层数据报?如果没设计好,接收方就很难区分,甚至产生bug!

那么如何避免粘包问题呢?归根结底就是一句话,明确两个包之间的边界

在这里插入图片描述

此处正确的做法,是合理地设计应用层协议,这件事本身在传输层这边已经无解了,需要站在应用层的角度,来解决这个问题

1.应用层协议中,引入分隔符,区分包之间的边界。

比如\n

2.应用层协议中,引入"包长度”,也能区分包之闻的边界。

比如使用最开头固定的2个字节表示包的长度,0x0003aaa

粘包问题不仅仅是TCP才有的,只要是面向字节流的机制(文件)也有同样的问题,解决方案也都是一样。要么使用分隔符,要么使用长度

TCP异常情况

网络本身就会存在一些变数,导致TCP连接不能继续正常工作了。以下是出现那些情况时TCP如何处理使其正常

  1. 进程崩溃

进程就没了=>PCB没了=>文件描述符表也就被释放了=>相当于调用了socket.close(),socket在系统内核也是一个文件,也会被放到文件描述符表中=>崩溃的一方就会发出FIN,进一步触发四次挥手,此时连接就正常释放了。此时TCP的处理和进程正常退出没啥区别

  1. 主机关机(正常步骤的关机)

正常关机,就会先尝试干掉所有的进程(强制终止进程),就和上述所说的崩溃的处理是一样的。主机关机会有一定的时间,在这个时间内四次挥手可能是挥完的,如果没挥完也没事

  1. 主机掉电(拔电源,没有任何反应的机会)

电脑瞬间黑了,此时自然就没有任何可以操作的空间了。

在这里插入图片描述

此处就涉及到"心跳包”,B这边虽然是接收方,也会周期性的给对方发起一个 不携带任何 业务数据(载荷)TCP数据报

发起这个包的目的,就是为了触发ACK,就是确认一下A是否正常工作/确认网络是否畅通.

  1. 网线断开

相当于主机掉电的升级版。

此时A和B就无法通信了
A这边发生的情况,就是主机掉电的第一种情况
B这边发生的情况,就是主机掉电的第二种情况

以上 TCP 介绍的十个核心的特性

  1. 确认应答(可靠性)
  2. 超时重传(可靠性)
  3. 连接管理(可靠性)
  4. 滑动窗口(效率)
  5. 流量控制(可靠性)
  6. 拥塞控制(可靠性)
  7. 延时应答(效率)
  8. 捎带应答(效率)
  9. 面向字节流 => 粘包问题(编程注意事项目)
  10. 异常情况处理 => 心跳包(异常情况)
TCP/UDP对比

我们说了TCP是可靠连接,那么是不是TCP一定就优于UDP呢?TCP和UDP之间的优点和缺点,不能简单,绝对的进行比较

  • TCP用于可靠传输的情况,应用于文件传输,重要状态更新等场景;
  • UDP用于对高速传输和实时性要求较高的通信领域,例如,早期的QQ,视频传输等。另外UDP可以用于广播;

网络层重点协议

在复杂的网络环境中确定一个合适的路径。

IP协议

协议头格式如下:

在这里插入图片描述

  • 4位版本号(version):指定IP协议的版本,对于IPv4来说,就是4。现有的IP协议只有两个版本,IPV4,IPV6

  • 4位头部长度(header length):IP头部的长度是多少个32bit,也就是 length * 4 的字节数。4bit表示最大的数字是15,因此IP头部最大长度是60字节。

    IP报头是可变长的

    IP报头又是带有选项的

    此处单位也是4个字节

  • 8位服务类型(Type Of Service):3位优先权字段(已经弃用),4位TOS字段,和1位保留字段(必须置为0)。4位TOS分别表示:最小延时,最大吞吐量,最高可靠性,最小成本。这四者相互冲突,只能选择一个。对于ssh/telnet这样的应用程序,最小延时比较重要;对于ftp这样的程序,最大吞吐量比较重要。

    最小延时:传输一个数据报的时间尽量短
    最大吞吐量:一定时间内传输的数据量尽量多

    最高可靠性:在传输过程中最不容易触发丢包

    最小成本:在传输过程中消耗的硬件资源最低

  • 16位总长度(total length):IP数据报整体占多少个字节。IP报头 + 载荷 的长度

  • 16位标识(id):唯一的标识主机发送的报文。如果IP报文在数据链路层被分片了,那么每一个片里面的这个id都是相同的。

  • 3位标志字段:第一位保留(保留的意思是现在不用,但是还没想好说不定以后要用到)。第二位置为1表示禁止分片,这时候如果报文长度超过MTU,IP模块就会丢弃报文。第三位表示"更多分片",如果分片了的话,最后一个分片置为1,其他是0。类似于一个结束标记。

  • 13位分片偏移(framegament offset):是分片相对于原始IP报文开始处的偏移。其实就是在表示当前分片在原报文中处在哪个位置。实际偏移的字节数是这个值 * 8 得到的。因此,除了最后一个报文之外,其他报文的长度必须是8的整数倍(否则报文就不连续了)。

    16位标识、3位标志字段、13位分片偏移:描述了整个 IP 数据报拆包组包的过程

  • 8位生存时间(Time To Live,TTL):数据报到达目的地的最大报文跳数。一般是64。每次经过一个路由,TTL -= 1,一直减到0还没到达,那么就丢弃了。这个字段主要是用来防止出现路由循环。

  • 8位协议:表示上层(传输层)协议的类型。

  • 16位头部校验和:使用CRC进行校验,来鉴别头部是否损坏。

  • 32位源地址和32位目标地址:表示发送端和接收端。(数据部从哪来到哪去)

  • 选项字段(不定长,最多40字节):略。

IP地址

网络上有那么多主机,需要有办法描述主机的具体位置。IP地址就是解决这个问题的关键。

IP地址概念

IP地址(Internet Protocol Address)是指互联网协议地址,又译为网际协议地址。

IP地址作用

IP地址是IP协议提供的一种统一的地址格式,它为互联网上的每一个网络和每一台主机分配一个逻辑地址,以此来屏蔽物理地址的差异。

IP地址格式

IP地址是一个32位的二进制数,通常被分割为4个“8位二进制数”(也就是4个字节),如:01100100.00000100.00000101.00000110。

通常用“点分十进制”的方式来表示,即 a.b.c.d 的形式(a,b,c,d都是0~255之间的十进制整数)。如:100.4.5.6。

所谓的IP地址其实是一个32位的整数(4字节),表示方式:点分十进制。因为32位的方式表示很难记忆。点分十进制:使用三个.把32位分成4部分,每个部分就是8位,1字节,每个字节范围0-255(不带符号)

IP地址不够用了怎么办?[重点]

  1. 动态分配IP(DHCP)

你这个设备,不会一直需要上网,需要上网,就分配ip,不需要就先不分配。

这种方案,只能缓解,不能根治

  1. NAT机制(网络地址转换)(理解网络结构的重点)

只需要保证在我所在的局域网内不重复即可,在别的局域网也可以使用这样的IP地址。此时,大量的设备可以使用同样的IP了(但是是在不同局域网中),此时 IP 不够用问题就得到了很大的改善了

但还是想了别的办法。把IP地址分成两大类:

  1. 内网IP:不同的局域网内的设备,内网 IP 可以重复;同一个局域网内的设备,内网 IP 不能重复

10.*

172.16.~172.31.

192.168.*

以上三种开头的是内网IP

  1. 外网IP:外网IP不能重复

局域网之间如何通信?

  1. 如果局域网内部的设备之间进行通信,肯定是可以的(局域网内部 内网 ip 都是唯一的)
  2. A局域网中的设备,想和 B 局域网中的设备通信,这个时候咋办?(当前很可能这俩设备的 ip 相同)

当前的规则是禁止的!要想通信,就需要有一个带有外网 IP 的设备进行中转

  1. 局域网内部的设备访问带有外网 IP 的设备

像平时使用的电脑,手机,都是在局域网内部使用,他们会有一个内网 IP

还有一类设备,是“服务器”,服务器可以有外网 IP

这个过程中,就涉及到 NAT 工作过程了

在这里插入图片描述

NAT机制下,意义在于说,一个外网IP代表的不一定是一个设备了,而是很多设备

上述过程是简化的,不太严谨。真实情况是,我的电脑的数据经过我家路由器,会进行 NAT,经过电信光猫,又有 NAT,经过电信路由器又有 NAT,(每次经历路由器转发,都“可能”会触发 NAT 机制,至于是否触发,取决于路由器咋配置的)

NAT机制的缺点:

  1. 效率不高
  2. 非常繁琐
  3. 不方便直接访问局域网内的设备

NAT最大的优点:纯软件实现(省钱)

  1. IPv6(从根本上解决IP地址不够用的问题)

IPv4,是 4 个字节,32位,表示 IP 地址

IPv6,是 16 个字节,128 位,表示IP 地址

2^32=42亿左右

2^128次方=4个42亿相乘,这个数字足以支持我们把地球上的每一粒砂子都分配一个 IP 地址

但由于IPv4和IPv6不兼容,要想升级IPv6就要升级路由器设备=>花钱

相比之下,NAT方案只需要路由器开发商开发出新版本的软件(路由器固件),升级软件,即可直接支持(成本非常低的)

IP地址的组成

IP地址分为两个部分,网络号和主机号

网络号标识网段,保证相互连接的两个网段具有不同的标识;

主机号标识主机,同一网段内,主机之间具有相同的网络号,但是必须有不同的主机号;

通过合理设置网络号和主机号,就可以保证在相互连接的网络中,每台主机的IP地址都是唯一的。

  1. 同一个局域网中设备的 网络号 必须相同,主机号 必须不同
  2. 两个相邻的局域网,网络号必须不同

那么,如何划分网络号和主机号呢?

  1. 通过子网掩码识别

在这里插入图片描述

cmd后输入 ipconfig /all 就能找到

子网掩码和 IP 地址一样,也是 4 字节,32 位的整数。左侧必须是连续的 1,右侧必须是连续的 0

  1. 分类

过去曾经提出一种划分网络号和主机号的方案,把所有IP 地址分为五类

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1638968.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

jvm 马士兵 01

01.JVM是什么 JVM是一个跨平台的标准 JVM只识别class文件,符合JVM规范的class文件都可以被识别

javaScript 判断闰年

接受用户输入年份 如果是闰年就弹出闰年,遇到平年就是弹出平年 var a prompt(请输入年份);if(a%40&&a%100!0||a%4000){alert(闰年);}else{alert(平年);}

智慧校园为师生带来的那些帮助

随着互联网技术的发展,学校高度重视校园信息化建设,越来越多的学校开始建设智能校园。智慧校园是以智慧校园建设为基础,为学生的校园生活和学校的日常管理带来生机和活力。 那么,在当代环境下建设智慧校园的必要性是什么呢&#x…

Java集合框架-容器源码分析

Java集合框架-容器&源码分析 文章目录 Java集合框架-容器&源码分析[TOC](文章目录)前言一、集合框架概述二、Collection接口及其子接口(List/Set)及实现类2.1 Collection接口中方法2.2 遍历:Iterator迭代器接口&foreach(5.0新特性)2.3 Connection子接口…

Java中使用Redis实现分布式锁的三种方式

1. 导语 随着软件开发领域的不断演进,并发性已经成为一个至关重要的方面,特别是在资源跨多个进程共享的分布式系统中。 在Java中,管理并发性对于确保数据一致性和防止竞态条件至关重要。 Redis作为一个强大的内存数据存储,为在Java应用程序中实现分布式锁提供了一种高效的…

WSL2连接Windows主机的Mysql

文章目录 需求查看主机IP防火墙设置Mysql设置允许远程连接WSL2连接Mysql 需求 在WSL2(本机Ubuntu20.04)运行的程序需要将数据写入到本机的Mysql服务器中 查看主机IP 两种办法: Windows主机输入 ipconfig,找到带有WSL后缀的部分…

第13章 软件测评相关标准

一、标准化概述 (一)概念 1、标准 一定范围内获得最佳秩序,经协商一致并由公认机构批准共同使用和重复使用的一种规范性文档,是标准化活动的核心产物。 2、标准化 一定范围内获得最佳秩序,对现实问题和潜在问题制…

ctfshow——SSRF

文章目录 web 351web 352web 353web 354web 355web 356web357web 358web 359web 360 SSRF(Server-Side Request Forgery:服务器端请求伪造) 是一种由攻击者构造形成由服务端发起请求的一个安全漏洞。一般情况下,SSRF攻击的目标是从外网无法访问的内部系统…

Java | Leetcode Java题解之第64题最小路径和

题目: 题解: class Solution {public int minPathSum(int[][] grid) {if (grid null || grid.length 0 || grid[0].length 0) {return 0;}int rows grid.length, columns grid[0].length;int[][] dp new int[rows][columns];dp[0][0] grid[0][0]…

【C/C++基础实战】:用C++实现通讯录管理系统——含完整源码

文章目录 通讯录管理系统一、系统需求以及成品演示二、代码实现三、完整代码 通讯录管理系统 一、系统需求以及成品演示 1.1 系统需求 通讯录是一个可以记录亲人、好友信息的工具。这里利用C来实现一个通讯录管理系统 系统中需要实现的功能如下: 添加联系人&am…

【C语言】/*C语言常见概念*/

目录 前言 一、C语言是什么 二、初识编译和链接 三、什么是可执行程序 四、什么是编译器 五、什么是集成开发环境 六、mian函数的特点 七、什么是关键字 八、标识符的命名规则是什么 九、字符和ASCII码表 十、字符串和\0 十一、转义字符 十二、注释 前言 本篇文章…

[蓝桥杯2024]-PWN:fd解析(命令符转义,标准输出重定向,利用system(‘$0‘)获取shell权限)

查看保护 查看ida 这里有一次栈溢出,并且题目给了我们system函数。 这里的知识点没有那么复杂 方法一(命令转义): 完整exp: from pwn import* pprocess(./pwn) pop_rdi0x400933 info0x601090 system0x400778payloa…

力扣刷题第0天:只出现一次的数字

目录 第一部分:题目描述 ​第二部分:题目分析 第三部分:解决方法 3.1思路1: 双指针暴力求解 3.2 思路2:异或运算 第四部分:总结收获 第一部分:题目描述 第二部分:题目分析 由图片分析可得,该题目对算法时间复杂度有一定的要求时间复杂度为O(N)&a…

VBA数据库解决方案第十讲:Recordset记录集合的动态查询显示结果

《VBA数据库解决方案》教程(版权10090845)是我推出的第二套教程,目前已经是第二版修订了。这套教程定位于中级,是学完字典后的另一个专题讲解。数据库是数据处理的利器,教程中详细介绍了利用ADO连接ACCDB和EXCEL的方法…

爬虫学习:基本网络请求库的使用

目录 一、urllib网络库 1.urlopen()方法 2.request方法 二、requests网络请求库 1.主要方法 2.requests.get()和requests.post() 一、urllib网络库 1.urlopen()方法 语法格式: urlopen(url,data,timeout,cafile,capath,context) # url:地址 # data:要提交的数据…

编程题库-Python、Java、C++、C 应有尽有!!!

目录 网址注册账号题库 网址 传送门 http://oj.ecustacm.cn/ 这个↑链接是网站 注册账号 刚进去是这个页面 注册一个账号 题库 点击上方的问题菜单,进入题库 点击题目标题进入题目,我就随便点一道 这里面一般会有样例输入和输出以及题目描述 点…

网络安全 SQLmap-tamper的使用

目录 使用SQLmap Tamper脚本 1. 选择合适的Tamper脚本 2. 在命令行中使用Tamper脚本 3. 组合使用Tamper脚本 4. 注意和考虑 黑客零基础入门学习路线&规划 网络安全学习路线&学习资源 SQLmap是一款强大的自动化SQL注入和数据库取证工具。它用于检测和利用SQL注入漏…

# 从浅入深 学习 SpringCloud 微服务架构(七)Hystrix(3)

从浅入深 学习 SpringCloud 微服务架构(七)Hystrix(3) 一、hystrix:通过 Actuator 获取 hystrix 的监控数据 1、Hystrix 的监控平台介绍: 1)Hystrix 除了实现容错功能,Hystrix 还…

【JAVA基础之多线程】多线程案例以及自定义线程池

🔥作者主页:小林同学的学习笔录 🔥mysql专栏:小林同学的专栏 目录 1.多线程 1.1 概述 1.2 并发和并行 1.3 进程和线程 1.4 多线程的实现 1.4.1 继承Thread类 1.4.2 实现Runnable接口 1.4.3 实现Callable接口 1.4.4 总结 …

Flask 3 保姆级教程(一):快速上手

一、创建项目 PyCharm 中新建项目 创建完成后会出现这么个项目 以下是代码解析: # 导入了 Flask 类 from flask import Flask# 创建了一个 Flask web 应用的实例,并将其赋值给变量 app # __name__ 是一个特殊的 Python 变量,它表示当前模块…