【计算机网络笔记三】传输层

news2025/1/10 2:57:53

端口

在网络中如何标记一个进程?

  • TCP/IP 体系的传输层使用【端口号】来标记区分应用层的不同应用进程。
  • 这里说的端口是一个逻辑的概念,并不是实实在在的物理端口。
    在这里插入图片描述
    在这里插入图片描述

端口号使用 16 比特表示,取值范围是 0 ~ 65535,端口号分为以下三类:

  • ① 熟知端口号(用于服务端)
  • ② 登记端口号(用于服务端)
  • ③ 短暂端口号(用于客户端)

熟知端口号

熟知端口号或系统端口号,数值为 0 ~ 1023IANA 把这些端口号指派给了 TCP/IP 最重要的一些应用程序,让所有的用户都知道

当一种新的应用程序出现后,IANA 必须为它指派一个熟知端口,否则因特网上的其他应用进程就无法和它进行通信。

在这里插入图片描述

登记端口号

登记端口号,数值为 1024 ~ 49151,这类端口号是为没有熟知端口号的应用程序使用的。

使用这类端口号必须在 IANA 按照规定的手续登记,以防止重复,比如 Oracle 的默认端口号 1521MySQL 的默认端口号 3306Java WEBtomcat 的默认端口号 8080

短暂端口号

客户端使用的端口号,数值为 49152 ~ 65535

由于这类端口号仅在客户进程运行时才动态选择,因此又叫做短暂端口号。这类端口号是留给客户进程选择暂时使用的。理论上,不应为服务端分配这些端口,实际上,机器通常从1024起分配动态端口。

当服务器进程收到客户进程的报文时,就知道了客户进程所使用的端口号,因而可以把数据发送给客户进程。

通信结束后,刚才已使用过的客户端口号就不复存在,这个端口号就可以供其他客户进程重复使用

