当前位置: 首页 > news >正文

Linux性能优化--性能工具:网络

7.0 概述

本章介绍一些在Linux上可用的网络性能工具。我们主要关注分析单个设备/系统网络流量的工具,而非全网管理工具。虽然在完全隔离的情况下评估网络性能通常是无意义的(节点不会与自己通信),但是,调查单个系统在网络上的行为对确定本地配置和应用程序的问题是有帮助的。此外,了解单系统的网络流量特性也有助于找到其他有问题的系统,以及造成网络性能降低的本地硬件和应用程序错误。
阅读本章后,你将能够:

  1. 确定系统内以太网设备的速度和双工设置(mii-tool、ethtool)。
  2. 确定流经每个以太网接口的网络流量(ifconfig、sar、gkrellm、iptraf、netstat、
    etherape)。
  3. 确定流入和流出系统的IP流量的类型(gkrellm、iptraf、netstat、etherape)。
  4. 确定流入和流出系统的每种类型的IP流量(gkrellm、iptraf、etherape)。
  5. 确定是哪个应用程序产生了IP流量(netstat)。

7.1网络I/O介绍

Linux和其他主流操作系统中的网络流量被抽象为一系列的硬件和软件层次。链路层,也就是最低一层,包含网络硬件,如以太网设备。在传送网路流量时,这一层并不区分流量类型,而仅仅以尽可能快的速度发送和接收数据(或帧)。
链路层的上面是网络层。这一层使用互联网协议(IP)和网际控制报文协议(ICMP)在机器间寻址并路由数据包。IP/ICMP尽其最大努力尝试在机器之间传递数据包,但是它们不能保证数据包是否能真正达到其目的地。
网络层的上面是传输层,它定义了传输控制协议(TCP)和用户数据报协议(UDP)。TCP是一个可靠协议,它可以保证消息通过网络送达,如果消息无法送达它就会产生一个错误。TCP的同级协议UDP,则是一个不可靠协议,它无法保证信息能够送达(为了获得最高的数据传输速率)。UDP和TCP为IP增加了“服务”的概念。UDP和TCP接收有编号“端口”的消息。按照惯例,每个类型的网络服务都被分配了不同的编号。例如,超文本传输协议(HTTP)通常为端口80,安全外壳(SSH)通常为端口22,文件传输协议(FTP)通常为端口23。在Linux系统中,文件/etc/services定义了全部的端口以及它们提供的服务类型。
最上一层为应用层。这一层包含了各种应用程序,它们使用下面各层在网络上传输数据包。这些应用程序包括:Web服务器、SSH客户端,甚至是P2P文件共享客户端,比如BitTorrent。
在Linux内核实现或控制的是最低三层(链路层、网络层和传输层)。内核可以提供每层的性能统计信息,包括数据流经每一层时的带宽使用情况信息和错误计数信息。本章介绍的工具就能使你提取并查看这些统计信息。

7.1.1链路层的网络流量

