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

【Linux笔记】防火墙firewall与相关实验(iptables、firewall-cmd、firewalld)

一、概念

1、防火墙firewall

Linux 防火墙用于控制进出系统的网络流量,保护系统免受未授权访问。常见的防火墙工具包括 iptablesnftablesUFW 和 firewalld。


  1. 防火墙类型

    • 包过滤防火墙:基于网络层(IP、端口、协议)过滤流量(如 iptables)。

    • 应用层防火墙:基于应用协议(如 HTTP、SSH)过滤流量(需结合代理或深度包检测)。

  2. 关键术语

    • 表(Table):规则集合,如 filter(过滤)、nat(地址转换)、mangle(包修改)。

    • 链(Chain):规则链,默认链包括 INPUT(入站)、OUTPUT(出站)、FORWARD(转发)。

    • 规则(Rule):定义匹配条件和动作(如允许 ACCEPT、拒绝 DROP)。

    • 区域(Zone)firewalld 的概念,定义不同网络环境(如 publichome)的安全级别。

  3. 状态检测

    • 跟踪连接状态(如 NEWESTABLISHED),允许响应流量自动放行。


2、iptables

iptables 是集成在 Linux 内核中的包过滤防火墙系统,它允许系统管理员配置规则集,以便控制网络数据包的进出和转发。iptables 通过定义一系列的规则来决定如何处理经过网络接口的数据包。这些规则可以基于数据包的来源、目的地、协议类型等多种条件来设置。

二、命令

1、搭建实验运行环境

(1)前提说明

防火墙命令相关实验我们准备三个虚拟机,请先自行克隆出来三个,分别命名为F1、F2、F3

其中,F1与F3相互沟通,F2是它们沟通的桥梁

主机名ip网络类型
F1192.168.76.10NAT
F2

192.168.76.20(NAT的)

192.168.194.20(Host-only的)

NAT + Host-only(仅主机)
F3192.168.194.30Host-only(仅主机)

ip项请务必清楚自己虚拟机在NAT和Host-only(仅主机) 这两个网络类型下的网段是什么,

这里说一下查看办法:

按图中步骤来:点击实验所需的三台主机中的其中一台,这里是F1;点编辑;点虚拟网络编辑器;进去后即可查看:

仅主机时的ip网段

NAT时的ip网段:

这里的都是博主自己的,你们的都可以按照这个办法来查询


(2)设置三台主机的网络类型

1)对于F1

F1用NAT模式,默认应该就是NAT模式,但还是建议去查看一下:

2)对于F2

F2有两个:

一个是默认自带的NAT

另一个是Host-only(仅主机)

  

3)对于F3

F3是Host-only(仅主机)

(3)设置IP等基础配置

IP地址的配置先前博客有讲过,这里不再赘述,简单过一遍。配置指令为nm-connection-editor

手动配置你们网段的IP地址即可,可以按照上面的表格:

来进行配置IP,注意,F2有两个网卡,需要配置两个。 

nm-connection-editor

示例 


主机F1、F3和F2的第二个网卡(为下图F2的ens192)都不用配置网关,F2的第一个NAT类型网卡(图中为ens160)需要配置网关

F2的第一个NAT类型网卡(图中为ens160)需要配置网关

到这里就完成了实验环境的搭建

(4)测试

F1能ping通F2的NAT网卡(192.168.76.20)

F2的仅主机网卡(192.168.194.20)能ping通F3

2、iptables命令

(1)安装软件

安装需要搭建软件仓库,详情请见之前博客

dnf install iptables-nft-services.noarch -y

示例


(2)关闭防火墙 

systemctl disable --now firewalld

示例 


systemctl mask firewalld

示例 


 (3)启动服务

systemctl enable --now iptables.service

示例 


(4)iptables基本语法格式

iptables [-t 表名] 命令选项 [链名] [规则条件] -j 目标动作

(5)常用命令选项

