【网络协议详解】——RIP协议(学习笔记)

news2025/1/15 13:34:35

目录

  • 🕒 1. IP路由协议概述
    • 🕘 1.1 路由表
    • 🕘 1.2 路由的度量尺度/度量值
    • 🕘 1.3 路由管理距离
  • 🕒 2. RIP协议
    • 🕘 2.1 概述
    • 🕘 2.2 工作原理
  • 🕒 3. 报文格式
    • 🕘 3.1 RIP 协议报文
    • 🕘 3.2 RIP2 路由项
    • 🕘 3.3 RIP 请求报文
    • 🕘 3.4 RIP 鉴别报文
    • 🕘 3.5 报文发送
  • 🕒 4. 计数到无穷问题及协议改进
    • 🕘 4.1 计数到无穷
    • 🕘 4.2 改进:水平分割
    • 🕘 3.3 改进:触发更新
  • 🕒 5. 实验:静态路由和RIP配置
    • 🕘 5.1 静态路由
    • 🕘 5.2 RIP配置

🕒 1. IP路由协议概述

路由器接收到一个 IP 分组后:

  • 从分组首部提取目的 IP 地址,检测目的地址是否属于某个直连网络,若属于则直接发送;
    • 否则,在路由表中查找是否存在主机路由(静态或动态);
    • 否则,在路由表中查找匹配的路由;
    • 否则,在路由表中查找默认路由;
    • 否则,丢弃分组,向源主机发送 ICMP 差错报文;
  • 经过多次接力转发,分组可以从源主机传输到目的主机。

🕘 1.1 路由表

路由表为分组转发提供了到达目的地址的“最佳路径”。

路由项的基本信息:
<目的网络地址,下一跳地址,转发接口,路由代价>

Router#show ip route
Codes: C-connected, S-static, R-RIP, D-EIGRP,
EX-EIGRP external,O-OSPF, IA-OSPF inter area
E1-OSPF external type 1,E2-OSPF external type 2,
*-candidate default
Gateway of last resort is 10.5.5.5 to network 0.0.0.0
	172.16.0.0/24 is subnetted, 1 subnets
	C 172.16.11.0 is directly connected, serial1/2
	O 172.22.0.0/16 [110/20] via 10.3.3.3,01:03:01, Serial1/2
	S* 0.0.0.0/0 [1/0] via 10.5.5.5
  • “C”代表该路由信息来源是直连网段。
  • “O”代表该路由信息来源是通过OSPF动态路由协议。
  • “S”代表该路由信息来源是静态路由。
  • “172.22.0.0/16”表示其目标网段为172.22.0.0,其子网掩码为255.255.0.0。
  • “[110/20]”就是指管理距离/度量值,OSPF的管理距离为110, 其度量值为20
  • “10.3.3.3”是指数据包要想到达“172.22.0.0/16”的下一个转发路由器端口地址
  • “01:03:01”说明动态路由己学到该路由,且该路由已经存在1小时3分1秒
  • “Serial1/2”说明IP数据包将由本地路由Serial1/2接口发送出去。

路由表中的路由信息主要通过三种方式获得:

  • 添加直连路由:到达路由器直接连接网络的路由。
  • 添加静态路由:网络管理员手动添加的路由。
  • 计算动态路由:在路由协议控制下,路由器之间通过交换路由信息而自动建立的路由。