在网络层次结构的最低几层,Linux可以侦测到流经链路层的数据流量的速率。链路层,通常是以太网,以帧序列的形式将信息发送到网络上。即便是其上层次的信息片段的大小比帧大很多,链路层也会将它们分割为帧,再发送到网络上。数据帧的最大尺寸被称为最大传输单位(MTU)。你可以使用网络配置工具,如ip或ifconfig来设置MTU。对以太网而言,最大大小一般为1500字节,虽然有些硬件支持的巨型帧可以高达9000字节。MTU 的大小对网络效率有直接影响。链路层上的每一个帧都有一个小容量的头部,因此,使用大尺寸的MTU就提高了用户数据对开销(头部)的比例。但是,使用大尺寸的MTU,每个数据帧被损坏或丢弃的几率会更高。对清洁物理链路来说,大尺寸MTU通常会带来更好的性能,因为它需要的开销更小;反之,对嘈杂的链路来说,更小的MTU则通常会提升性能,因为,当单个帧被损坏时,它要重传的数据更少。
在物理层,帧流经物理网络,Linux内核可以收集大量有关帧数量和类型的不同统计数据:

  1. 发送/接收–如果一个帧成功地流出或流入机器,那么它就会被计为一个已发送或已接收的帧。
  2. 错误–有错误的帧(可能是因为网络电缆坏了,或双工不匹配)。
  3. 丢弃–被丢弃帧的(很可能是因为内存或缓冲区容量小)。
  4. 溢出–由于内核或网卡有过多的帧,因此被网络丢弃的帧。通常这种情况不应该
    发生。
  5. 帧–由于物理级问题导致被丢弃的帧。其原因可能是循环冗余校验(CRC)错误或
    其他低级别的问题。
  6. 多播–这些帧不直接寻址到当前系统,而是同时广播到一组节点。
  7. 压缩–一些底层接口,如点对点协议(PPP)或串行线路网际协议(SLIP)设备在把帧发送到网络上之前,会对其进行压缩。该值表示的就是被压缩帧的数量。
    有些Linux网络性能工具能够显示通过每一个网络设备的每一种类型的帧数。这些工具通常需要设备名,因此,熟悉Linux如何对网络设备命名以便搞清楚哪个名字代表了哪个设备是很重要的。以太网设备被命名为ethN,其中,eth0指的是第一个设备,eth1指的是第二个设备,以此类推。与以太网设备命名方式相同,PPP设备被命名为pppN。环回设备,用于与本机联网,被命名为lo。
    在调查性能问题时,非常关键的一点是要清楚底层物理层能够支持的最大速度。比方说,以太网设备通常支持多种速度,如10Mbps、100Mbps,甚至是1000Mbps。底层以太网卡和基础设施(交换机)必须能控制所需的速度。虽然大多数网卡可以自动检测能支持的最高速度,并进行适当地自我设置,但是,如果一个网卡或交换机设置错误,就会影响到性能。如果不能达到更高的速度,以太网设备一般会协商降低速度,但它们仍然是起作用的。假如网络性能大大低于预期,那么最好使用工具ethtool或mii-tool来检验以太网速度是否设置为你的期望值。

7.1.2协议层网络流量

对TCP或UDP流量而言,Linux使用套接字/端口来抽象两台机器的连接。当与远程机器连接时,本地应用程序用一个网络套接字来打开远程机器上的一个端口。如前所述,常见网络服务都有约定的端口号,因此,给定的应用程序就能连接到远程机器的正确端口上。比如,端口80通常用于HTTP。在加载一个Web页面时,浏览器就连接到远程机器的80端口上。远程机器上的Web服务器监听80端口上的连接,当连接发生时,Web服务器就为Web页面的传输设置该连接。
Linux网络性能工具可以跟踪流经特定网络端口的数据量。由于每个服务的端口号具有唯一性,因此有可能确定流向特定服务的物理流量。

7.2 网络性能工具

本节介绍能够诊断性能问题的Linux网络性能工具。我们先从确定最底层网络性能(物理统计信息)的工具开始,然后逐步增加可以调查其上各层的工具。

7.2.1mii-tool(媒体无关接口工具)

mii-tool是以太网专用硬件工具,主要用于设置以太网设备,但它也可以提供有关当前设置的信息。这个信息,诸如链接速度和双工设置,对于追踪性能不佳设备的成因是非常有用。

7.2.1.1网络I/O性能相关的选项

使用mii-tool时需要根访问权限。其调用命令行如下:
mii -tool [-v] [device]
mii -tool输出指定设备的以太网设置。如果没有指定设备,那么mii -tool就会显示所有可用以太网设备的信息。若使用了-v选项,mii -tool将显示被提供或协商的网络功能的详细信息。

7.2.1.2 用法示例

清单7.1显示的是系统上eth0的配置信息。第一行告诉我们网络设备正在使用100BASE-T全双工连接。接下来的几行描述了机器网卡的功能,以及该网卡检测到的线路另一端网络设备的功能。
在这里插入图片描述
mii-tool提供了关于如何配置以太网设备物理层的底层信息。

7.2.2 ethtool

在配置和显示以太网设备统计数据方面,ethtool提供了与mii-tool相似的功能。不过,ethtool更加强大,包含了更多配置选项和设备统计信息。

7.2.2.1网络I/O性能相关的选项