传输层协议

  • TCP: Transmission Control Protocol(传输控制协议
  • UDP: User Datagram Protocol (用户数据报协议
    在这里插入图片描述

每个协议都是为了解决一个具体特定的问题:

  • CSMA/CD 协议:协调总线上各计算机的工作
  • ARP 协议:根据 IP 得到对应主机网卡的 MAC 地址
  • IP 协议:解决多个异构网络的互连问题
  • ICMP 协议:为了更有效地转发 IP 数据报和提高交付成功的机会
  • TCP 协议:提供可靠的端到端数据的传输服务
  • UDP 协议:提供不可靠但是高效的传输服务

在这里插入图片描述
在这里插入图片描述

  • 应用层的 RIP DNS TFTP SNMP DHCP 等对应传输层的 UDP 协议,
  • 应用层的 SMTP FTP BGP HTTP HTTPS 等对应传输层的 TCP 协议
  • 在网络层的 IP 数据报中,有一个 协议字段 值是用来表示当前报文使用的传输层协议 ,它是一个数字

UDP VS TCP

UDP 的首部:

在这里插入图片描述

  • (1) 源端口: 源端口号。在需要对方回信时选用。不需要时可用全 0
  • (2) 目的端口: 目的端口号。这在终点交付报文时必须要使用到。
  • (3) 长度: UDP 用户数据报的长度,其最小值是 8(仅有首部)。

TCP 的首部:

在这里插入图片描述

TCP 的首部包含源端口、目的端口、序号(seq)、确认号(ack) 等。

在这里插入图片描述

  • UDP 是无连接的,TCP是面向连接的。

在这里插入图片描述

  • UDP 支持单播、多播、广播,TCP 仅支持单播

在这里插入图片描述

  • UDP 是面向应用报文的,对报文既不合并,也不拆分;TCP 是面向字节流的,这也是 TCP 实现可靠传输、流量控制、拥塞控制的基础。

  • 发送方的 TCP 将应用层交付下来的数据看成是一连串的、无结构的字节流TCP 将字节先存储在自己的缓存中,根据发送策略,先发送一部分字节;接收方提取字节,并存储在自己的缓存中;接收方的应用进程必须有能力识别收到的字节流,把它还原成有意义的应用数据。

在这里插入图片描述

  • UDP 向上层提供无连接不可靠的传输服务(适用于 IP 电话、视频会议等实时应用),TCP 向上层提供面向连接可靠的传输服务(适用于要求可靠传输的应用,例如文件传输)

总结:

在这里插入图片描述

TCP 首部

TCP 可靠传输的实现:

  • TCP 可靠传输使用 选择重传协议(SR) 来实现(两个滑动窗口:发送窗口+接收窗口
  • TCP 的滑动窗口是以字节为单位的
  • TCP 首部中和可靠传输相关的字段如下:
    在这里插入图片描述

序号(seq)字段:占 4 个字节

  • 也就是使用 32 个比特来编号,序号大小范围 [0, 2^32 - 1],共 2^32 个序号(即 4 294 967 296 个)。

  • 当序号增加到 2^32 - 1 后,下一个序号就又回到 0

  • TCP 是面向字节流的,在一个 TCP 连接中传送的字节流中的每一个字节都按顺序编号

  • 整个要传送的字节流的起始序号必须在连接建立时设置。

  • 首部中的 seq 字段值则指的是本报文段所发送的数据的第一个字节的序号

确认号(ack)字段:占 4 个字节

  • 表示期望收到对方下一个报文段的第一个数据字节的序号。
    在这里插入图片描述
  • 若确认号=N,则表明:到序号 N - 1 为止的所有数据都已正确收到。

ACK 字段 (Acknowledgement,确认):

  • 仅当 ACK=1 时确认号字段才有效。
  • 当 ACK = 0 时,确认号无效。
  • TCP 规定,在连接建立后所有传送的报文段都必须把 ACK 置 1。

窗口字段:占 2 字节

  • 窗口值是 [0, 2^16 - 1]之间的整数。

  • 窗口指的是发送本报文段的一方的接收窗口(而不是自己的发送窗口)。

  • 窗口值告诉对方:从本报文段首部中的确认号ack算起,接收方目前允许对方发送的数据量。之所以要有这个限制,是因为接收方的数据缓存空间是有限的。 (简单理解:我给你发数据,我会在数据中顺便告诉你,我的接收缓存区有多大,你再给我回复数据时,不给我超了范围)

  • 总之,窗口值作为接收方让发送方设置其发送窗口的依据。窗口值是经常在动态变化着。

TCP 三次握手

第一次握手:客户端 → 服务端

在这里插入图片描述

  • SYN = 1,表示这是一个 TCP 连接请求报文

  • 序号字段 seq 被设置为一个初始值 x,作为 TCP 客户进程所选择的初始序号

  • TCP 规定:SYN = 1 的报文段不能携带数据,但要消耗掉一个序号

第二次握手:服务端 → 客户端

在这里插入图片描述

  • SYN = 1,ACK = 1,表明这是一个对 TCP 连接请求的确认报文
  • 序号字段 seq 被设置为一个初始值 y,作为 TCP 服务进程所选择的初始序号(TCP 是全双工通信的,客户端和服务端都可以接发数据的)
  • ack = x + 1,这是对 TCP 客户进程所选择的初始序号的确认

第三次握手:客户端 → 服务端

在这里插入图片描述

  • ACK = 1,表明这是一个普通的确认报文段
  • seq = x + 1,是在上次选择的初始序号x的基础上加 1 作为本次的序号值
  • ack = y + 1,是对服务端初始序号的确认

三次握手之后,客户端和服务端的 TCP 连接已建立,就可以进行相互发送数据了:

在这里插入图片描述

为什么最后还要发送一个普通确认报文呢?

在这里插入图片描述

采用三报文握手,而不是两报文握手,来建立 TCP 连接,是为了防止已失效的连接请求报文段突然又到达了 TCP 服务器,此时服务端又会向客户端发送确认请求报文,而客户端因为是关闭状态无法响应服务端,则服务端会因为不知道客户端已经处于关闭状态,还在一直不停的给客户端发送确认请求报文,因而浪费服务器资源。

三次握手总结

  • 第一次握手:客户端发送 SYN = 1 seq = x 给服务端。

    SYN = 1 表示这是一个TCP连接请求报文

    seq = x 表示客户端进程使用序号 x 作为初始序号

    TCP规定:SYN 被设为1的报文不能携带数据,但要消耗一个序号。

  • 第二次握手:服务端发送 SYN = 1 ACK = 1 seq = y ack = x + 1 给客户端。

    SYN = 1 ACK = 1 表示当前报文是服务端对客户端前一次发送的连接请求报文的确认报文

    ack = x + 1 就是确认了客户进程上一次的起始序号 x,并且期望客户端下一次发送的报文的起始序号是 x + 1

    seq = y 则表示服务端进程选择 y 作为初始序号

    TCP 和 UDP 都是全双工通信的,客户端和服务端都可以收发数据。

  • 第三次握手:客户端发送 ACK = 1 seq = x + 1 ack = y + 1 给服务端。

    ACK = 1 表当前报文是对上一次的普通确认报文

    seq = x + 1 表示当前报文选择使用上次的初始序号x1,也就是服务端期望的序号

    ack = y + 1 表示确认服务端上一次报文发来的序号y,并期望服务端下一次发送报文的起始序号是 y + 1。

说人话版本的理解:

  • 第一次(我方):我请求(SYN = 1)当前使用起始序号 x (seq = x)
  • 第二次(对方):我确认收到你的请求(SYN = 1 ACK = 1),你下一次应该从 x + 1 序号开始(ack = x + 1),我请求当前使用起始序号 y (seq = y)
  • 第三次(我方):我确认收到你的回复(ACK = 1),你下一次应该从 y + 1 序号开始 (ack = y + 1),我当前使用你期望我发送的序号 x + 1seq = x + 1
    在这里插入图片描述

说骚话版本的理解:

在这里插入图片描述

互相伤害版本的理解:

在这里插入图片描述

为什么最后需要发送一次普通确认报文 / 为什么TCP需要三次握手而不是两次握手?

  • TCP是可靠的传输控制协议,而三次握手是保证数据可靠传输又能提高传输效率的最小次数。

为什么?RFC793,也就是TCP的协议,RFC中就谈到了原因,这是因为:

  1. 为了实现可靠数据传输, TCP协议的通信双方,都必须维护一个序列号, 以标识发送出去的数据包中,哪些是已经被对方收到的。

  2. 三次握手的过程即是通信双方相互告知序列号起始值,并确认对方已经收到了序列号起始值的必经步骤。如果只是两次握手, 至多只有连接发起方的起始序列号能够被确认, 而另一方选择的序列号则得不到确认。 至于为什么不是四次,很明显,三次握手后,通信的双方都已经知道了对方序列号起始值,也确认了对方知道自己序列号起始值,第四次握手已经毫无必要了。

  3. 为了防止已失效(如超时重传)的连接请求报文突然又到达了服务器,浪费服务器资源。 如果采用两次握手,则第一次请求之后,服务端就确认已建立连接,那么此时如果客户端关闭连接之后,服务端又收到了客户端之前已失效的 TCP 连接请求后,向客户端发送确认请求报文,此时客户端因为是关闭状态无法响应服务端,则服务端会因为不知道客户端已经处于关闭状态,还在一直不停的给客户端发送确认请求报文,导致浪费资源

TCP 四次挥手

TCP 释放连接过程

第一次挥手:

在这里插入图片描述

  • FIN = 1,表示是一个 TCP 释放连接请求报文
  • TCP 规定,FIN 报文段即使不携带数据,它也消耗掉一个序号。

第二次挥手:

在这里插入图片描述

根据 TCP 标准,前面发送过的 FIN 报文段要消耗一个序号,从 A 到 B 这个方向的连接就释放了,这时的 TCP 连接处于半关闭(half-close)状态,即 A 已经没有数据要发送了,但 B 若发送数据,A 仍要接收。也就是说,从 B 到 A 这个方向的连接并未关闭,这个状态可能会持续一些时间。

第三次挥手:

在这里插入图片描述

第四次挥手:

在这里插入图片描述

  • 注意:只有发起连接终止的一方会进入 TIME_WAIT 状态

有必要等待 2MSL 吗?

在这里插入图片描述

  • 如果客户端发送的确认服务端终止连接请求的报文丢失了,没有到达服务端,那么就会导致服务端由于迟迟得不到确认,反复不停的向客户端发送连接终止请求,从而导致服务端就一直无法进入 CLOSED 状态。

如果建立连接后,服务端进程挂了,会发生什么?

  • 如果建立连接后,服务端进程挂了,会给客户端发送一个 FIN 包,客户端回复一个 ACK 包,此时如果客户端继续向服务端写数据,服务端会回复一个 RST 包,然后终止。

    在这里插入图片描述

  • 如果服务端进程是因为断电挂了,则客户端向服务端继续写数据,会一直等待得不到任何响应,最终等待超时。客户端进程需要设置超时时间。

    在这里插入图片描述

  • 同理,如果是客户端进程挂了,服务端进程继续给客户端发送数据的响应情况跟上面类似,对调了一下

    在这里插入图片描述
    在这里插入图片描述

TCP 连接管理 — 保活计时器

在这里插入图片描述

  1. TCP 服务器进程每收到一次 TCP 客户进程的数据,就重新设置并启动保活计时器(2小时定时)

  2. 若保活计时器定时周期内未收到 TCP 客户进程发来的数据,则当保活计时器到时后,TCP服务器进程就向 TCP 客户进程发送一个探测报文段

  3. 以后每隔 75 秒钟发送一次,若一连发送了 10 个探测报文段后仍无 TCP 客户进程的响应,TCP 服务器进程就认为 TCP 客户进程所在主机出了故障,接着就关闭这个连接。

说白了,TCP 保活计时器就是一个超时等待的终止机制

四次挥手总结

  • 第一次:客户端发送 FIN = 1 ACK = 1 seq = u ack = v 给服务端。FIN = 1 表示这是一个 TCP 释放连接的请求报文

    TCP规定:FIN 报文段即使不携带数据,也消耗一个序号

  • 第二次:服务端发送 ACK = 1 seq = v ack = u + 1 给客户端。表示确认了客户端第一次的释放连接请求报文。

    此时 A → B 方向的连接释放了,TCP 处于半关闭状态虽然 B 确认了 A 不会再发送数据了,但 B 仍有可能给 A 发送数据

  • 第三次:服务端发送 FIN = 1 ACK = 1 seq = w ack = u + 1 给客户端,表示服务端释放连接的请求报文

  • 第四次:客户端发送 ACK = 1 seq = u + 1 ack = w + 1 给服务端。

    此时 A 也确认了 B 的关闭状态,B 直接进入关闭状态,A 进入 TIME_WAIT 等待状态,等待时长为 2MSL,即最长报文生命周期的 2 倍,如果这期间没有收到对方的报文,A 才最终进入关闭状态

一句话总结就是:双方都要发起连接终止请求,并且双方都要确认对方发来的连接终止请求。

客户端和服务端都可以发起 FIN 断开连接请求(TCP 是全双工的),但只有发起连接终止的一方会进入 TIME_WAIT 等待状态

在实际中第二次和第三次会合并为一次报文发送。

四次分手版本的理解:

在这里插入图片描述

为什么 TCP 的挥手需要四次?

  • TCP 是全双工的连接,必须两端同时关闭连接,连接才算真正关闭

    如果 A 已经准备关闭写,但是它还可以读 B 发送来的数据。此时,A 发送 FIN 报文给 B 收到后,B 回复 ACK 报文给 A。

    当 B 也准备关闭写,发送 FIN 报文给 A,A 回复 ACK 给 B。此时两端都关闭了,TCP 连接才正常关闭。

    所以对全双工模式来说,为了彻底关闭,就需要通信两端的 4 次交互才行互相确认对方的关闭状态

为什么发起方要等待 2MSL ?/ 为什么要存在 TIME_WAIT 状态

  1. 保证可靠的终止 TCP 连接

    如果第四次客户端给服务端发送的确认报文丢失了,则服务端会因为没有收到确认报文超时重传 FIN 报文给客户端

    但是如果此时客户端处于关闭状态,就会无法响应服务端了,那么服务端就会一直在重传 FIN 报文,也就是说服务端一直得不到确认,最终会无法进入 CLOSED 状态

  2. 保证让迟来的 TCP 报文有足够的时间被识别并丢弃

    在 Linux 中,一个 TCP 端口不能被同时打开多次,当一个 TCP 连接处于 TIME_WAIT 状态时,我们无法使用该连接的端口来建立一个新连接。

    反过来思考,如果不存在 TIME_WAIT 状态,则应用程序能够立即建立一个和刚关闭的连接相似的连接(这里的相似,是指他们具有相同的 IP 地址和端口号)。这个新的、和原来相似的连接被称为原来连接的化身。新的化身可能收到属于原来连接携带应用程序数据的 TCP 报文段(迟到的报文段),这显然是不该发生的。这就是 TIME_WAIT 状态存在的第二个原因。

如果建立连接后,TCP 某一端进程挂了,会发生什么?

  • 如果是服务端进程挂了,会给客户端发送一个FIN包,客户端回复一个ACK包,此时如果客户端继续向服务端写数据,服务端会回复一个RST包,然后终止。

  • 如果服务端进程是因为断电挂了,则客户端向服务端继续写数据,会一直等待得不到任何响应,最终等待超时。客户端进程需要设置超时时间。

  • 同理,如果是客户端进程挂了,服务端进程继续给客户端发送数据的响应情况跟上面类似,对调了一下。

  • 服务端如何检测客户端挂了:通过 TCP 保活计时器,类似超时等待 + 心跳机制。

TCP 粘包/拆包

TCP 是以流的方式来处理数据,一个完整的包可能会被 TCP 拆分成多个包进行发送,也可能把小的封装成一个大的数据包发送。

在这里插入图片描述

粘包

粘包就是一次接收到多个消息,应用进程无法从一个粘包中解析出数据。

出现粘包的原因:

  • ① 发送方每次写入数据 < 内核缓冲区大小

  • ② 接收方读取内核缓冲区不够及时

半包

半包就是一个消息分多次接收,应用进程无法从一个半包中解析出数据。

出现半包的原因

  • ① 发送方写入数据 > 内核缓冲区大小
  • ② 发送方数据大于 MTU(以太网大传输单元默认1500字节),必须拆包

解决方案

粘包和拆包的根本原因:TCP 是面向字节流的,消息无边界,应用进程无法从一个粘包和半包中解析出数据。但这不是 TCP 本身的问题,而是上层应用层需要处理的问题。

应用进程如何解读字节流呢?也就是如何解决粘包和半包问题?

解决粘包和拆包的根本手段:确定消息的边界

  • ① 固定长度
  • ② 分隔符
  • ③ 固定长度字段存储内容的长度信息
第一种方案:固定长度

即每次发送固定长度字节。 比如每 3 个字节表示一个消息:

在这里插入图片描述

这种方案简单,但是缺点是会浪费空间。 比如规定每10个字节表示一个消息,但是客户端发送的消息只包含1个字节,那么剩余9个字节就需要补空或者补0,浪费了。

第二种方案:分隔符

比如使用回车符(\n)作为分隔符:

在这里插入图片描述

再例如 HTTP 报文头中就使用了回车符、换行符作为 HTTP 协议的边界:

在这里插入图片描述

这种方案简单,空间也不浪费,但是缺点是如果消息内容本身出现分隔符时,需要转义,所以需要提前扫描内容。

在这里插入图片描述

第三种方案:固定长度字段存储内容的长度信息

即在消息头部附加一个固定长度的字段来存储本次消息内容的长度,例如在每个消息的头部使用固定4个字节的大小来表示消息内容的长度

在这里插入图片描述

在接收方解析时也是先读取固定长度的字段,获取长度,然后根据长度读取数据内容,精确定位数据内容,不需要转义。

缺点:数据内容长度有限制,需要提前知道最长消息的字节数。

一般这种方案是比较推荐的,但也要看场景,有时第一种和第二种会更简单。

理解 TCP 的面向字节流和网络字节顺序

理解 TCP 的面向字节流

在这里插入图片描述

应用进程在调用write()方法向socket发送数据时,数据并没有被真正从网络上发送出去,只是从应用程序拷贝到了内核缓冲区中,至于什么时候真正被发送,取决于发送窗口、拥塞窗口以及当前发送缓冲区的大小等条件。

在这里插入图片描述

而且,并不是每次调用 write() 发送的数据,都会作为一个整体完整地被发送出去。 数据会分几次分发送出去,也是不确定的。

但是 TCP 接收端的在读取字节时的顺序是保证跟发送时 write 的字节顺序一致的:

在这里插入图片描述

TCP 发送一个数据时可能会多次调用write发送小数据包:

在这里插入图片描述

那这两个数据包到底什么时候发送到网络上呢?这个取决于接收端的需求。

  • ① 如果接收端不允许延迟,那么发送端每次调用 write 的时候,就应该把数据包发送出去,不管数据包的大小。
  • ② 如果接收端允许一定时间的延迟,那么发送端可以再等待一定时间,将多个小数据包一起发送出去,这样可以减少网络中的包数量。

在这里插入图片描述

网络字节顺序

TCP 在发送字节流时如何决定先发送哪一个字节、后发送哪一个字节呢?

先了解下什么是主机的字节顺序:

  • 大端序(big endian):字节存储顺序按照从内存低地址到内存高地址的顺序存储
  • 小端序(little endian):字节存储顺序按照从内存高地址到内存低地址的顺序存储
    在这里插入图片描述

可以看到大端序更加符合人类的阅读直觉(从左往右读,从低往高存),但是对计算机来说,小端序往往更加容易处理。

另外,不同的 CPU 上运行不同的操作系统,字节序也是不同的,参见下表。

处理器操作系统字节排序
Alpha全部Little endian
HP-PANTLittle endian
HP-PAUNIXBig endian
Intelx86全部Little endian <-----x86系统是小端字节序系统
Motorola680x()全部Big endian
MIPSNTLittle endian
MIPSUNIXBig endian
PowerPCNTLittle endian
PowerPC非NTBig endian <-----PPC系统是大端字节序系统
RS/6000UNIXBig endian
SPARCUNIXBig endian
IXP1200 ARM 核心全部Little endian

网络协议采用的是大端序发送字节。

在这里插入图片描述

如果发送主机是采用的小端序,则发送数据前需要做小端序到大端序的转化,同样,如果接收方主机是采用小端序,读取数据后需要做大端序到小端序的转化。Linux 系统提供了一些函数可以直接调用来方便进行主机字节顺序和网络字节顺序的转换:

在这里插入图片描述

当使用这些函数时,我们并不需要关心主机到底是什么样的字节顺序,只要使用函数给定值进行网络字节序和主机字节序的转换就可以了。

如果发送字符的话,就不用考虑字节顺序的转换,因为每个字符只占用 1 个字节而已。

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

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

相关文章

「大数据-2.0」安装Hadoop和部署HDFS集群

目录 一、下载Hadoop安装包 二、安装Hadoop 0. 安装Hadoop前的必要准备 1. 以root用户登录主节点虚拟机 2. 上传Hadoop安装包到主节点 3. 解压缩安装包到/export/server/目录中 4. 构建软链接 三、部署HDFS集群 0. 集群部署规划 1. 进入hadoop安装包内 2 进入etc目录下的hadoop…

分享40个Python源代码总有一个是你想要的

分享40个Python源代码总有一个是你想要的 源码下载链接&#xff1a;https://pan.baidu.com/s/1PNR3_RqVWLPzSBUVAo2rnA?pwd8888 提取码&#xff1a;8888 下面是文件的名字。 dailyfresh-天天生鲜 Django-Quick-Start freenom-自动续期域名的脚本 Full Stack Python简体中…

竟然可以在一个项目中混用 Vue 和 React?

React和Vue是前端开发中的两大热门框架&#xff0c;各自都有着强大的功能和丰富的生态系统。然而&#xff0c;你有没有想过&#xff0c;在一个项目中同时使用React和Vue&#xff1f;是的&#xff0c;你没有听错&#xff0c;可以在同一个项目中混用这两个框架&#xff01;本文就…

redis学习(一)——初识redis

redis学习&#xff08;一&#xff09;——初识redis 非关系型数据库 redis是非关系型数据库&#xff0c;和mysql不同&#xff0c;redis中的所有数据都是以key&#xff1a;value形式存在的 两者区别 SQL | NoSQL 结构化 | 非结构化 关联的 | 无关联 sql查询 | 非sql ACI…

[python 刷题] 22 Generate Parentheses

[python 刷题] 22 Generate Parentheses 题目&#xff1a; Given n pairs of parentheses, write a function to generate all combinations of well-formed parentheses. 这里 well-formed 指的就是合法的括号配对&#xff0c;这里会提两个解 第一个是暴力解&#xff0c;也就…

服务注册发现_服务发现Discovery

修改payment8001的Controller /*** 支付控制层*/ Slf4j RestController public class PaymentController {Autowiredprivate DiscoveryClient discoveryClient;GetMapping("/payment/discovery")public Object discovery(){// 获取所有微服务信息List<String>…

栈和队列2——队列的实现

栈和队列2——队列的实现 一&#xff0c;前言二&#xff0c;队列的定义三&#xff0c;队列的结构四&#xff0c;队列的实现4.1队列初始化4.2队列的销毁4.3队列的尾插4.4队列的删除4.5找队头的数据4.6找队尾的数据4.7判断为空4.8计算长度 五&#xff0c;小结 一&#xff0c;前言…

STL常用遍历,查找,算法

目录 1.遍历算法 1.1for_earch 1.2transform 2.常用查找算法 2.1find&#xff0c;返回值是迭代器 2.1.1查找内置数据类型 2.1.2查找自定义数据类型 2.2fin_if 按条件查找元素 2.2.1查找内置的数据类型 2.2.2查找内置数据类型 2.3查找相邻元素adjeacent_find 2.4查找指…

简易介绍如何使用拼多多商品详情 API。

拼多多&#xff08;Pinduoduo&#xff09;是中国一家快速发展的电商平台&#xff0c;为了帮助开发者更好地接入拼多多&#xff0c;平台提供了丰富的 API 接口供开发者使用&#xff0c;其中包括获取拼多多商品详情的 API。接下来&#xff0c;我们将介绍如何使用拼多多商品详情 A…

重学 HashMap

文章目录 1.从 Map 接口入手1.1 从 JDK 1.0 的 Dictionary\<K,V\> 抽象类讲起1.2 Map 接口中的集合视图又是怎样的&#xff1f;1.3 为什么 JDK 官方不推荐使用可变对象作为 Map 的键&#xff1f;1.4 为什么映射不应该将自己作为键&#xff0c;而可以作为值&#xff1f;1.…

python基于轻量级卷积神经网络模型开发构建眼疾识别系统

常见的眼疾包括但不限于以下几种&#xff1a; 白内障&#xff1a;白内障是眼睛晶状体变得模糊或不透明&#xff0c;导致视力下降。它通常与年龄相关&#xff0c;但也可以由其他因素引起&#xff0c;如遗传、外伤、糖尿病等。 青光眼&#xff1a;青光眼是一组引起视神经损伤的眼…

HTTP 协议的定义,工作原理,Fiddler的原理和使用,请求的内容

文章目录 一. HTTP协议是什么?1.HTTP工作原理2.HTTP协议格式2.1抓包工具的原理2.2抓包工具的使用2.3 HTTP协议的内容请求首行请求头(header)空行正文(body) 一. HTTP协议是什么? HTTP (全称为 “超文本传输协议”) 是一种应用非常广泛的 应用层协议. "超文本"是指…

异步电机直接转矩控制学习

导读&#xff1a;本期文章对异步电机直接转矩控制进行梳理。DTC包括转速外环、磁链观测器、滞环和电压矢量离线开关表。离线电压矢量开关表共分为两种&#xff1a;添加零矢量和未添加零矢量。 如果需要文章种的仿真模型&#xff0c;关注微信公众号&#xff1a;浅谈电机控制&am…

同城配送商城小程序的作用是什么

本地生活服务如餐饮、服装、鲜花、百货等产品都具备同城经营属性&#xff0c;在产品销售方面普遍是以实体店为主做三公里生意&#xff0c;而随着互联网线上深入&#xff0c;很多商家会通过进驻外卖平台获得生意&#xff0c;当然也有越来越多的商家选择自建商城完成品牌的配送平…

机器学习第十四课--神经网络

总结起来&#xff0c;对于深度学习的发展跟以下几点是离不开的: 大量的数据(大数据)计算资源(如GPU)训练方法(如预训练) 很多时候&#xff0c;我们也可以认为真正让深度学习爆发起来的是数据和算力&#xff0c;这并不是没道理的。 由于神经网络是深度学习的基础&#xff0c;学…

AIGC(生成式AI)试用 6 -- 桌面小程序

生成式AI&#xff0c;别人用来写作&#xff0c;我先用来写个桌面小程序。 桌面小程序&#xff1a;计算器 需求 Python开发图形界面&#xff0c;标题&#xff1a;计算器 - * / 基本运算计算范围&#xff1a;-999999999 ~ 999999999** 乘方计算&#xff08;例&#xff0c;2*…

c==ubuntu+vscode debug redis7源码

新建.vscode文件夹&#xff0c;创建launch.json和tasks.json {"version": "0.2.0","configurations": [{"name": "C/C Launch","type": "cppdbg","request": "launch","prog…

人工智能轨道交通行业周刊-第61期(2023.9.18-9.24)

本期关键词&#xff1a;焊线机器人、智能综合运维管理系统、信号平面图、铁路部门架构、书生浦语大模型 1 整理涉及公众号名单 1.1 行业类 RT轨道交通人民铁道世界轨道交通资讯网铁路信号技术交流北京铁路轨道交通网上榜铁路视点ITS World轨道交通联盟VSTR铁路与城市轨道交通…

确知波束形成matlab仿真

阵列信号处理中的导向矢量 假设一均匀线性阵列&#xff0c;有N个阵元组成&#xff0c;满足&#xff1a;远场、窄带假设。 图1. 均匀线性阵模型 假设信源发射信号&#xff0c;来波方向为 θ \theta θ&#xff0c;第一个阵元接收到的信号为 x ( t ) x(t) x(t)&#xff0c;则第…

mybatsi-MyBatis的逆向工程

mybatsi-MyBatis的逆向工程 一、前言二、创建逆向工程的步骤1.添加依赖和插件2.创建MyBatis的核心配置文件3.创建逆向工程的配置文件4.执行MBG插件的generate目标 一、前言 正向工程&#xff1a;先创建Java实体类&#xff0c;由框架负责根据实体类生成数据库表。 Hibernate是支…