🕘 1.2 路由的度量尺度/度量值

  • 跳数(Hop Count):最常用的路由度量尺度。它是数据包从源到达目的地途中经过的路由器的数目
    • RIP路由选择协议就使用跳数度量值。
  • 可信度(Reliability):网络连接的可靠性指标链路的差错率。任何可靠性因素都能够影响可信度级别。
    • 可信度级别通常由网络管理员指定给网络连接。
  • 延时(Delay):延时是一种常用的有效度量尺度。它指数据包从源到达目的地所要求的时间
    • 延迟取决于多种因素,包括中继网络连接的带宽、路径上各路由器端口的数据包队列长度,中继网络连接的堵塞以及传输的物理距离
  • 带宽(Bandwidth):体现了网络连接可用的交通容量,链路的速度
    • 在所有其他条件相同的情况下,10Mbps以太网连接比64Kbps专线更可取。
    • 尽管带宽表明网络连接可达到的最大传输能力,但通过更大带宽连接的路由不一定比通过较慢连接的路由更好。
  • 负载(Load):负载指网络设备(如路由器)的繁忙程度。可以根据各种各样的参数来计算负载,包括CPU利用率和每秒被处理的包的数目
    • 对这些参数持续不断的监视也会加重设备本身的负担。
  • 通信代价(Communication Cost):又称为通信成本、通信开销等,也是一个重要的度量值。
    • OSPF协议就使用通信代价作为度量值。
  • 管理距离(Administrative Distance):是路由器用来评价路由信息可信度的一个指标,定义了路由来源的优先级别。

🕘 1.3 路由管理距离

管理距离是从0到255的整数值,对于每个路由来源,包括特定路由协议、静态路由又或是直连网络,使用管理距离值按从低到高的优选顺序来排定优先级。

  • 每个路由协议都有一个默认的信任等级。等级值越小,协议的信任度越高
  • 默认管理距离:
     路 由 来 源   管理距离   直连路由  0  以一个接口为出口的静态路由  0  以下一跳为出口的静态路由  1  EIGRP 的归纳路由 (Summary Route)  5  外部 BGP (EBGP) 路由  20  内部 EIGRP  90  IGRP  100  OSPF  110  IS-IS  115  RIP (V1 和 V2)  120  外部 EIGRP 路由  170  内部 BGP (IBGP) 路由  200  不可信路由  255 \begin{array}{|c|c|} \hline \text { 路 由 来 源 } & \text { 管理距离 } \\ \hline \text { 直连路由 } & 0 \\ \hline \text { 以一个接口为出口的静态路由 } & 0 \\ \hline \text { 以下一跳为出口的静态路由 } & 1 \\ \hline \text { EIGRP 的归纳路由 (Summary Route) } & 5 \\ \hline \text { 外部 BGP (EBGP) 路由 } & 20 \\ \hline \text { 内部 EIGRP } & 90 \\ \hline \text { IGRP } & 100 \\ \hline \text { OSPF } & 110 \\ \hline \text { IS-IS } & 115 \\ \hline \text { RIP (V1 和 V2) } & 120 \\ \hline \text { 外部 EIGRP 路由 } & 170 \\ \hline \text { 内部 BGP (IBGP) 路由 } & 200 \\ \hline \text { 不可信路由 } & 255 \\ \hline \end{array}       直连路由  以一个接口为出口的静态路由  以下一跳为出口的静态路由  EIGRP 的归纳路由 (Summary Route)  外部 BGP (EBGP) 路由  内部 EIGRP  IGRP  OSPF  IS-IS  RIP (V1  V2)  外部 EIGRP 路由  内部 BGP (IBGP) 路由  不可信路由  管理距离 00152090100110115120170200255

🕒 2. RIP协议

🕘 2.1 概述

RIP(Routing Information Protocol)即选路信息协议,是一种基于距离向量算法的动态路由选择协议,是内部网关协议IGP中最先得到广泛使用的协议之一。

  • 优点:简单
  • 缺点:适用于小型互连网

标准:

  • RFC 1058:RIP1
  • RFC 2453:RIP2,支持 CIDR、简单的鉴别及组播发送
  • RFC 2080:RIPng,支持 IPv6

特点:

  • RIP认为好的路由就是“距离短”的路由,也就是所通过路由器数量最少的路由
  • 当到达同一目的网络有多条“距离相等”的路由时,可以进行等价负载均衡

🕘 2.2 工作原理