ethtool在使用时需要根访问权限,其调用使用如下命令行:
ethtool [device]
ethtool输出给定的以太网设备的配置信息。如果没有特别指定设备,ethtool就会输出系统中所有以太网设备的统计信息。ethtool的主页详细说明了修改当前以太网设置的选项。

7.2.2.2用法示例

清单7.2显示了系统内eth0的配置信息。虽然该设备支持多种不同的速度和链接设置,但它当前连接到的是一个全双工,1000Mbps的链路。
在这里插入图片描述
ethtool运行简单,它能迅速提供配置不当的网络设备的有关信息。

7.2.3 ifconfig(接口配置)

ifconfig的主要工作就是在Linux机器上安装和配置网络接口。它还提供了系统中所有网络设备的基本性能统计信息。ifconfig几乎在所有联网的Linux机器上都是可用的。

7.2.3.1网络I/O性能相关的选项

ifconfig用如下命令行调用:
ifconfig [device]
如果没有指定设备,ifconfig就会显示所有活跃的网络设备。表7-1解释了ifconfig提供的性能统计项。
在这里插入图片描述
尽管ifconfig主要用于网络配置,但由它提供的适当数量的统计信息也能使你确定系统中每一个网络设备的健康和性能状况。

7.2.3.2用法示例

清单7.3显示了来自系统所有设备的网络性能统计信息。这里,我们有一个以太网卡(eth0)和一个环回(lo)设备。本例中,以太网卡接收数据量约为790Mb,发送数据量约为319Mb。在这里插入图片描述
ifconfig提供的统计数据显示的是自系统启动开始的累计数值。如果你将一个网络设备下线,之后又让其上线,其统计数据也不会重置。如果你按规律的间隔来运行ifconfig,就可以发现各种统计数据的变化率。这一点可以通过watch命令或shell脚本来自动实现,这两种方式我们将在下一章讨论。

7.2.4 ip

一些网络工具,如ifconfig,正在被淘汰,取而代之的是新的命令:ip。ip不仅可以让你对Linux联网的多个不同方面进行配置,还可以显示每个网络设备的性能统计信息。

7.2.4.1网络I/O性能相关的选项

提取性能统计数据时,用如下命令行调用ip:
ip -s [-s] link
如果你用上述选项调用ip,它就会输出系统中所有网络设备的统计信息,包括环回(lo)设备和简单互联网转换(sit0)设备。设备sit0允许将IPv6的数据包封装到IPv4的数据包中,并保持下来,这样可以缓解IPv4和IPv6之间的转换。如果ip中还有一个-s,它将会提供底层以太网更加详细的统计信息。表7-2对ip提供的部分性能统计信息进行了说明。
在这里插入图片描述
ip是一个非常灵活的Linux网络配置工具,虽然它的主要功能是对网络进行配置,但你也可以用它来提取底层设备的统计数据。

7.2.4.2用法示例

清单7.4给出了系统中所有设备的网络性能统计信息。这里,我们有一个以太网卡,一个环回设备,和sit0通道设备。本例中,以太网卡接收数据大约为820Mb,发送数据大约为799Mb。
在这里插入图片描述
在这里插入图片描述
与ifconfig非常相似的是,ip提供的是自系统启动开始的总的系统统计数据。如果使用watch(下一章讨论),你就可以监控这些数值是如何随着时间发生变化的。

7.2.5sar(IV)

前面的章节已经讨论过,sar是最灵活的Linux性能工具之一。它可以监控许多不同的事情,归档统计数据,甚至还能用其他工具可用的格式来显示信息。sar并不能总是与专门领域性能工具一样来提供尽可能多的详细信息,但它能给出一个很好的总体概况。
网络性能统计信息并无不同。和ip以及ifconfig一样,sar提供了链路级的网络性能数据。但是,它同时还提供了一些关于传输层打开的套接字数量的基本信息。

7.2.5.1网络I/O性能相关的选项

sar使用如下命令行来收集网络统计信息:
sar [-N DEVIEDEVISOCKIFULL] [DEVICE] [interval] [count]
sar收集多种不同类型的性能统计数据。表7-3解释了一些命令行选项,sar使用它们来显示网络性能统计信息。
在这里插入图片描述
表7-4给出了sar提供的网络性能选项。
在这里插入图片描述
考虑到sar能收集到全部统计信息,它确实为单点提供了最系统级的性能统计数据。