参数说明
-A 或 --append在链末尾添加规则(如 -A INPUT)。
-I 或 --insert在链的指定位置插入规则(如 -I INPUT 1 插入为第一条)。
-D 或 --delete删除指定规则(如 -D INPUT 2 或按规则内容删除)。
-L 或 --list列出链中的规则(配合 -n 禁用DNS解析,-v 显示详细信息)。
-F 或 --flush清空链中的所有规则(如 -F INPUT)。
-P 或 --policy设置链的默认策略(如 -P INPUT DROP)。
-N 或 --new-chain创建自定义链(如 -N MY_CHAIN)。
-X 或 --delete-chain删除自定义空链。
-Z 或 --zero重置计数器(数据包和字节计数)。
参数说明
-p 或 --protocol指定协议(如 tcpudpicmpall)。
-s 或 --source源IP地址或网段(如 -s 192.168.1.0/24)。
-d 或 --destination目标IP地址或网段。
-i 或 --in-interface指定数据包进入的网络接口(如 -i eth0)。
-o 或 --out-interface指定数据包离开的网络接口。
- j 或 -- jump指定目标,即满足某条件时该执行什么样的动作,如ACCPET。
参数说明
--dport目标端口(如 --dport 80)。
--sport源端口。
--multiport多端口匹配(需加载 multiport 模块,如 --dports 80,443)。

(6) 各种命令选项的常用命令

就是上面的表中的部分常用的详解

1)iptables  -nL

查看当前iptables策略

iptables  -nL

示例

下面的三行:INPUT、FORWARD、OUTPUT,即为-A后面接的东西(规则)


2)iptables -t 表名
iptables -t

示例

输入-t后,我们连按table键,可以看到弹出来的这些就是表名,分别为:filter  mangle  nat


以下是各个表的详解 

filter表

  • 默认表:若未指定 -t 参数,默认使用 filter 表。

  • 核心功能:过滤数据包,决定是否允许数据包通过。

  • 内置链

    链名触发时机常见用途
    INPUT处理目标是本机的数据包(入站)控制进入本机的流量(如开放 SSH 端口)。
    OUTPUT处理本机产生的数据包(出站)限制本机程序对外访问(如禁止某些 IP)。
    FORWARD处理经过本机转发的数据包(路由)配置 NAT 网关或防火墙路由规则。

nat 表:

  • 核心功能:网络地址转换(Network Address Translation),用于修改数据包的源或目标地址。

  • 内置链

    链名触发时机常见用途
    PREROUTING数据包进入路由决策之前(刚到达网卡)DNAT(目标地址转换,如端口转发)。
    POSTROUTING数据包离开本机之前(即将发送到网卡)SNAT/MASQUERADE(源地址转换,如共享上网)。
    OUTPUT本机产生的数据包在路由决策之后对本机出站流量做 NAT(较少使用)

mangle 表:

  • 核心功能:修改数据包内容(如 TTL、TOS 字段)或标记数据包(MARK),用于高级流量控制。

  • 内置链

    链名触发时机
    PREROUTING数据包进入路由决策之前
    POSTROUTING数据包离开本机之前
    INPUT处理目标是本机的数据包
    OUTPUT处理本机产生的数据包
    FORWARD处理经过本机转发的数据包

 拓展:清空指定表中的策略

iptables -t filter(这里填你想清理的表名,这里以filter举例) -F

示例

 


3)拒绝某条流量的访问

iptables -t  表名  -p  协议  --dport  80  -s  ip地址  -j  功能 

1))命令解析与添加规则

我们以一个实例来举例理解,比如:我们想让F1的tcp协议的访问数据不能到达F2,即拒绝F1的tcp流量,所以我们的命令可以写成:

iptables -t filter -A INPUT -p tcp --dport 80 -s 192.168.76.10 -j REJECT

这一项命令很长,但把其拆解就不复杂了:

所以,整条命令的意思即为:通过iptables写入一条规则 —— 拒绝访问(-j REJECT)表头为filter(-t filter)、端口为80(--dport 80)的tcp协议(-p tcp),并且还是来自(-A INPUT)192.168.76.10(-s 192.168.76.10)的流量


我们再次通过iptables  -nL查看一下当前的规则,可以看到在INPUT行我们刚刚新写入的规则:

iptables  -nL


2))测试规则的存在与生效

我们在F2主机安装nginx来进行测试,看看我们刚刚设置的规则是否存在且生效:

dnf install nginx -y

示例

启动nginx服务:

systemctl enable --now nginx.service

 示例

往F2的nginx里的默认index.html写入一个内容,方便我们后续测试,内容即为F2的NAT网卡ip本身:

echo 192.168.76.20 > /usr/share/nginx/html/index.html

示例 

接下来我们分别到F1主机和F3主机进行测试,看看在F2写的规则是否生效:

我们刚刚写的规则是,F2拒绝F1的tcp协议访问流量,F3的访问流量不拒绝

  • 在F1端对F2进行访问:

  • 在F3端对F2进行访问:


 3))总结 

这就是火墙,通过iptables命令设置规则,规定谁能访问,谁不能访问 


4)只允许某条流量访问