距离

  • RIP要求自治系统AS内的每一个路由器都要维护从它自己到AS内其他每一个网络的距离记录。这是一组距离,称为“距离向量D-V(Distance-Vector)" 。

  • RIP使用跳数(Hop Count)作为度量(Metric)来衡量到达目的网络的代价(cost)

    • 路由器到直连网络的距离定义为1

    • 路由器到非直连网络的距离定义为所经过的路由器数加1
      在这里插入图片描述

    • 允许一条路径最多只能包含15个路由器。“距离”等于16时相当于不可达

路由表交换

  • RIP 协议规定,相邻路由器(通过同一网络连接的路由器)之间周期性交换各自的路由表
    • 路由表交换周期是 30 秒。
    • 周期性不是严格的:发送前附加一段随机延迟(0 到 5 秒)。
    • 原因:避免大量路由器同时发送路由表而造成网络拥塞。

报文发送

  • RIP 使用 UDP 协议进行路由信息交换。
  • RIP1 和 RIP2 使用 UDP 520 端口发送或接收 RIP 报文。

在这里插入图片描述
路由更新

  • 接收到邻居的路由表后,路由器采用距离向量算法更新自己的路由表。
  • 在下一个发送周期,路由器将更新后的路由表再发送给自己的邻居路由器。
  • 若网络拓扑结构不变,经过有限次的路由表交换后,所有 RIP 路由器都会获得到达自治系统中所有网络的最短路由。此时称路由协议收敛(convergence)。

在这里插入图片描述

RIP的路由条目的更新规则:

  • 发现了新的网络,添加
  • 到达目的网络,不同下一跳,新路由优势,更新
  • 到达目的网络,不同下一跳,等价负载均衡
  • 到达目的网络,相同下一跳,最新消息,更新
  • 到达目的网络,不同下一跳,新路由劣势,不更新