7.2.5.2用法示例

在清单7.5中,我们查看了系统中所有网络设备的发送和接收统计信息。就像你能看到的,设备eth0是最活跃的。在第一个采样,eth0每秒接收的数据大约为63000字节(rxbyt/s),发送的数据大约为45000字节(txbyt/s)。未发送或接收压缩数据包(txcmp、rxcmp)。(压缩数据包通常出现在SLIP或PPP连接中)。
在这里插入图片描述
在这里插入图片描述
在清单7.6中,我们查看了系统中开放套接字的数量。我们可以看到开放套接字以及TCP、RAW和UDP套接字的总数。sar还能显示IP数据包分片的数量。
在这里插入图片描述
sar提供了对系统性能的一个很好的概览。但是,当我们要调查一个性能问题时,我们实际上想要了解的是哪些进程或服务消耗了特定的资源。sar不会提供这方面的详细信息,但它确实让我们观察到了整个系统的网络I/O统计信息。

7.2.6gkrellm

gkrellm是一个图形化监视器,它使你能够观察到多种不同的系统性能统计信息。它为各种统计信息绘制图表,包括CPU使用情况、磁盘I/O,以及网络使用情况。它可以通过“主题”来改变外观,甚至可以使用插件来监控默认版本中不包含的事件。
gkrellm提供的信息与sar、ip和ipconfig类似,但与它们不同的是,它提供的是数据的图形视图。此外,它还提供流经特定UDP和TCP端口流量的有关信息。这是我们看到的第一个可以显示具有不同网络带宽消耗量的服务的工具。

7.2.6.1网络I/O性能相关的选项

gkrellm用如下命令行调用:
gkrellm
gkrellm没有命令行选项用于配置其监控的统计信息。启动gkrellm之后,所有的配置都是图形化的。调出配置界面有两种方法:你可以右键点击gkrellm标题栏并选择Configuration,或者当光标在窗口的任何位置时按下F1。这两种操作都可以调出配置窗口(如图7-1所示)。
在这里插入图片描述
图7-2显示的是网络配置窗口。它用于配置哪些统计信息以及哪些服务显示在gkrellm 的最终输出窗口。
在这里插入图片描述
你可以将gkrellm配置为监控特定范围TCP端口的活动。这样你就能够监控服务,如HTTP或FTP,使用的确切端口,并测量它们使用的带宽量。在图7-2中,我们将gkrellm 配置为监控被BitTorrent(BT)P2P应用和Web服务器(HTTP)使用的端口。
gkrellm是一个灵活而强大的图形化性能监控工具。它使你能够观察到当前系统的执行情况,以及其性能随时间的变化。使用gkrellm最困难的地方在于阅读小的默认文本。不过,gkrellm的外观定制起来很容易,因此我们也可以推测这个缺点修正起来也比较容易。

7.2.6.2用法示例

如前所述,gkrellm可以监控多种不同类型的事件。在图7-3中,我们对输出进行了选择,因此只显示了与网络流量及其使用有关的统计数据。
从图7-3中可以看到,顶部的两个图是端口的使用带宽(BT 和HTTP),端口已经在配置部分进行了设置,底部的两个图则分别是两个设备(eth0和lo)的统计数据。图中可见,有少量BitTorrent(BT)流量,但是没有Web服务器流量(HTTP)。以太网设备eth0之前有一些大的活动,但是现在已经平静下来。eth0 中较浅的阴影部分表示的是接收的字节数,而较深的阴影部分表示的是发送的字节数。
gkrellm是一个功能强大的图形化工具,利用它可以一眼就判断出系统的状态。
在这里插入图片描述

7.2.7iptraf

iptraf是一个实时网络监控工具。它提供了相当多的模式来监控网络接口和流量。iptraf 是一种控制台应用程序,但其用户界面则是基于光标的一组菜单和窗口。
与本章前面所述其他工具一样,iptraf可以提供有关每个网络设备发送帧速率的信息。同时,它还能够显示TCP/IP数据包的类型和大小信息,以及哪些端口被用于网络流量。

7.2.7.1网络I/O性能相关的选项

