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

news2025/1/12 5:00:57

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工具,它们能让性能工具的使用变得更加容易。这些工具本身不是性能工具,但是,它们使得使用性能工具变得更加容易接受。同时,它们有助于把工具得到的结果进行可视化和分析,并且还可以把更多的重复性任务进行自动化。

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

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

相关文章

从零开始的LINUX(二)

1.alias: 用法:取别名,此时code1是code的别名,对code1进行操作和对code进行操作结果一致。 如果原本文件名不存在,仍可以正常运行指令,不会报错。 2.stat 显示指定文件或目录的状态、属性。 3.touch 当文件名不存在的…

基于SSM+Vue的日用品网站设计与实现

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:Vue 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目:是 目录…

数据结构复盘——第一章:绪论

文章目录 第一部分:数据的专业术语1、数据2、数据元素3、数据项4、数据对象5、数据类型6、抽象数据类型(ADT)第一部分习题第二部分:数据结构1、逻辑结构:2、存储结构(又称物理结构)︰3、运算:第二部分习题第三部分:算法1、算法的五个特性2、算法的设计五个要求第三部分习题…

antd的RangePicker设置默认值,默认近七天(andt+react)

import moment from "moment";state {initData:[moment().startOf(day).subtract(6, d), moment().endOf(day)], }<FormItem label"产生时间" {...tailItemLayout}>{getFieldDecorator("produceTime", {initialValue: initData})(<Ran…

C语言 形参、实参

定义 形参 形式上的参数&#xff0c;没有确定的值 实参 实际存在的&#xff0c;已经确定的参数&#xff0c;常量&#xff0c;变量&#xff0c;表达式&#xff0c;都是实参 区别 实参的值不随形参的变化而变化 在C语言中&#xff0c;数据传送是单向的&#xff0c;即只能把实…

【软考】14.2 统一建模语言UML/事务关系图

《统一建模语言UML》 可视化的建模语言&#xff0c;非程序设计语言UML的结构&#xff1a;构造块&#xff08;事物、关系、图&#xff09;、规则、公共机制 模型的事物 结构事物&#xff1a;静态行为事物&#xff1a;动态分组事物&#xff1a;组织注释事物&#xff1a;解释 事…

基于寄生捕食优化的BP神经网络(分类应用) - 附代码

基于寄生捕食优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码 文章目录 基于寄生捕食优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码1.鸢尾花iris数据介绍2.数据集整理3.寄生捕食优化BP神经网络3.1 BP神经网络参数设置3.2 寄生捕食算法应用 4.测试结果…

GPT绘制流程图咒语

【咒语】下面是我的一篇论文选取部分&#xff0c;为了让读者更好理解&#xff0c;我准备画一张图&#xff0c;请你阅读后为我设计一下这个图应该怎么画&#xff0c;更有说服力&#xff0c;更容易理解 论文片段&#xff1a; 多模态数据融合研究的基础在于有效的数据采集。首先&a…

DIY私人图床:使用CFimagehost源码自建无需数据库支持的PHP图片托管服务

文章目录 1.前言2. CFImagehost网站搭建2.1 CFImagehost下载和安装2.2 CFImagehost网页测试2.3 cpolar的安装和注册 3.本地网页发布3.1 Cpolar临时数据隧道3.2 Cpolar稳定隧道&#xff08;云端设置&#xff09;3.3.Cpolar稳定隧道&#xff08;本地设置&#xff09; 4.公网访问测…

12-网络篇-通信过程中的网络表

1.ARP表 主机1和主机2在同一个局域网内&#xff0c;通过之前的章节&#xff0c;我们知道在通信过程中&#xff0c;除了要知道对方的IP地址以外&#xff0c;我们还要知道对方的硬件地址&#xff0c;也就是Mac地址。而ARP协议就是为了解决此种问题。 ARP协议的用途是为了从网络层…

操作系统备考学习 day9 (3.1.1 ~ 3.1.11)

操作系统备考学习 day9 第3章 内存3.1 内存管理概念3.1.1 内存的基本知识指令的工作原理绝对装入可重定位装入动态运行时装入从写程序到程序运行链接的三种方式 3.1.2 内存管理概念内存空间的分配与回收内存保护 3.1.3 覆盖与交换覆盖技术交换技术 3.1.4 连续分配管理方式单一连…

用批处理连续ping一个ip段

今天写这个有一个原因&#xff0c;就是我家的网络用了一个无线电力猫做为无线网络扩展&#xff0c;但忘记了无线电力猫的IP&#xff0c;而且我家新路由器也看不到这个电力猫&#xff0c;也可能有一个原因。我原来用的是192.168.1.1的华为路由器&#xff0c;自然我就把这个无线电…

IDEA中明明导入jar包了,依旧报ClassNotFoundException

解决办法&#xff1a; 1.点击IDEA右上角的设置 2.点击Project Structure... 3.点击Artifacts,点击号把包添加下就可以了

Typora 导出PDF 报错 failed to export as pdf. undefined 解决方案

情况 我想把一个很大的markdown 导出为 248页的pdf 然后就报错 failed to export as pdf. undefined 原因 &#xff1a; 个人感觉应该是图片太大了 格式问题之类导致的 解决 文件 -> 偏好设置 - > 导出 -> pdf -> 自定义 -> 把大小全部改为24mm (虽然图中是32 …

Linux网络编程——套接字socket

文章目录 套接字创建套接字绑定套接字侦听接收请求建立连接 sockaddrsockaddr_insockaddr_un 地址转换函数字符串转in_addr的函数inet_aton 函数inet_pton 函数inet_addr 函数 in_addr转字符串的函数inet_ntoa 函数inet_ntop 函数 总结 套接字 Socket&#xff08;套接字&#…

【并发编程-1】多线程与并发设计

多线程介绍&#xff1a; 1、基础回顾&#xff1a; 线程状态&#xff1a; NEW-新建&#xff1a;创建了线程对象&#xff0c;还未开始执行。RUNNABLE-运行&#xff1a;线程对象已在java虚拟机运行&#xff0c;分为就绪&#xff08;Ready&#xff09;和运行中(Running)。BLOCKED-…

阵列信号处理_对比常规波束形成法(CBF)和Capon算法

空间谱估计 利用电磁波信号来获取目标或信源相对天线阵列的角度信息的方式&#xff0c;也称测向、波达方向估计&#xff08;DOA&#xff09;。主要应用于雷达、通信、电子对抗和侦察等领域。 发展 常规波束形成&#xff08;CBF&#xff09;。本质是时域傅里叶变换在空域直接…

双十一期间如何抢占流量,打造品牌爆款产品

进入10月末&#xff0c;也就进入了电商行业的大促流量红利期。如何提前规划大促期间&#xff0c;店铺流量扩张的计划&#xff0c;提前抢占流量&#xff0c;是每一个品牌方都需要考虑的问题。今天为大家分享下双十一期间如何抢占流量&#xff0c;打造品牌爆款产品&#xff01; 一…

复制粘贴,不如Ctrl+D~预制体和变体

复制并粘贴&#xff1a;Ctrl D 问题 当你Ctrl D复制粘贴出几个新物体时&#xff0c;你这时又去修改新物体&#xff0c;导致所有物体不一样该怎么办&#xff1f; 预制体的使用 使用预设体的好处&#xff1a;修改预设体的文件数值&#xff0c;会影响其对应的物体&#xff1…

Python下载与安装进阶

一.python下载&#xff0c;安装与常见问题 玩转python下载与安装 下载流程&#xff1a;在百度搜索“python”——》打开python官网 ——》选择python版本——>另存为python安装程序手动修改环境变量修改安装目录 1. 玩转python下载与安装 流程&#xff1a; 识别电脑的…