故障处理

  • 实际环境中,网络或路由器可能出现故障。
  • 从上一次接收到邻居路由器发送的路由表起,如果经过 180 秒还没有收到新的发送,就假定:
    • 连接邻居路由器的网络发生故障,或邻居路由器发生故障。(跳数置为15
  • 路由器立即更新自己与故障相关的路由表项,并在随后的发送周期中将新的路由表发送给邻居路由器。
    • 经过有限次的路由表交换后,RIP 协议将达到新的收敛状态。

RIP处理流程
在这里插入图片描述

🕒 3. 报文格式

🕘 3.1 RIP 协议报文

在这里插入图片描述

RIP 协议报文由固定首部路由项列表组成。

  • 固定首部包括3个字段,占4个字节。
  • 命令”字段指明发送该报文的目的,占1个字节。
    • 命令字段为1时是请求报文,表明请求接收方发送其全部或部分路由表;
    • 命令字段为2时是响应报文,表明报文携带有发送方的全部或部分路由表。响应报文可以是对请求报文的回应,也可以是发送方周期性的路由表发送。周期性发送也称为非请求响应。
  • 版本”字段指明RIP协议的版本号,占1个字节,RIP1协议设置为1,RIP2协议设置为2
  • 第三个字段没有使用,占2个字节,必须置为0
  • 路由项列表包括最多 25 个路由项。每个路由项描述了一条路由。

🕘 3.2 RIP2 路由项

在这里插入图片描述
路由项有固定的格式,占20个字节,分为6个字段。

  • 地址族标识符”字段指明了解释网络地址时应遵循的协议族,占2个字节。对IPv4协议,地址族标识符定义为2
  • 路由标记”字段占2字节,是分配给该路由项的一个属性值,主要用于区分内部RIP路由和外部RIP路由。内部RIP路由是来自自治系统内部RIP协议的路由;外部RIP路由是来自其他自治系统RIP协议的路由。例如可用自治系统编号作路由标记。路由器在向邻居通告一条路由时,必须保持该路由的标记不变。
  • 字段“IP地址”和“子网掩码”共同标识了该路由项的目的地址。如果IP地址字段是全0地址(0.0.0.0),表示是默认路由
  • 下一跳”字段指明了报文接收方路由器到达目的地址下一跳地址。如果是全0地址(0.0.0.0),表明报文接收方路由器到达目的地址的下一跳就是报文发送方路由器,其地址就是携带RIP报文IP分组的源地址
  • 距离”字段指明了从报文发送方路由器或下一跳字段地址到达目的地址路由的距离

🕘 3.3 RIP 请求报文

RIP 路由器可通过向邻居发送 RIP 请求报文的方式显式地请求其全部或部分路由表。

  • 全部路由表请求用于路由表建立:路由器启动时,可向邻居发送 RIP 请求报文,请求邻居将其整个路由表发送给自己。
    • 请求报文中只有 1 个路由项,且地址族标识符是 0、距离是无穷(16)。
    • 若路由数量超过一个 RIP 报文的携带能力,接收方可构造多个响应报文。
  • 部分路由表请求主要用于路由监测:请求方可以是一台能够发送、接收及处理 RIP 报文的主机(不参与 RIP 路由交换)。
    • 请求报文中的路由项列表列出了所请求的路由。
    • 构造响应报文时,接收方在其路由表中逐项查找相应路由项,若存在,就在距离字段填入其距离值;否则,在距离字段填 16

🕘 3.4 RIP 鉴别报文

RIP2 中路由器可对每个接收的报文进行鉴别(authentication)。

鉴别信息占用了第一个路由项20 字节:

  • 地址族标识符: 0xFFFF
  • 路由标记:命名为鉴别类型(authentication type),用于区分不同的鉴别机制。

RFC 2453 只定义了一种简单的密码鉴别:

  • 鉴别类型:2
  • 路由项中剩余的 16 字节包含了鉴别用的明文密码(若密码不足16字节,靠左对齐并补 0)。

🕘 3.5 报文发送

  • RIP1 中路由器用广播(broadcast)方式向邻居发送 RIP 报文。
  • RIP2 中路由器以组播(multicast)方式向邻居发送RIP报文。
    • 减少了对不参与 RIP 路由交换主机的影响;
    • 不需要组播管理协议(IGMP)的支持:只在相邻路由器间交换报文。

🕒 4. 计数到无穷问题及协议改进

🕘 4.1 计数到无穷

RIP 协议通过在邻居路由器之间周期性交换路由表达到收敛状态:

  • 周期约 30 秒
  • 收敛速度慢

网络发生故障时:

  • 存在"坏消息传播很慢"的问题,又称为路由环路(两个路由器相互学习错误路由,造成循环)或计数到无穷(counting to infinity)问题

在这里插入图片描述

  • 在图示的网络中,有四台路由器,A、B、C、D,其中C和D之间的网络代价(这里即跳数)是10,其余网络的代价都是1
  • 为了表述简单,只关注路由表中到达目标网络的路由表项。
  • 左侧的表格给出了各路由器到达目标网络的最优路由。

某时刻 B 和 D 之间的网络发生了故障,则到达目标网络应通过C和D之间的网络:
在这里插入图片描述

  • T0时刻,路由器B通过超时机制发现BD之间的网络发生故障,其将自己通过D到达目标网络的路由项设置为不可达(Unreachable)。但此时AC仍认为可通过B到达目标网络。
  • T1时刻,相邻路由器之间交换路由表,B接收到AC的路由表后,认为可通过AC到达目标网络(距离都是4;实际上不可能,因为通过AC到达目标网络又要经过B,而B无法到达目标网络。),表中B根据C发送的路由项更新了自己到达目标网络的路由项。A接收到BC的路由表后,根据距离向量算法,会选择通过C到达目标网络(通过B无法到达,通过C的距离是4)。C可以接收到ABD发送的路由表,C会选择通过A去往目标网络(通过B无法到达目标网络,通过D到达目标网络的距离是11,通过A到达目标网络的距离是4。)。
  • T2T7时刻的路由表交换与T1时刻类似,在此不再赘述。直到T8时刻,路由器C才找到正确的去往目标网络的路由(通过CD之间的网络)。在下一个交换周期,AB也找到了正确的路由。

在最坏的情况下,当网络实际不可达时,到达该网络路由的距离要增加到无穷(16),路由才会收敛,此称为计数到无穷问题

在这里插入图片描述

这是距离向量算法的一个固有问题,可以采取多种措施减少出现该问题的概率或减小该问题带来的危害。

因此,RIP协议中用于表示无穷的距离值不能太大,以便在发生故障情况下路由能尽快收敛。RIP中采用16表示无穷大,这是在网络直径与路由收敛速度之间的一个折中。

RIP协议采用水平分割技术和触发更新技术来尽量避免此类问题的发生。

🕘 4.2 改进:水平分割

前述例子中,路由收敛慢的原因在于路由器 A 和 C 之间形成了一个循环路由:各自以对方为到达目标网络的下一跳路由器。

路由器把从邻居学习到的路由再发送给邻居就有可能形成循环路由。

在这里插入图片描述
简单水平分割(simple split horizon):禁止将从邻居学习到的路由再回送给邻居。

  • 在刚开始形成环路时,双方就不再交换环路路由信息。
  • 环路路由最终将在超时机制下被丢弃。

带毒性逆转的水平分割(split horizon with positioned reverse):允许路由器在发送的路由表中包含从邻居学习到的路由,但将这些路由的距离置为无穷(16)。

  • 邻居能立即知道环路路由不可用,而不用等待路由超时后再丢弃。
  • 缺点:路由更新消息中包含了无效的路由项,增加了路由交换开销。

🕘 3.3 改进:触发更新

循环路由也可能存在于多个路由器之间。

  • 例如,路由器 A 认为到达某网络可经由路由器 B,B 认为可经由 C,而 C 又认为可经由 A。

水平分割技术只能避免在两个邻居路由器之间形成的环路,在这种情况下不起作用。
在这里插入图片描述

触发更新含义:

  • 任何时候,当更新了一条路由时,路由器就立即向其邻居发送路由更新消息,而不必等到下一个发送周期时再发送;
  • 邻居路由器更新路由表后,若存在改变的路由,也立即再向其邻居发送路由更新消息。

这种级联(cascading)的触发更新使路由变化尽快在网络中扩散开来,加速路由收敛

  • 在触发更新扩散路由信息的过程中,路由器也会进行正常的周期性路由表交换。
  • 如果触发更新尚未扩散到的路由器发送了正常的周期性路由交换消息,那些已经被触发更新影响的路由器有可能会重新采用旧的路由,从而再次建立循环路由。
  • 触发更新技术并不能完全避免循环路由问题。
  • 如果触发更新能在很短时间内完成路由信息的扩散,形成环路路由的可能性很低。

【2016年题37】假设R1、R2、R3采用RIP协议交换路由信息,且均已收敛。若R3检测到网络201.1.2.0/25不可达,并向R2通告一次新的距离向量,则R2更新后,其到达该网络的距离是()
A.2
B.3
C.16
D.17
在这里插入图片描述
解析:根据题目所给“R3检测到网络201.1.2.0/25不可达”可知,R3与该网络是直连的。

又根据题目所给“R1、R2、R3采用RIP协议交换路由信息,且均已收敛”可知,先前它们各自的路由表中关于该目的网络的路由条目分别是:
在这里插入图片描述

再根据题目所给“R3检测到网络201.1.2.0/25不可达,并向R2通告一次新的距离向量”可知,R3与该网络之间的链路出现了故障。当R3检测到该故障时,将自己到达该网络的路由条目中的距离修改为16,表示不可达。并向R2发送关于这条路由条目的通告。R2收到后将距离修改为16。在这里插入图片描述

最后根据题目所给“则R2更新后”可知,R1给R2发送了关于该路由条目的RIP更新报文,而R2听信了该谣言,误认为到达该目的网络可以通过R1的转发,距离为3。
在这里插入图片描述
因此选B。

🕒 5. 实验:静态路由和RIP配置

题目:R2为某公司总部,R1和R3是两个分部,主机PC1和PC2所在的网段分别模拟两个分部中的办公网络。现需要总部和各个分部,各个分部之间能够实现通信。分别使用静态路由和RIP路由协议实现需求。

在这里插入图片描述

设备名端口ip地址掩码默认网关
R1f2/0192.168.1.254255.255.255.0N/A
f0/010.1.1.1255.255.255.0N/A
R2f0/110.1.1.2255.255.255.0N/A
f0/010.1.2.1255.255.255.0N/A
R3f0/110.1.2.2255.255.255.0N/A
f2/0192.168.2.254255.255.255.0N/A
PC1E0192.168.1.1255.255.255.0192.168.1.254
PC2E0192.168.2.1255.255.255.0192.168.2.254

🕘 5.1 静态路由

实验步骤:

一、配置静态路由:R2上配置到192.168.1.0/24和192.168.2.0/24网段的静态路由。

R2(config)#ip route 192.168.1.0 255.255.255.0 10.1.1.1
R2(config)#ip route 192.168.2.0 255.255.255.0 10.1.2.2    

二、配置默认路由:R1和R3上配置默认路由。

R1(config)#ip route 0.0.0.0 0.0.0.0 f0/0
R3(config)#ip route 0.0.0.0 0.0.0.0 f0/1

三、查看路由配置情况

R1#show ip route 
R2#show ip route     
R3#show ip route

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

🕘 5.2 RIP配置

实验步骤:

一、在R1上配置RIP

# 启动RIP
R1(config)#router rip
# 指定RIP的版本
R1(config-router)#version 2
# 关闭路由聚合
R1(config-router)#no auto-summary
# 指定直连网段
R1(config-router)#network 192.168.1.0
R1(config-router)#network 10.1.1.0
# 指定被动接口
R1(config-router)#passive-interface f2/0

二、在R3上配置RIP

# 启动RIP
R3(config)#router rip
# 指定RIP的版本
R3(config-router)#version 2
# 关闭路由聚合
R3(config-router)#no auto-summary
# 指定直连网段
R3(config-router)#network 192.168.2.0
R3(config-router)#network 10.1.2.0
# 指定被动接口
R3(config-router)#passive-interface f2/0

三、在R2上配置RIP

# 启动RIP
R2(config)#router rip
# 指定RIP的版本
R2(config-router)#version 2
# 关闭路由聚合
R2(config-router)#no auto-summary
# 指定直连网段
R2(config-router)#network 10.1.1.0
R2(config-router)#network 10.1.2.0

四、查看路由信息

R1#show ip route 
R2#show ip route     
R3#show ip route 

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

五、抓包分析
在R1和R2的链路上启动抓包,在wireshark的显示过滤器设置过滤条件为rip.version==2

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

在这里插入图片描述


❗ 转载请注明出处
作者:HinsCoder
博客链接:🔎 作者博客主页

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

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

相关文章

【自动化测试】第一次项目实施

测试项目简介&#xff1a;基于python语言 跨平台的测试自动化工具&#xff0c;适用于后台、原生或混合型客户端应用的测试。它支持 Android、iOS、Web、后台、云服务和 Windows 端的 UI 自动化测试。 上手快&#xff0c;操作简单&#xff0c;只要有一点python基础&#xff0c…

5. 多线程并发锁

本文介绍了多线程并发下为了避免临界资源被抢占而出现的错误&#xff0c;引入了锁和原子操作 来解决。 一、问题分析 创建10个线程&#xff0c;每个线程实现往总进程加1万个数。则总进程会达到10万 #include<stdio.h> #include <unistd.h> #include<pthread.h…

路径规划算法:基于头脑风暴算法的路径规划算法- 附代码

路径规划算法&#xff1a;基于头脑风暴的路径规划算法- 附代码 文章目录 路径规划算法&#xff1a;基于头脑风暴的路径规划算法- 附代码1.算法原理1.1 环境设定1.2 约束条件1.3 适应度函数 2.算法结果3.MATLAB代码4.参考文献 摘要&#xff1a;本文主要介绍利用智能优化算法头脑…

强化学习-初步认识

前言 强化学习这个概念是2017年Alpha Go战胜了当时世界排名第一的柯洁而被大众知道&#xff0c;后面随着强化学习在各大游戏比如王者荣耀中被应用&#xff0c;而被越来越多人熟知。王者荣耀AI团队&#xff0c;甚至在顶级期刊AAAI上发表过强化学习在王者荣耀中应用的论文。 什么…

BEVDet4D 论文学习

1. 解决了什么问题&#xff1f; 单帧数据包含的信息很有限&#xff0c;制约了目前基于视觉的多相机 3D 目标检测方法的性能&#xff0c;尤其是关于速度预测任务&#xff0c;要远落后于基于 LiDAR 和 radar 的方法。 2. 提出了什么方法&#xff1f; BEVDet4D 将 BEVDet 方法从…

C++ Vecter

C Vecter &#x1f4df;作者主页&#xff1a;慢热的陕西人 &#x1f334;专栏链接&#xff1a;C &#x1f4e3;欢迎各位大佬&#x1f44d;点赞&#x1f525;关注&#x1f693;收藏&#xff0c;&#x1f349;留言 本博客主要内容讲解了C中vector的介绍以及相关的一些接口的使用 …

Prometheus+Grafana监控系统

一、简介 1、Prometheus简介 官网&#xff1a;https://prometheus.io 项目代码&#xff1a;https://github.com/prometheus Prometheus&#xff08;普罗米修斯&#xff09;是一个最初在SoundCloud上构建的监控系统。自2012年成为社区开源项目&#xff0c;拥有非常活跃的开发人员…

第二章 Electron自定义界面(最大化、最小化、关闭、图标等等)

一、介绍 &#x1f606; &#x1f601; &#x1f609; Electron是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架。 嵌入 Chromium 和 Node.js 到 二进制的 Electron 允许您保持一个 JavaScript 代码代码库并创建 在Windows上运行的跨平台应用 macOS和Linux——不需…

linux--systemd、systemctl

linux--systemd、systemctl 1 介绍1.1 发展sysvinitupstart主角 systemd 登场 1.2 简介 2 优点兼容性启动速度systemd 提供按需启动能力采用 linux 的 cgroups 跟踪和管理进程的生命周期启动挂载点和自动挂载的管理实现事务性依赖关系管理日志服务systemd journal 的优点如下&a…

GAMS建模技术案例01 求解简单的线性规划模型

目录 1.问题描述 2 GAMS代码要点 2.1 代码编写要点 2.2 案例源码 2.3 计算结果及报告解 1.问题描述 首先给出一个基本线性规划问题的计算案例 subject to: 2 GAMS代码要点 2.1 代码编写要点 使用 * 表示注释文本定义变量 Positive Variable 表示定义非负变量Negative V…

【经典论文】打通文本图像的里程碑--clip

Git&#xff5c;Paper&#xff5c;Colab&#xff5c; CLIP 论文逐段精读【论文精读】_哔哩哔哩_bilibili clip是openai团队在4亿对文本图像对上训练出来的。它的训练方法简单&#xff0c;但效果缺出奇的好。是打通图片文本的里程碑式的模型。 目录 一.模型结构​编辑 1.为…

“Shell“免交互

文章目录 一.免交互&#xff08;Here Document&#xff09;1.1Here Document 概述2.2Here Document 常规用法 二.Expect2.1Expect基本命令2.2Expect执行方式 一.免交互&#xff08;Here Document&#xff09; 1.1Here Document 概述 使用I/O重定向的方式将命今列表提供给交互式…

chatgpt赋能Python-pythonandor

Pythonandor&#xff1a;探索Python的异步编程方式 如果您是一个Python工程师&#xff0c;你可能已经听过Pythonandor。Pythonandor是一个Python异步框架&#xff0c;能够让你更高效地处理请求&#xff0c;并且提高应用程序的响应速度。 什么是Pythonandor? Pythonandor实际…

5。STM32裸机开发(4)

嵌入式软件开发学习过程记录&#xff0c;本部分结合本人的学习经验撰写&#xff0c;系统描述各类基础例程的程序撰写逻辑。构建裸机开发的思维&#xff0c;为RTOS做铺垫&#xff08;本部分基于库函数版实现&#xff09;&#xff0c;如有不足之处&#xff0c;敬请批评指正。 &…

一篇文章打好SQL基础,熟悉数据库的基础操作和方法,以及安装MySQL软件包和Python操作MySQL基础使用

1.SQL的概述 SQL的全称&#xff1a;Structured Query Language&#xff0c;结构化查询语言&#xff0c;用于访问和处理数据库的标准计算机语言。 SQL语言1974年有Boyce和Chamberlin提出的&#xff0c;并且首先在IBM公司研制的关系数据库系统SystemR上实现。 经过多年发展&am…

KVM(二)命令行新建虚拟机

目录 一、准备工作 二、新建虚拟机 2.1 文件准备 2.2 正式安装 2.3 时区设置 2.4 安装设置 2.5 设置root用户密码 2.6 vm2安装完成 三、进入虚拟机vm2 四、网络设置 五、参考链接 若还未部署KVM&#xff0c;请参考第一节&#xff1a; KVM&#xff08;一&#xff09;…

如何让你的 Jmeter+Ant 测试报告更具吸引力?

目录 引言 一、安装apache-Ant 二、Jmeter准备 3、生成测试报告 4、JMeter动态参数处理逻辑是什么&#xff1f; 5、JMeter是怎么做API自动化测试的&#xff1f; 结语 引言 想象一下&#xff0c;你辛苦搭建了一个复杂的网站&#xff0c;投入了大量的时间和精力进行开发和…

java 对接国标摄像头流程、代码整合 springboot SIP -GB2818

java 对接设备的代码资料较少&#xff0c;这里介绍GB2818的基本对接流程&#xff0c;有用自取&#x1f447; java负责SIP信令的注册交互&#xff0c;推流、拉流鉴权摄像头负责推流、流媒体负责拉流、转码 wvp-GB28181-pro项目 ,如果java对接各种摄像头&#xff0c;这个项目很&a…

Java流程控制(二)

⭐ 循环结构⭐ 嵌套循环⭐ break 语句和 continue 语句⭐ 方法⭐ 方法的重载(overload)⭐ 递归结构 ⭐ 循环结构 循环结构分两大类&#xff0c;一类是当型&#xff0c;一类是直到型。 &#x1f41f; 当型&#xff1a; 当布尔表达式条件为 true 时&#xff0c;反复执行某语句&a…

【eNSP】win11解决virtualbox5.2.44无法安装、不兼容的问题

问题描述&#xff1a; 本人大三学生一枚&#xff0c;这学期上计算机网络&#xff0c;老师要求安装华为eNSP软件&#xff0c;安装环节一切顺利&#xff0c;直到安装到依赖组件中VirtualBox-5.2.44时&#xff0c;发生了问题&#xff0c;Windows提示此应用无法在此设备上运行&…