iptraf用如下命令行调用:
iptraf [-d interface] [-s interface] [·t ]
如果调用iptraf时不带参数,就会显示一个菜单,让你选择监控界面以及想要监控的信息类型。表7-5对命令行选项进行了说明,这些选项用于观察特定接口或网络服务上的网络流量。
在这里插入图片描述
iptraf还有更多模式和配置选项。详细信息请参阅其附带文档。

7.2.7.2 用法示例

当用如下命令行调用iptraf时,它创建的输出如图7-4所示:
[rootewintermute tmp]# iptraf -d etho ·t 1
这条命令指定iptraf显示以太网设备eth0的详细信息并在运行1分钟后退出。此例中,我们可以看到网络设备eth0的接收速率为186.8kbps,发送速率为175.5kbps。
在这里插入图片描述
图7-5所示的是下一条命令,它要求iptraf显示每个UDP和TCP端口上的网络流量信息。调用命令如下:
[rootewintermute etherape·0.9.0]# iptraf -s etho -t 10
因为常用服务的TCP和UDP端口是固定的,所以,你可以利用这些信息来确定每个服务处理了多少流量。图7-5显示,有29kb的HTTP数据从eth0发送出来,有25kb则被其接收。
在这里插入图片描述
由于iptraf是基于控制台的应用程序,因此,它不需求X服务器或X服务器库。即使iptraf不能用鼠标来控制,它也是易于使用和配置的。

7.2.8 netstat

netstat是一种基本的网络性能工具,它几乎出现在每一个联网的Linux机器上。可以用它抽取的信息包括:当前正在使用的网络套接字的数量和类型,以及有关流入和流出当前系统的UDP和TCP数据包数量的特定接口统计数据。它还能将一个套接字回溯到其特定进程或PID,这在试图确定哪个应用程序要对网络流量负责时是很有用的。

7.2.8.1网络I/O性能相关的选项

netstat用如下命令行调用:
netstat [-p] [-c] [-interfaces=] [-s] [-t] [-u] [-w]
如果netstat调用时不带任何参数,它将显示系统范围内的套接字使用情况以及Internet 域和UNIX域套接字的信息。(UNIX域套接字用于本机的进程通信。)为了能检索所有其可以显示的统计信息,需要从根目录运行netstat。表7-6中的命令行选项可以用于修改netstat 显示信息的类型。
在这里插入图片描述
netstat还可以使用其他未在表中列出的命令行选项,更多信息参见netstat帮助手册。

7.2.8.2用法示例

清单7.7要求netstat显示活跃的TCP连接并持续更新该信息。每一秒netstat都将显示新的TCP网络统计数据。netstat不允许设置监控时长,因此如果被杀死或中断(Ctrl-C),它就只能停止。
在这里插入图片描述
在这里插入图片描述
清单7.8再次要求netstat显示TCP套接字的信息,但是,这一次我们还要求它给出与该套接字相关的程序。本例中,我们可以看到应用程序SSH和mozilla-bin发起了TCP连接。
在这里插入图片描述
清单7.9要求netstat提供启动后系统已接收的UDP流量统计信息。
在这里插入图片描述
清单7.10要求netstat提供流经接口eth0的网络流量的相关信息。
在这里插入图片描述
netstat提供了大量的,与运行的Linux系统的套接字和接口相关的网络性能统计信息。它是唯一能将被使用套接字映射回其使用者进程PID的网络性能工具,因此,它是非常有用的。

7.2.9 etherape

etherape(基于Windows的网络工具etherman的双关语)为当前网络流量提供了可视化信息。默认情况下,它观察的是流经网络的全部网络流量,而不只是当前机器收发的那些包。不过,它也可以被配置为仅显示当前机器的网络信息。
etherape(界面和文档)不够完美,但它提供了独一无二的视图来显示网络是如何连接的、被请求服务的类型,以及哪些节点请求了服务。在ehterape创建的图中,节点代表的就是网络上的系统。通信的节点之间用线连接,节点间网络流量越大则线的规模也越大。当某个系统的网络使用量增加时,代表该系统的圆圈也会变大。不同系统之间的连线用不同的颜色来区分两者之间使用的通信协议。

7.2.9.1网络I/O性能相关的选项