有了上面的基础,这一条就好理解了:

同样在F2进行配置

iptables -t filter -A INPUT -p tcp --dport 80 ! -s 192.168.194.30 -j REJECT

示例 

这里与上面不同的是-s前面的“!”感叹号,感叹号表示反选,-s本来是表示指定192.168.194.30这条流量,加了“!”感叹号后,就表示除了192.168.194.30这条之外的所有ip地址,所以这条命令也就变成了:

除了192.168.194.30,之外的其他所有ip全部都被拒绝访问F2,即——只允许ip为192.168.194.30的tcp访问流量来访问F2

而在默认不设置的情况下,策略都为ACCEPT,即允许,所以192.168.194.30的流量能够访问


5)删除filter表中的第X条策略
iptables -D INPUT  3

各项解释:

INPUT —— (指定为INPUT链,想删哪条链的策略就写哪条链名) 

3 —— (3为第三条策略,想删哪条写哪个数字)


3、firewalld命令

(1)概念

Firewalld 是 Linux 系统(尤其是 RHEL/CentOS/Fedora)中动态管理防火墙规则的工具,基于 firewall-cmd 命令行工具和 zone(区域)概念,支持动态更新规则而无需重启服务。


1)核心概念 

区域(Zone)

  • 定义:预定义的网络信任级别,每个区域关联一组规则(允许的服务、端口等)。

  • 默认区域:通常为 public(未明确指定时使用)。

  • 常见区域

    区域名用途
    public公共网络(默认,仅开放明确允许的服务)。
    trusted完全信任所有连接。
    internal内部网络(类似 home)。
    dmz非军事区(仅允许部分服务)。
    block拒绝所有入站流量(出站允许)。
    drop丢弃所有入站流量(无响应,出站允许)。