etherape利用libpcap库来捕捉网络包,因此,它必须作为根用户运行。etherape用如下命令行调用:
etherape [-n] [-i ]
表7-7解释了部分命令行选项,它们可以用来改变etherape监控的接口,或者决定是否在每个节点上显示解析主机名。
在这里插入图片描述
总之,etherape的文档相当少。etherape说明页给出了一些可以改变其外观和行为的命令行,但是,最好的学习方法就是使用它。一般说来,etherape是网络可视化的相当不错的方法。

7.2.9.2用法示例

图7-6显示的是etherape对一个相对简单的网络的监控。如果我们匹配一下协议的颜色
在这里插入图片描述
与最大圆圈的颜色,我们会发现该节点产生了大量的SSH流量。从图上来看,要确定哪个节点导致了这些SSH流量是很困难的。虽然没有显示,如果我们双击这个大圆圈,etherape 就会新建一个窗口来显示与该流量相关的节点的统计信息。我们可以用这些信息来调查网络流量的每个生成者以及它们的节点名称。
etherape的输出会周期性的更新。如果网络流量发生了变化,则图形就会更新。观察网络流量发现它是如何使用的,以及如何随时间变化,是一件非常有趣的事情。

7.3 本章小结

本章的主要内容是如何使用Linux网络性能工具来监控从底层网络接口到高层应用,流经整个系统的网络流量。本章首先介绍的工具可以查询当前物理链接设置(mii-tool、ethtool),以及监控流经底层接口数据包的类型和数量(ifconfig、ip、sar、gkrellm、iptraf、netstat、etherape)。接着介绍的工具可以显示不同类型的IP流量(gkrellm、iptraf、netstat、etherape)和每种流量的数量(gkrellm、iptraf、etherape)。本章还介绍了一种工具(netstat)用来将IP套接字的使用映射到接收/发送每种类型流量的进程上。最后,本章给出了一个网络可视化工具,它可以将流经网络的数据类型和数量与其流经节点之间的关系可视化(etherape)。
下一章将会介绍几个常用的Linux工具,它们能让性能工具的使用变得更加容易。这些工具本身不是性能工具,但是,它们使得使用性能工具变得更加容易接受。同时,它们有助于把工具得到的结果进行可视化和分析,并且还可以把更多的重复性任务进行自动化。

相关文章:

Linux性能优化--性能工具:网络

7.0 概述 本章介绍一些在Linux上可用的网络性能工具。我们主要关注分析单个设备/系统网络流量的工具,而非全网管理工具。虽然在完全隔离的情况下评估网络性能通常是无意义的(节点不会与自己通信),但是,调查单个系统在网络上的行为对确定本地配置和应用程…...

【Linux】线程互斥与同步

文章目录 一.Linux线程互斥1.进程线程间的互斥相关背景概念2互斥量mutex3.互斥量的接口4.互斥量实现原理探究 二.可重入VS线程安全1.概念2.常见的线程不安全的情况3.常见的线程安全的情况4.常见的不可重入的情况5.常见的可重入的情况6.可重入与线程安全联系7.可重入与线程安全区…...

敏捷开发中,Sprint回顾会的目的

Sprint回顾会的主要目的是促进Scrum团队的学习和持续改进。在每个Sprint结束后,团队聚集在一起进行回顾,以达到以下目标: 识别问题: 回顾会允许团队识别在Sprint(迭代)期间遇到的问题、挑战和障碍。这有助于…...

排序【七大排序】

文章目录 1. 排序的概念及引用1.1 排序的概念1.2 常见的排序算法 2. 常见排序算法的实现2.1 插入排序2.1.1基本思想:2.1.2 直接插入排序2.1.3 希尔排序( 缩小增量排序 ) 2.2 选择排序2.2.1基本思想:2.2.2 直接选择排序:2.2.3 堆排序 2.3 交换排序2.3.1冒…...

人大与加拿大女王大学金融硕士项目——立即行动,才是缓解焦虑的解药

!在这个经济飞速的发展的时代,我国焦虑症的患病率为7%,焦虑已经超越个体范畴,成为整个社会与时代的课题。焦虑,往往源于我们想要达到的,与自己拥有的所产生的差距。任何事情,开始做远比准备做更会给人带来成…...

老卫带你学---leetcode刷题(46. 全排列)

46. 全排列 问题: 给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1:输入:nums [1,2,3] 输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]示例 2&#x…...

6.6 图的应用

思维导图: 6.6.1 最小生成树 ### 6.6 图的应用 #### 主旨:图的概念可应用于现实生活中的许多问题,如网络构建、路径查询、任务排序等。 --- #### 6.6.1 最小生成树 **概念**:要在n个城市中建立通信联络网,则最少需…...

100问GPT4与大语言模型的关系以及LLMs的重要性

你现在是一个AI专家,语言学家和教师,你目标是让我理解语言模型的概念,理解ChatGPT 跟语言模型之间的关系。你的工作是以一种易于理解的方式解释这些概念。这可能包括提供 例子,提出问题或将复杂的想法分解成更容易理解的小块。现在…...

Linux:mongodb数据逻辑备份与恢复(3.4.5版本)

我在数据库aaa的里创建了一个名为tarro的集合,其中有三条数据 备份语法 mongodump –h server_ip –d database_name –o dbdirectory 恢复语法 mongorestore -d database_name --dirdbdirectory 备份 现在我要将aaa.tarro进行备份 mongodump --host 192.168.254…...

凉鞋的 Godot 笔记 109. 专题一 小结

109. 专题一 小结 在这一篇,我们来对第一个专题做一个小的总结。 到目前为止,大家应该能够感受到此教程的基调。 内容的难度非常简单,接近于零基础的程度,不过通过这些零基础内容所介绍的通识内容其实是笔者好多年的时间一点点…...

数据结构 - 4(栈和队列6000字详解)

一:栈 1.1 栈的概念 栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原…...

MySQL InnoDB引擎深入学习的一天(InnoDB架构 + 事务底层原理 + MVCC)

目录 逻辑存储引擎 架构 概述 内存架构 Buffer Pool Change Buffe Adaptive Hash Index Log Buffer 磁盘结构 System Tablespace File-Per-Table Tablespaces General Tablespaces Undo Tablespaces Temporary Tablespaces Doublewrite Buffer Files Redo Log 后台线程 事务原…...

TX Text Control .NET Server for ASP.NET 32.0 Crack

TX Text Control .NET Server for ASP.NET 是VISUAL STUDIO 2022、ASP.NET CORE .NET 6 和 .NET 7 支持,将文档处理集成到 Web 应用程序中,为您的 ASP.NET Core、ASP.NET 和 Angular 应用程序添加强大的文档处理功能。 客户端用户界面 文档编辑器 将功能…...

Leetcode刷题详解——将x减到0的最小操作数

1. 题目链接:1658. 将 x 减到 0 的最小操作数 2. 题目描述: 给你一个整数数组 nums 和一个整数 x 。每一次操作时,你应当移除数组 nums 最左边或最右边的元素,然后从 x 中减去该元素的值。请注意,需要 修改 数组以供接下来的操作…...

精选免费热门api接口分享