2)服务(Service)
  • 预定义的端口和协议组合(如 sshhttphttps),简化规则配置。

  • 服务定义文件路径:/usr/lib/firewalld/services/*.xml

 3)运行时与永久配置
  • 运行时(Runtime):临时生效,重启后失效。

  • 永久(Permanent):持久化配置,需 --permanent 参数,重启或重载后生效。


(2)常用命令

1)firewall-cmd命令表

状态与基本信息

命令说明示例
firewall-cmd --state查看防火墙运行状态。-
firewall-cmd --reload重新加载配置(应用永久规则)。sudo firewall-cmd --reload
firewall-cmd --complete-reload完全重启防火墙服务(断开现有连接)。sudo firewall-cmd --complete-reload
firewall-cmd --version查看 firewalld 版本。-

区域(Zone)管理

命令说明示例
firewall-cmd --get-default-zone查看默认区域。-
firewall-cmd --set-default-zone=<zone>设置默认区域(需 --permanent)。sudo firewall-cmd --set-default-zone=internal --permanent
firewall-cmd --get-active-zones查看所有活动区域及绑定的接口。-
firewall-cmd --get-zones列出所有可用区域。-
firewall-cmd --zone=<zone> --list-all查看指定区域的详细配置。firewall-cmd --zone=public --list-all
firewall-cmd --zone=<zone> --change-interface=<iface>为接口绑定区域(需 --permanent)。sudo firewall-cmd --zone=work --change-interface=eth0 --permanent

服务(Service)与端口(Port)管理

命令说明示例
firewall-cmd --list-services查看当前区域允许的服务。firewall-cmd --list-services
firewall-cmd --add-service=<service>允许服务(默认运行时,加 --permanent 永久生效)。sudo firewall-cmd --add-service=http
firewall-cmd --remove-service=<service>移除服务。sudo firewall-cmd --remove-service=ftp
firewall-cmd --list-ports查看当前区域开放的端口。firewall-cmd --list-ports
firewall-cmd --add-port=<port>/<protocol>开放端口(如 80/tcp)。sudo firewall-cmd --add-port=8080/tcp --permanent
firewall-cmd --remove-port=<port>/<protocol>移除端口。

 高级规则(Rich Rules)

命令说明示例
firewall-cmd --add-rich-rule='<rule>'添加富规则(支持 IP、端口、协议等复杂条件)。sudo firewall-cmd --add-rich-rule='rule family="ipv4" source address="192.168.1.0/24" port port="22" protocol="tcp" accept'
firewall-cmd --remove-rich-rule='<rule>'移除富规则。sudo firewall-cmd --remove-rich-rule='rule family="ipv4" source address="192.168.1.0/24" port port="22" protocol="tcp" accept'
firewall-cmd --list-rich-rules列出所有富规则。

应急模式与连接追踪

命令说明示例
firewall-cmd --panic-on进入应急模式(拒绝所有流量,立即生效)。sudo firewall-cmd --panic-on
firewall-cmd --panic-off退出应急模式。sudo firewall-cmd --panic-off
firewall-cmd --query-panic检查应急模式状态。firewall-cmd --query-panic

2) 火墙信息查看
firewall-cmd --state

示例 


firewall-cmd --list-all

示例 

 

3)管理域
firewall-cmd --get-default-zonefirewall-cmd --set-default-zone=trustedfirewall-cmd  --get-zonesfirewall-cmd  --get-active-zones

 示例

4)管理服务
firewall-cmd --get-servicesfirewall-cmd --list-services --zone=publicfirewall-cmd --permanent --add-service=http --zone=publicfirewall-cmd --permanent --remove-service=http

示例 

5)管理ip
firewall-cmd --add-source=192.168.76.20 --zone=trustedfirewall-cmd --remove-source=192.168.76.20 --zone=trusted

示例

6)管理port接口
firewall-cmd --add-port=80/tcpfirewall-cmd --remove-port=80/tcp

示例 

(3)firewalld高级规则 

Firewalld 的高级规则(Rich Rules)允许管理员基于复杂条件(如源/目标 IP、端口、协议、连接状态等)定义精细化的防火墙策略。

1)核心参数与功能:
匹配条件
参数说明
`family="ipv4ipv6"`指定协议族(IPv4 或 IPv6)。
source address="CIDR"匹配源 IP 或网段(如 192.168.1.0/24)。
destination address="CIDR"匹配目标 IP 或网段。
`port port="端口" protocol="tcpudp"`匹配目标端口和协议(如 port="80" protocol="tcp")。
service name="服务名"匹配预定义的服务(如 sshhttp)。
protocol value="协议"匹配 IP 协议号或名称(如 icmpgre)。
动作与日志
参数说明
accept允许数据包。
reject拒绝数据包并返回错误(默认 icmp-port-unreachable)。
drop丢弃数据包(无响应)。
log记录日志(可选 prefix 和 level)。
audit生成审计日志(需审计子系统支持)。
mark set="标记值"为数据包设置标记(需结合 tc 等工具实现 QoS 或策略路由)。
 2)规则优先级与执行顺序
  1. 富规则优先级

    • 富规则优先于普通服务/端口规则执行。

    • 规则按添加顺序匹配,首条匹配的规则生效

  2. 规则顺序调整

    • 默认无法直接调整顺序,需先删除再重新添加。

相关文章:

【Linux笔记】防火墙firewall与相关实验(iptables、firewall-cmd、firewalld)

一、概念 1、防火墙firewall Linux 防火墙用于控制进出系统的网络流量&#xff0c;保护系统免受未授权访问。常见的防火墙工具包括 iptables、nftables、UFW 和 firewalld。 防火墙类型 包过滤防火墙&#xff1a;基于网络层&#xff08;IP、端口、协议&#xff09;过滤流量&a…...

人工智能解析:技术革命下的认知重构

当生成式AI能够自主创作内容、设计方案甚至编写代码时&#xff0c;我们面对的不仅是工具革新&#xff0c;更是一场关于智能本质的认知革命。人工智能解析的核心&#xff0c;在于理解技术如何重塑人类解决问题和创造价值的底层逻辑——这种思维方式的转变&#xff0c;正成为数字…...

Neo4j实现向量检索

最近因为Dify、RagFlow这样的智能体的镜像拉取的速度实在太麻烦&#xff0c;一狠心想实现自己的最简单的RAG。 因为之前图数据库使用到了neo4j&#xff0c;查阅资料才发现​​Neo4j从5.11版本开始支持向量索引&#xff0c;提供一个真实可用的单元测试案例。 Neo4j建向量索引表…...

SpringBoot外部化配置

外部化配置&#xff08;Externalized Configuration&#xff09;是指将应用的配置从代码中剥离出来&#xff0c;放在外部文件或环境中进行管理的一种机制。 通俗地说&#xff0c;就是你不需要在代码里写死配置信息&#xff08;比如数据库账号、端口号、日志级别等&#xff09;…...

Gut(IF: 23.1)|深度多组学破局肝癌免疫联合治疗耐药的空间微环境图谱

肝细胞癌&#xff08;HCC&#xff09;是癌症相关死亡的主要原因之一&#xff0c;晚期患者预后极差。近年来&#xff0c;免疫检查点抑制剂&#xff08;ICI&#xff09;联合治疗&#xff08;如抗CTLA-4的tremelimumab和抗PD-L1的durvalumab&#xff09;已成为晚期HCC的一线治疗方…...

2025年保姆级教程:Powershell命令补全、主题美化、文件夹美化及Git扩展

文章目录 1. 美化 Powershell 缘起2. 安装 oh-my-posh 和 posh-git3. 安装文件夹美化主题【可选】 1. 美化 Powershell 缘起 背景&#xff1a;用了 N 年的 Windows 系统突然觉得命令行实在太难用了&#xff0c;没有补全功能、界面也不美观。所以&#xff0c;我决定改变它。但是…...

LeetCode-链表-合并两个有序链表

LeetCode-链表-合并两个有序链表 ✏️ 关于专栏&#xff1a;专栏用于记录 prepare for the coding test。 文章目录 LeetCode-链表-合并两个有序链表&#x1f4dd; 合并两个有序链表&#x1f3af;题目描述&#x1f50d; 输入输出示例&#x1f9e9;题目提示&#x1f9ea;AC递归&…...

SpringBoot3+Vue3(2)-前端基本页面配置-登录界面编写-Axios请求封装-后端跨越请求错误

前端&#xff1a; 清理文件 main.js 刷新后页面上什么都没有了 App.vue就留这 1.基本页面配置 新建Vue组件 单页面&#xff0c;考路由才操作。 1.前端根目录下安装路由 2.创建路由文件夹 main.js中添加路由配置 App.vue 添加上路由 welcomeView.vue 浏览器刷新&…...

Android Framework学习八:SystemServer及startService原理

文章目录 SystemServer、SystemServiceManger、SystemService、serviceManager的关系SystemServer进程的执行包含的ServiceSystemServer启动服务的流程startService Framework学习系列文章 SystemServer、SystemServiceManger、SystemService、serviceManager的关系 管理机制&a…...

远程访问家里的路由器:异地访问内网设备或指定端口网址

在一些情况下&#xff0c;我们可能需要远程访问家里的路由器&#xff0c;以便进行设置调整或查看网络状态等&#xff0c;我们看看怎么操作&#xff1f; 1.开启远程访问 在路由本地电脑或手机&#xff0c;登录浏览器访问路由管理后台&#xff0c;并设置开启WEB远程访问。 2.内…...

大语言模型 17 - MCP Model Context Protocol 介绍对比分析 基本环境配置

MCP 基本介绍 官方地址&#xff1a; https://modelcontextprotocol.io/introduction “MCP 是一种开放协议&#xff0c;旨在标准化应用程序向大型语言模型&#xff08;LLM&#xff09;提供上下文的方式。可以把 MCP 想象成 AI 应用程序的 USB-C 接口。就像 USB-C 提供了一种…...

python生成requirements.txt文件

方法一&#xff1a;只生成项目所用到的python包(常用) 首先安装pipreqs pip install pipreqs 然后进入到你所在的项目根目录&#xff0c;运行以下命令&#xff1a; pipreqs ./ --encodingutf-8 方法二&#xff1a;把本地所有安装包写入文件 pip freeze > requirements.txt …...

如何在PyCharm2025中设置conda的多个Python版本

前言 体验的最新版本的PyCharm(Community)2025.1.1&#xff0c;发现和以前的版本有所不同。特别是使用Anaconda中的多个版本的Python的时候。 关于基于Anaconda中多个Python版本的使用&#xff0c;以及对应的Pycharm&#xff08;2023版&#xff09;的使用&#xff0c;可以参考…...

StepX-Edit:一个通用图像编辑框架——论文阅读笔记

一. 前言 代码&#xff1a;https://github.com/stepfun-ai/Step1X-Edit 论文&#xff1a;https://arxiv.org/abs/2504.17761 近年来&#xff0c;图像编辑技术发展迅速&#xff0c;GPT- 4o、Gemini2 Flash等前沿多模态模型的推出&#xff0c;展现了图像编辑能力的巨大潜力。 这…...

vue原生table表格实现动态添加列,一行添加完换行继续添加。el-select输入框背景颜色根据所选内容不同而改变

效果如下 动态添加列 代码如下 <template><div class"table-container"><button click"addColumn">添加列</button><div class"scroll-container"><div class"table-grid"><div v-for"(r…...

maven之pom.xml

MAVEN 1、基础配置​2、项目信息3、依赖管理​4、构建配置​5、继承与聚合​6、仓库与SCM​7、其他高级配置​ Maven的pom.xml文件是项目的核心配置文件&#xff0c;用于定义项目结构、依赖关系和构建过程 https://www.runoob.com/maven/maven-pom.html 1、基础配置​ **<…...

深度学习Y8周:yolov8.yaml文件解读

&#x1f368; 本文为&#x1f517;365天深度学习训练营中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 本周任务&#xff1a;根据yolov8n、yolov8s模型的结构输出&#xff0c;手写出yolov8l的模型输出、 文件位置&#xff1a;./ultralytics/cfg/models/v8/yolov8.…...

充电桩APP的数据分析:如何用大数据优化运营?

随着新能源汽车的普及&#xff0c;充电桩作为基础设施的核心环节&#xff0c;其运营效率直接影响用户体验和行业可持续发展。充电桩APP积累了海量用户行为、充电记录、设备状态等数据&#xff0c;如何利用这些数据优化运营成为关键课题。大数据分析能够帮助运营商精准定位问题、…...

shell脚本之函数详细解释及运用

什么是函数 通俗地讲&#xff0c;所谓函数就是将一组功能相对独立的代码集中起来&#xff0c;形成一个代码块&#xff0c;这个代码可 以完成某个具体的功能。从上面的定义可以看出&#xff0c;Shell中的函数的概念与其他语言的函数的 概念并没有太大的区别。从本质上讲&#…...

校平机的原理、应用及发展趋势

一、校平机的定义与作用 校平机&#xff08;Leveling Machine&#xff09;是一种用于矫正金属板材、带材或卷材表面平整度的工业设备。其核心功能是通过机械作用消除材料内部残余应力&#xff0c;修正材料在加工、运输或存储过程中产生的弯曲、波浪形、翘曲等缺陷&#xff0c;…...

NFM算法解析:如何用神经网络增强因子分解机的特征交互能力?

在推荐系统和广告点击率预测等场景中&#xff0c;特征交叉&#xff08;Feature Interaction&#xff09;是提升模型效果的关键。传统的因子分解机&#xff08;FM&#xff09;通过二阶特征交互取得了显著效果&#xff0c;但其线性建模方式和有限阶数限制了模型的表达能力。今天&…...

Python人工智能算法 模拟退火算法:原理、实现与应用

模拟退火算法&#xff1a;从物理启发到全局优化的深度解析 一、算法起源与物理隐喻 模拟退火算法&#xff08;Simulated Annealing, SA&#xff09;起源于20世纪50年代的固体退火理论&#xff0c;其核心思想可追溯至Metropolis等人提出的蒙特卡罗模拟方法。1983年&#xff0c…...

服务器网络配置 netplan一个网口配置两个ip(双ip、辅助ip、别名IP别名)

文章目录 问答 问 # This is the network config written by subiquity network:ethernets:enp125s0f0:dhcp4: noaddresses: [192.168.90.180/24]gateway4: 192.168.90.1nameservers:addresses:- 172.0.0.207- 172.0.0.208enp125s0f1:dhcp4: trueenp125s0f2:dhcp4: trueenp125…...

FTP与NFS服务详解

一、FTP服务 &#xff08;一&#xff09;Linux下FTP客户端管理工具 1. ftp工具 安装命令&#xff1a;yum install ftp -y连接服务器&#xff1a;ftp 服务器IP&#xff0c;输入账号密码登录。常用命令&#xff1a; 命令说明ls查看远程目录文件put上传单个文件到远程服务器get…...

算法中的数学:欧拉函数

1.相关定义 互质&#xff1a;a与b的最大公约数为1 欧拉函数&#xff1a;在1~n中&#xff0c;与n互质的数的个数就是欧拉函数的值 eg&#xff1a; n1时&#xff0c;欧拉函数的值为1&#xff0c;因为1和1是互质的 n2是&#xff0c;值为2&#xff0c;因为1和2都是互质的 积性函数&…...

如果有三个服务实例部署在三台不同的服务器上,这三个服务实例的本地缓存,是存储一模一样的数据?还是各自只存一部分?

✅ 答案是&#xff1a;通常每个服务实例都会独立地缓存它自己访问过的数据&#xff0c;这些数据可能是相同的&#xff0c;也可能是不同的&#xff0c;取决于请求的内容。 &#x1f4cc; 举个例子说明 假设你有一个商品详情页的服务&#xff0c;部署了 3 个服务实例&#xff08…...

Coze工作流-选择器的用法

上集回顾 上集教程我们学习了什么是变量以及变量类型的用法。即什么时候用什么变量类型 教程简介 本教程将带大家学习工作流的选择和问答模块 工作流类型选择 在Coze中&#xff0c;工作流是智能体的核心逻辑单元。根据任务复杂度&#xff0c;可选择两种模式&#xff1a; 类…...

《AI工程技术栈》:三层结构解析,AI工程如何区别于ML工程与全栈工程

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…...

uni-app使用大集

1、手动修改页面标题 uni.setNavigationBarTitle({title: 修改标题 }); 2、单选 不止有 radio-group&#xff0c;还有 uni-data-checkbox 数据选择器 <!-- html部分 --> <uni-data-checkbox v-model"sex" :localdata"checkboxList"></u…...

链表day3

链表定义 struct ListNode{int val;ListNode *next; //next是一个指针变量&#xff0c;存储的是地址&#xff0c;是ListNode类型的地址ListNode(int x) : val(x),next(nullptr){} //也就是说ListNode必须接受一个int x&#xff0c;next指针默认为nullptr&#xff0c;值由外部指…...

C++23关联容器的异质擦除重载 (P2077R2)介绍

文章目录 一、基本概念二、原理重载机制类型转换 三、优势提高查找效率提升程序整体性能避免不必要的初始化确保系统实时性 四、应用场景高性能计算大型对象管理实时系统 五、代码示例六、相关图片材料结构与微观图像半导体研究图示与图表科学图表芯片与电路板 一、基本概念 在…...

Flink架构概览,Flink DataStream API 的使用,FlinkCDC的使用

一、Flink与其他组件的协同 Flink 是一个分布式、高性能、始终可用、准确一次&#xff08;Exactly-Once&#xff09;语义的流处理引擎&#xff0c;广泛应用于大数据实时处理场景中。它与 Hadoop 生态系统中的组件可以深度集成&#xff0c;形成完整的大数据处理链路。下面我们从…...

AI加速芯片全景图:主流架构和应用场景详解

目录 一、为什么AI芯片如此重要? 二、主流AI芯片架构盘点 三、不同芯片在训练与推理中的部署逻辑 四、真实应用案例解读 五、AI芯片发展趋势预测 AI芯片的选择,是AI系统能否高效运行的关键。今天笔者就从架构角度出发,带你系统了解主流AI加速芯片的种类、优劣对比及实际…...

Ubuntu22.04 系统安装Docker教程

1.更新系统软件包 #确保您的系统软件包是最新的。这有助于避免安装过程中可能遇到的问题 sudo apt update sudo apt upgrade -y 2.安装必要的依赖 sudo apt install apt-transport-https ca-certificates curl software-properties-common -y 3.替换软件源 原来/etc/apt/s…...

更新ubuntu软件源遇到GPG error

BUG背景 执行sudo apt update后遇到类似下列报错&#xff1a; E: The repository https://download.docker.com/linux/ubuntu bionic Release no longer has a Release file. N: Updating from such a repository cant be done securely, and is therefore disabled by defau…...

vue调后台接口

1.1 什么是 axios Axios 是一个基于 promise 的 HTTP 库&#xff0c;可以用来发送网络请求。它可以在浏览器和 node.js 中使用&#xff0c;本质上是对原生 XMLHttpRequest 的封装&#xff0c;符合最新的 ES 规范&#xff0c;支持 Promise API&#xff0c;能够拦截请求和响应&am…...

Ubuntu学习记录

冷知识补充 1.VMware官网安装后&#xff0c;会有两个软件&#xff0c;一个收费&#xff08;pro&#xff09;(功能更多&#xff0c;可以一次运行多个虚拟机)&#xff08;尽管2024年最新版本的也免费了&#xff09;一个免费(player)。 2.ubuntu打开终端快捷键&#xff1a;ctrlal…...

【音频】如何解析mp3文件

解析和播放MP3文件涉及两个主要步骤:解码(将MP3压缩数据转换为原始PCM音频)和播放(将PCM数据通过音频设备输出)。以下是不同平台和编程语言的实现方法: 一、MP3文件结构基础 MP3文件由多个**帧(Frame)**组成,每帧包含固定时长的音频数据(通常为26ms)。每个帧包含:…...

学习笔记:黑马程序员JavaWeb开发教程(2025.4.9)

12.16 异常处理 定义一个类&#xff0c;加上注解RestControllerAdvice&#xff0c;即定义了一个全局异常处理器 再方法上加上注解ExceptionHandler&#xff0c;通过注解当中的value属性来指定捕获那个类型的异常 完成Filter、interceptor、异常处理代码实操 Filter Filter里…...

【音频】wav文件如何解析编码格式(压缩格式)?

要确定一个WAV文件的编码格式&#xff0c;可以通过以下几种方法实现&#xff0c;包括使用操作系统自带工具、专业音频软件或编程解析文件头信息。以下是详细说明&#xff1a; 一、通过文件属性查看&#xff08;Windows/macOS&#xff09; 1. Windows系统 步骤&#xff1a; 右…...

【Django系统】Python+Django携程酒店评论情感分析系统

Python Django携程酒店评论情感分析系统 项目概述 这是一个基于 Django 框架开发的酒店评论情感分析系统。系统使用机器学习技术对酒店评论进行情感分析&#xff0c;帮助酒店管理者了解客户反馈&#xff0c;提升服务质量。 主要功能 评论数据导入&#xff1a;支持导入酒店…...

OpenCv高阶(十六)——Fisherface人脸识别

文章目录 前言一、Fisherface人脸识别原理1. 核心思想&#xff1a;LDA与Fisher准则2. 实现步骤(1) 数据预处理(2) 计算类内散布矩阵 SW对每个类别&#xff08;每个人&#xff09;计算均值向量 μi&#xff1a;(3) 计算类间散布矩阵 SB(4) 求解投影矩阵 W(5) 降维与分类 3. Fish…...

数据库与Redis数据一致性解决方案

在写数据时保证 Redis 和数据库数据一致,可采用以下方案,需根据业务场景权衡选择: 1. 先更新数据库,再更新 Redis 步骤: 写入 / 更新数据库数据。删除或更新 Redis 缓存。适用场景:读多写少,对缓存一致性要求不高(短暂不一致可接受)。风险:若第二步失败,导致缓存与…...

Python面试题

Python面试题 Python面试题回答1. Python面向对象的三个特征&#xff1f;多态如何实现和使用2. is 和 的区别&#xff1f;3. GIL了解吗&#xff1f;说说4. 可变类型和不可变类型&#xff1f;5. yield用法&#xff1f;6. 深拷贝和浅拷贝区别&#xff1f;7. Python中的线程8. 生…...

力扣周赛置换环的应用,最少交换次数

置换环的基本概念 置换环是排列组合中的一个概念&#xff0c;用于描述数组元素的重排过程。当我们需要将一个数组转换为另一个数组时&#xff0c;可以把这个转换过程分解为若干个 “环”。每个环代表一组元素的循环交换路径。 举个简单例子 假设原数组 A [3, 2, 1, 4]&…...

差分数组 - 对区间内元素的统一操作

目录 概念 题单 1 拼车 2 将区间分为最少组数 3 字母移位 4 使数组中的所有元素都等于零 5 零数组变换Ⅰ 6 最大化城市的最小电量 概念 差分数组&#xff0c;顾名思义&#xff0c;就是由原数组的相邻元素作差而得到的差值组成的新的数组。 对于原数组 a [ 1 , 3 , 5 …...

线上问题排查

一&#xff1a;CPU飙高问题排查过程 遇到这种问题&#xff0c;首先是登录到服务器&#xff0c;看一下具体情况。 定位进程&#xff1a;top命令&#xff0c;查看CPU占用情况定位线程&#xff1a;top -Hp 1893命令&#xff0c;查看各个线程的CPU使用情况定位代码&#xff1a;pr…...

计及可再生能源不确定性的经济优化调度方法

目前&#xff0c;计及可再生能源不确定性的经济调度方法主要有随机优化、鲁棒优化和区间优化。 随机优化&#xff1a;可再生能源输出被定义为一个已知概率分布的随机变量。 难以同时保证计算精度和效率。 1-场景法 场景生成 基于随机变量概率分布进行采样&#xff1a;蒙特…...

支持向量机(SVM):分类与回归的数学之美

在机器学习的世界里&#xff0c;支持向量机&#xff08;Support Vector Machine&#xff0c;简称 SVM&#xff09;是一种极具魅力且应用广泛的算法。它不仅能有效解决分类问题&#xff0c;在回归任务中也有着出色的表现。下面&#xff0c;就让我们深入探索 SVM 如何在分类和回归…...

用户刷题记录日历——签到表功能实现

MySQL实现 在数据库中设计一张签到表&#xff0c;记录用户每次签到的日期及其他相关信息。然后通过时间范围查询得到用户的签到记录。 CREATE TABLE user_sign_in (id BIGINT AUTO_INCREMENT PRIMARY KEY, -- 主键&#xff0c;自动递增userId BIGINT NOT NULL, …...