IP归属地-IPv4城市级:根据IP地址查询归属地信息,支持到城市级,包含国家、省、市、和运营商等信息。IP归属地-IPv6城市级:根据IP地址(IPv6版本)查询归属地信息,支持到中国大陆地区(不…...

androidx.appcompat.widget.Toolbar最右边设置控件不能仅靠最右边

androidx.appcompat.widget.Toolbar最右边设置控件不能仅靠最右边 Android Toolbar左、中、右对齐-CSDN博客Android Toolbar左、中、右对齐默认的Android Toolbar中添加子元素view是从左到右依次添加。需要注意的是,Android Toolbar为自身的…...

Springboot整合WebSocket实现浏览器和服务器交互

Websocket定义 代码实现 引入maven依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId></dependency>配置类 import org.springframework.context.annotation.Bean;i…...

这些 channel 用法你都用起来了吗?

channel 是什么&#xff1f; channel 是GO语言中一种特殊的类型&#xff0c;是连接并发goroutine的管道 channel 通道是可以让一个 goroutine 协程发送特定值到另一个 goroutine 协程的通信机制。 关于 channel 的原理&#xff0c;channel通道需要注意的地方&#xff0c;之前…...

纽交所上市公司安费诺宣布将以1.397亿美元收购无线解决方案提供商PCTEL

来源&#xff1a;猛兽财经 作者&#xff1a;猛兽财经 猛兽财经获悉&#xff0c;纽交所上市公司安费诺(APH)宣布将以每股7美元现金&#xff0c;总价格1.397亿美元收购无线解决方案提供商PCTEL(PCTI)。 该交易预计将在第四季度或2024年初完成。 Lake Street Capital Markets担任…...

二分查找算法(Python)

目录 1、概念 2、思路 3、实现算法 1、概念 二分查找又称折半查找&#xff0c;它是一种效率较高的查找方法 原理&#xff1a;首先&#xff0c;假设表中元素是按升序排列&#xff0c;将表中间位置记录的关键字与查找关键字比较&#xff0c;如果两者相等&#xff0c;则查找成…...

“第四十二天”

这个&#xff0c;之前用的b去存储a的总和和排名&#xff0c;后来在比较的过程中&#xff0c;只改变的b的值&#xff0c;却没有改变a的值&#xff0c;但在比较语文成绩的时候用的还是a&#xff0c;这个时候a和b同样是第i个对应的可能不是同一个对象了 &#xff0c;因为上面b的值…...

Qt/C++编写物联网组件/支持modbus/rtu/tcp/udp/websocket/mqtt/多线程采集

一、功能特点 支持多种协议&#xff0c;包括Modbus_Rtu_Com/Modbus_Rtu_Tcp/Modbus_Rtu_Udp/Modbus_Rtu_Web/Modbus_Tcp/Modbus_Udp/Modbus_Web等&#xff0c;其中web指websocket。支持多种采集通讯方式&#xff0c;包括串口和网络等&#xff0c;可自由拓展其他方式。自定义采…...

windows常用命令

一.文件操作 dir&#xff1a;查看文件当前路径目录列表 cd .. &#xff1a;返回上一级目录 cd 路径&#xff1a;进入路径...

数据结构--堆

一. 堆 1. 堆的概念 堆&#xff08;heap&#xff09;&#xff1a;一种有特殊用途的数据结构——用来在一组变化频繁&#xff08;发生增删查改的频率较高&#xff09;的数据集中查找最值。 堆在物理层面上&#xff0c;表现为一组连续的数组区间&#xff1a;long[] array &…...

Android12之报错 error: BUILD_COPY_HEADERS is obsolete(一百六十七)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 人生格言&#xff1a; 人生…...

vue前端中v-model与ref的区别

v-model <template><input type"text" v-model"message"> </template>作用&#xff1a;将输入框与message绑定&#xff0c;及将用户输入的内容绑定到message这个变量上&#xff0c;但是message是无法在script中获取到的&#xff0c;要想…...

探索未来:硬件架构之路

文章目录 &#x1f31f; 硬件架构&#x1f34a; 基本概念&#x1f34a; 设计原则&#x1f34a; 应用场景&#x1f34a; 结论 &#x1f4d5;我是廖志伟&#xff0c;一名Java开发工程师、Java领域优质创作者、CSDN博客专家、51CTO专家博主、阿里云专家博主、清华大学出版社签约作…...

Linux 系统安装 Redis7 —— 超详细操作演示!

内存数据库 Redis7 一、Redis 概述1.1 Redis 简介1.2 Redis 的用途1.3 Redis 特性1.4 Redis 的IO模型 二、Redis 的安装与配置2.1 Redis 的安装2.2 连接前的配置2.3 Redis 客户端分类2.4 Redis 配置文件详解 三、Redis 命令四、Redis 持久化五、Redis 主从集群六、Redis 分布式…...

首次建站用香港服务器有影响没?

​  对于首次租用香港服务器的朋友来说&#xff0c;难免会对它没有一个很清晰的认知。因此&#xff0c;本文就从香港服务器适用人群&#xff0c;以及建站影响&#xff0c;选择技巧上做一个全方位的解答。 1. 哪一类人群适合使用香港服务器建站? 做外贸业务的网站。香港走的国…...

大数据Flink(九十八):SQL函数的归类和引用方式

文章目录 SQL函数的归类和引用方式 一、SQL 函数的归类...