HAproxy 七层负载均衡调度器详解及配置

news2025/1/9 1:35:01

HAproxy 七层负载均衡

负载均衡技术

负载均衡(Load Balance):一种服务,或基于硬件设备实现的高可用的反向代理技术,是指将特定的业务流量分摊给一个或多个后端的特定服务器或设备,实现高并发处理业务流量,从而保证了业务的高可用性,方便业务后期的水平动态拓展。

优点

1、Web服务器的动态水平扩展:对用户无感知
2、增加业务并发访问及处理能力:解决单服务器瓶颈问题
3、节约公网IP地址:降低T支出成本
4、隐藏内部服务器P:提高内部服务器安全性
5、配置简单:固定格式的配置文件
6、功能丰富:支持四层和七层,支持动态下线主机
7、性能较强:并发数万甚至数十万

四层负载均衡

1、通过识别和改变 IP 地址或端口决定负载均衡的去向;

2、对业务流量请求进行 NAT 处理,转发至后台服务器;

3、记录 TCP 和 UDP 流量分别是由哪台服务器处理,后续该请求连接的流量都通过该服务器处理;

4、支持四层负载均衡的软件:
LVS:重量级四层负载均衡器(无后端检测功能)
Nginx:轻量级四层负载均衡器,可缓存。(nginx四层是通过upstream模块)
Haproxy:模拟四层转发。

七层负载均衡

1、通过虚拟 URL 或主机 IP 进行流量识别,根据应用层信息进行解析,决定是否需要进行负载均衡;

2、代理后台服务器与客户端建立连接,如 NGINX 可代理前后端,与前端客户端进行 TCP 连接,与后端服务器建立 TCP 连接;

3、支持7层代理的软件:
Nginx:基于 http 协议(nginx七层是通过proxy_pass)
Haproxy:七层代理,会话保持、标记、路径转移

四层和七层的区别

所谓的四到七层负载均衡,就是在对后台的服务器进行负载均衡时,依据四层的信息或七层的信息来决定怎么样转发流量

四层的负载均衡,就是通过发布三层的 IP 地址(VIP)加四层的端口号,来决定哪些流量需要做负载均衡,对需要处理的流量进行 NAT 处理,转发至后台服务器,并记录下这个TCP或者UDP的流量是由哪台服务器处理的,后续这个连接的所有流量都会转发至同一台服务器处理

七层的负载均衡,就是在四层的基础上(没有四层是绝对不可能有七层的),再考虑应用层的特征,比如同一个 Web 服务器的负载均衡,除了根据 VIP 加 80 端口辨别是否需要处理的流量,还可以根据七层的 URL、浏览器类别、语言来决定是否要进行负载均衡

1、分层位置:四层负载均衡在传输层及以下,七层负载均衡在应用层及以下;
2、性能:四层负载均衡架构无需解析报文消息内容,在网络吞吐量与处理能力上较高;七层可支持解析应用层报文消息内容,识别URL、Cookie、HTTP header 等信息;
3、原理:四层负载均衡是基于 IP 和端口来实现的;七层是基于虚拟的 URL 或主机IP等;
4、功能类比:四层负载均衡类似于路由器;七层类似于代理服务器;
5、安全性:四层负载均衡无法识别 DDOS 攻击;七层可防御 SYN Cookie / Flood 攻击

HAproxy 概念

HAproxy 是一款开源、高性能的负载均衡器和代理服务器,专为 TCP 和 HTTP 应用而设计。它可以将客户端的请求分发到多台后端服务器,从而提高应用的可用性和性能。HAProxy支持多种负载均衡算法和健康检查机制,是构建高可用性系统的理想选择。

HAproxy 的优势
高性能:HAProxy采用事件驱动模型,能够处理大量并发连接;
灵活性强:支持多种负载均衡算法和调度策略,适应不同的应用场景;
高可用性:通过健康检查和故障转移机制,确保服务的连续性;
丰富的功能:支持SSL终止、HTTP重写、压缩等多种功能。

HAproxy 基本配置

1、软件包下载

[root@haproxy ~]# yum install haproxy.x86_64 -y

2、启动服务

[root@haproxy ~]# systemctl enable --now haproxy

3、配置文件

[root@haproxy ~]# vim /etc/haproxy/haproxy.cfg

在这里插入图片描述

在这里插入图片描述

HAProxy的配置文件haproxy.cfg由两大部分组成,分别是:

global:全局配置段
1.进程及安全配置相关的参数
2.性能调整相关参数
3.Debug参数

option abortonclose:当服务器负载很高时,自动结束掉当前队列处理比较久的连接,针对业务情况选择开启
option redispatch:当server ID对应的服务器挂掉后,强制定向到其他健康的服务器,重新派发
option http-keep-alive:开启与客户端的会话保持

option forwardfor:透传客户端真实IP至后端web服务器(在apachei配置文件中加入:%X-Forwarded-For}i后在webserert中看日志即可看到地址透传信息)
mode http|tcp:设置默认工作类型,使用TCP服务器性能更好,减少压力
timeout http-keep-alive 120s:session会话保持超时时间,此时间段内会转发到相同的后端服务器
timeout connect 120s:客户端请求从haproxy到后端serveri最长连接等待时间(TCP连接之前),默认单位ms
timeout server 600s:客户端请求从haproxy到后端服务端的请求处理超时时长(TCP连接之后),默认单位ms,如果超时,会出现502错误,此值建议设置较大些,访止502错误
timeout client 600s:设置naproxy与客户端的最长非活动时间,默认单位ms,建议和timeout server相同
timeout check 5s:对后端服务器的默认检测超时时间
default-server inter 1000 weight 3:指定后端服务器的默认设置

proxies:代理配置段
defaults:为frontend,backend,listen提供默认配
frontend:前端,相当于nginx中的server{}
backend:后端,相当于nginx中的upstream{}
listen:同时拥有前端和后端配置,配置简单,生产推荐使用

4、日志管理

[root@haproxy ~]# vim /etc/rsyslog.conf 
[root@haproxy ~]# systemctl restart rsyslog.service

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

5、多进程和线程

[root@haproxy errorpage]# pstree -p |grep haproxy	----查看进程

在这里插入图片描述

6、在listen字段中server的配置

check:对指定real进行健康状态检查,如果不加此设置,默认不开启检查,check后面没有其它配置也可以启用检查功能----只针对一个server设置

默认对相应的后端服务器工P和端口,利用TCP连接进行周期性健康性检查,注意必须指定端口才能实现健康性检查
addr <IP>:可指定的健康状态监测工P,可以是专门的数据网段,减少业务网络的流量
port <num>:指定的健康状态监测端口
inter <num>:健康状态检查间隔时间,默认2000ms
fall <num>:后端服务器从线上转为线下的检查的连续失效次数,默认为3
rise <num>:后端服务器从下线恢复上线的检查的连续有效次数,默认为2
weight <weight>:默认为1,最大值为256,0(状态为蓝色)表示不参与负载均衡,但仍接受持久连接
backup:将后端服务器标记为备份状态,只在所有非备份主机down机时提供服务
disabled:将后端服务器标记为不可用状态,即维护状态,除了持久模式,将不再接受连接,状态
为深黄色,不再接受新用户的请求
redirect prefix http://www.baidu.com/ :将请求临时(302)重定向至其它URL,只适用于http模式
redir http://www.baidu.com :将请求临时(302)重定向至其它URL,只适用于
http模式
maxconn <maxconn>:当前后端server的最大并发连接数

在这里插入图片描述

7、socat工具

对服务器动态权重和其它状态可以利用socat工具进行调整,Socat是Linux下的一个多功能的网络工具,名字来由是Socket CAT,相当于netCAT的增强版,Socat的主要特点就是在两个数据流之间建立双向通道,且支持众多协议和链接方式。如IP、TCP、UDP、IPv6、Socket文件等

$1 :监听的名称;$2 :server名称;$3 :套接字文件名

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

HAproxy 的算法

1、HAProxy通过固定参数balance指明对后端服务器的调度算法;
2、balance参数可以配置在listen或backend选项中;
3、HAProxy的调度算法分为静态和动态调度算法;
4、有些算法可以根据参数在静态和动态算法中相互转换。

静态算法

按照事先定义好的规则轮询公平调度,不关心后端服务器的当前负载、连接数和响应速度等,且无法实时修改权重(只能为0和1,不支持其它值),只能靠重启HAProxy生效。

static-rr

基于权重的轮询调度

缺点:不支持动态的调整权重(socat工具);不支持服务器的慢启动(服务器刚启动时,只接受一部分数据,没有故障发生后接收全部数据)

优点:后端主机无数量限制
在这里插入图片描述

效果演示:

在这里插入图片描述

无法动态修改权重

在这里插入图片描述

first

基于服务器所在理论位置自上而下的调度

缺点:忽略服务器权重的设置;不支持动态修改权重(socat工具)

优点:当第一台服务器连接数达上限时才会分配链接给下一台服务器,充分利用资源

在这里插入图片描述

动态算法

基于后端服务器状态进行调度适当调整;新请求将优先调度至当前负载较低的服务器;权重可以在naproxyi运行时动态调整无需重启。

roundrobin

基于权重的轮询动态调度

优点:支持慢启动;支持动态的权重调整;默认算法,使用广泛;

缺点:后端主机数量最大支持4095个

在这里插入图片描述

动态修改权重

在这里插入图片描述

leastconn

基于最少链接数调度

支持动态调整权重;正常慢启动;适合于长连接的场景(MySQL等);无视权重,根据链接最少的后端服务器而调度

在这里插入图片描述

效果演示

在这里插入图片描述

可变算法

可通过不同的选项将静态算法变为动态算法

source

源地址hash,基于用户源地址hash并将请求转发到后端服务器,后续同一个源地址请求将被转发至同一个后端web服务器。

此方式当后端服务器数据量发生变化时,会导致很多用户的请求转发至新的后端服务器,默认为静态方式,但是可以通过hash-type支持的选项更改这个算法,一般是在不插入cookie的TCP模式下使用,也可给拒绝会话cookie的客户提供最好的会话粘性

适用于session会话保持但不支持cookie和缓存的场景源地址,有两种转发客户端请求到后端服务器的服务器选取计算方式,分别是取模法一致性hash

在这里插入图片描述

效果演示
在这里插入图片描述

source 取模法

map-based:取模法,对sourcef地址进行hash计算,再基于服务器总权重的取模,最终结果决定将此请求转发至对应的后端服务器。
此方法是静态的,即不支持在线调整权重,不支持慢启动,可实现对后端服务器均衡调度
缺点是当服务器的总权重发生变化时,即有服务器上线或下线,都会因总权重发生变化而导致调度结果整体改变,hash-type指定的默认值为此算法

比如当源hash值时1111,1112,1113,三台服务器abc的权重均为1,
即abc的调度标签分别会被设定为012(1111%3=1,1112%3=2,1113%3=0)
假设a为0,1113主机会被调度到a上
如果a下线后,权重数量发生变化
1111%2=1,1112%2=0,1113%2=1
1112和1113被调度到的主机都发生变化,这样会导致会话丢失

在这里插入图片描述

source 一致性hash

一致性哈希,当服务器的总权重发生变化时,对调度结果影响是局部的,不会引起大的变动hash(o) mod n
该hash算法是动态的,支持使用socat等工具进行在线权重调整,支持慢启动

hash环

1、后端服务器哈希环点keyA=hash(后端服务器虚拟ip)%(2^32)	----0至(2^32-1)的所有数字落在一个环上
2、客户机哈希环点keyl=hash(c1ient_ip)%(2^32),得到的值在[0---4294967295]之间
3、将keyA和keyl都放在hash环上,将用户请求调度到离keyl最近的keyA对应的后端服务器

在这里插入图片描述

服务器在hash环的模拟位置

在这里插入图片描述

hash环偏斜

增加虚拟服务器IP数量,比如:一个后端服务器根据权重为1生成1000个虚拟IP,再hash;而后端服务器权重为2则生成2000的虚拟IP,再bash;最终在hash环上生成3000个节点,从而解决hash环偏斜问题

一致性hash

客户端会顺时针去寻找离自己最近的一台服务器,当一台服务器宕机时,连接在服务器上的链接会顺时针再去寻找一台最近的服务器,保证了服务器已存在会话的连接不会断开。

服务器在线时状态
在这里插入图片描述

某台服务器离线时

在这里插入图片描述

source 一致性hash在HAphroxy配置

在这里插入图片描述

uri

基于对用户请求的UR的左半部分或整个uri做hash,再将hash结果对总权重进行取模后,根据最终结果将请求转发到后端指定服务器;适用于后端是缓存服务器场景
默认是静态算法,也可以通过hash-type指定map-based和consistent,来定义使用取模法还是一致性hash

该算法只支持 mode http(七层);不支持 mode tcp(四层)

<scheme>://<user>:<password>@<host>:<port>/<path>;<params>?<query>#<frag>
左半部分:/<path>;<params>
整个uri:/<path>;<params>?<query>.#<frag>

在这里插入图片描述

uri 取模法

在这里插入图片描述

uri 一致性hash

在这里插入图片描述

演示效果:

在这里插入图片描述

url_param

url_param对用户请求的url中的params部分中的一个参数key对应的value值作hash计算,并由服务器总权重相除以后派发至某挑出的服务器,后端搜索同一个数据会被调度到同一个服务器,多用与电商
通常用于追踪用户,以确保来自同一个用户的请求始终发往同一个real server
如果无没key,将按roundrobin算法

url http://www.tym.com/foo/bar/index.html?key=value

host = "www.timinglee.com"
url_param = "key=value"或"name=name"
url_param 取模法

在这里插入图片描述

演示效果:

在这里插入图片描述

url_param 一致性hash

在这里插入图片描述

演示效果:

在这里插入图片描述

hdr

针对用户每个http头部(header)请求中的指定信息做hash
此处由name指定的http首部将会被取出并做hash计算,然后由服务器总权重取模以后派发至某挑出的服务器,如果无有效值,则会使用默认的轮询调度(roundrobin)

hdr 取模法

在这里插入图片描述

hdr 一致性hash

在这里插入图片描述

演示效果:
在这里插入图片描述
在这里插入图片描述

HAproxy 高级功能

cookie 保持会话长连接

通过设定 cookie 值,在不同的浏览器之间临时绑定一个会话,客户端通过第一次访问浏览器时,浏览器会缓存一个客户端对应的 cookie 值,当客户端再次访问时,会将客户端的 cookie 值与浏览器缓存的 cookie 值进行对比,找到上一次访问的浏览器进行连接会话。cookie 的缓存时间由浏览器决定,也可手动将缓存清除;当缓存

基本配置

listen webcluster
     bind *:80
     mode http
     balance roundrobin
     cookie tym(cookie名称) insert(插入新cookie值,默认不插入) nocache(如果客户端以有cookie值,则不再发送cookie信息) indirect(不允许中间缓存器缓存cookie)
     server web1 192.168.0.10:80 cookie tym1 check inter 2 fall 3 rise 5 weight 2
     server web2 192.168.0.20:80 cookie tym2 check inter 2 fall 3 rise 5 weight 1

在这里插入图片描述

效果演示
在这里插入图片描述

HAproxy 状态页

修改 HAproxy 配置文件

stats enable	----基于默认的参数启用stats page
stats hide-version	----将状态页中haproxy版本隐藏
stats refresh <delay>	----设定自动刷新时间间隔,默认不自动刷新
stats uri <prefix>	----自定义stats page uri,默认值:/haproxy?stats
stats auth <user>:<passwd>	----认证时的账号和密码,可定义多个用户,每行指定一个用户;默认:no authentication
stats admin{if|unless}<cond>	----启用stats page中的管理功能

在这里插入图片描述

效果演示

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

IP 透传

四层 IP 透传

修改 HAproxy 配置文件

在这里插入图片描述

修改 NGINX 配置文件
在这里插入图片描述
在这里插入图片描述

效果演示

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

七层 IP 透传

修改 HAproxy 配置文件

在这里插入图片描述

修改 apache 配置文件

在这里插入图片描述

修改 nginx 配置文件
在这里插入图片描述

效果演示

apache 日志:
在这里插入图片描述

nginx 日志:
在这里插入图片描述

ACL

访问控制列表ACL(Access Control Lists)
是一种基于包过滤的访问控制技术,它可以根据设定的条件对经过服务器传输的数据包进行过滤(条件匹配)即对接收到的报文进行匹配和过滤,基于请求报文头部中的源地址、源端口、目标地址、目标端口、请求方法、UL、文件后缀等信息,对内容进行匹配并执行进一步操作,比如允许其通过或丢弃。

ACL 配置选项
acl	<aclname>(名称) <criterion>(匹配规范) [flags](匹配模式) [operator](具体操作符) [<value>](操作对象类型)
ACL 命名规则
acl image_service hdr_dom(host) -i img.magedu.com

ACL名称,可以使用大字母(A-Z)、小写字母(a-z)、数字(0-9)、冒号(:)、点(.)、中横线(-)和下划线(_),并且严格区分大小写,比如:my_acl和My_Acl就是两个完全不同的acl
ACL 匹配

域名解析地址

匹配条件:输入www.ty.org则访问server1,其他访问至server2
在这里插入图片描述

演示效果:

在这里插入图片描述

以什么结尾为匹配规则

在这里插入图片描述

效果演示:
在这里插入图片描述

域名内的某一段匹配

在这里插入图片描述

效果演示:
在这里插入图片描述

正则匹配
在这里插入图片描述

效果演示:
在这里插入图片描述

条件的匹配

在这里插入图片描述

错误页提示

errorfile

指定错误页路径和内容
在这里插入图片描述

效果演示:
在这里插入图片描述

errorloc

重定向 IP 地址

当网页访问错误时,自动跳转至指定的地址

在这里插入图片描述

HAproxy 四层负载-数据库

数据库监听字段:
在这里插入图片描述

效果演示:
在这里插入图片描述

HAproxy https加密认证

创建认证秘钥文件

[root@haproxy ~]# openssl req -newkey rsa:2048 -nodes -sha256 -keyout /etc/haproxy/ssl/tym.org.key -x509 -days 365 -out /etc/haproxy/ssl/tym.org.crt

在这里插入图片描述

全站加密:
在这里插入图片描述

效果展示:
在这里插入图片描述

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

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

相关文章

KNN算法原理

KNN&#xff08;K-Nearest Neighbors&#xff0c;K最近邻&#xff09;算法是一种基本且广泛使用的分类与回归方法。在分类任务中&#xff0c;KNN的输入为实例的特征向量&#xff0c;对应于特征空间的点&#xff1b;输出为实例的类别&#xff0c;可以取为类别集合中任意一个类别…

深入解析Java设计模式之中介者模式

一、什么是中介者模式 中介者模式&#xff08;Mediator Pattern&#xff09;是Java设计模式中的一种行为型模式。在中介者模式中&#xff0c;一个中介者对象封装了一系列对象之间的交互&#xff0c;使对象之间不直接相互通信&#xff0c;而是通过中介者对象进行通信。这种模式有…

VM——深度学习算子GPU版本耗时不稳定

1、问题&#xff1a;使用3080TI显卡4台130万相机&#xff0c;GPU版本算子&#xff0c;耗时不稳定&#xff0c;15ms-150ms波动 2、方法&#xff1a; 1&#xff09;参考海康提供的问题手册

Java面试题--JVM大厂篇之JVM 内存管理深度探秘:原理与实战

目录 引言: 正文: 1. JVM内存管理的基本原理 痛点一&#xff1a;频繁的Minor GC 2. 内存分配与回收案例 3. 避免内存泄漏的技巧 痛点二&#xff1a;未关闭的资源 痛点三&#xff1a;静态集合类持有对象引用 4. 优化内存使用的技巧 痛点四&#xff1a;对象过多占用内存…

超越自我——带你学haproxy算法一遍过!!!

文章目录 前言介绍 静态算法static-rrfirst 动态算法roundrobinleastconn 其他算法source算法map-base 取模法一致性hashuriurI_param 取模法hdr 总结本文相关连接如下&#xff1a; 前言 本文相关连接如下&#xff1a; 如果想更多了解haproxy的相关知识&#xff0c;请点击&am…

考试:操作系统知识(03)

分区存储管理 所谓分区存储组织&#xff0c;就是整存&#xff0c;将某进程运行所需的内存整体一起分配给它&#xff0c;然后再执行。有三种分区方式&#xff1a; 固定分区&#xff1a;静态分区方法&#xff0c;将主存分为若干个固定的分区&#xff0c;将要运行的作业装配进去…

ArcGIS Pro 实现人口分布栅格TIFF数据的网格提取与可视化

这里在分享一个人口1km精度栅格数据&#xff0c;LandScan是由美国能源部橡树岭国家实验室&#xff08;ORNL&#xff09;提供的全球人口分布数据集&#xff0c;具有最高分辨率的全球人口分布数据&#xff0c;是全球人口数据发布的社会标准&#xff0c;是全球最为准确、可靠&…

架构设计-分层思想

一、为什么要分层设计&#xff1f; 分层设计是为了剥离硬件环境的依赖&#xff0c;使软件系统更好复用&#xff0c;当更换硬件方案时&#xff0c;只需要修改底层函数的初始化&#xff0c;抽象层和服务层完全不需要改动&#xff0c;这样极大的减小时间成本&#xff0c;平台能够很…

前后端分离项目实战-通用管理系统搭建(前端Vue3+ElementPlus,后端Springboot+Mysql+Redis)第二篇:项目登录功能的实现

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

Element UI左侧导航栏写法(递归组件实现)

1、左侧导航栏组件使用的是Element Ui的导航栏组件&#xff0c;思路&#xff1a;首先判断导航栏数据是否存在children&#xff0c;以此来实现一级菜单与多级菜单的渲染&#xff0c;然后使用递归组件实现多级菜单的子菜单渲染&#xff0c;注意使用递归组件需将菜单栏数据在父组件…

SQL— DDL语句学习【后端 10】

SQL— DDL语句学习 在数据管理的广阔领域中&#xff0c;SQL&#xff08;Structured Query Language&#xff09;作为操作关系型数据库的编程语言&#xff0c;扮演着举足轻重的角色。它不仅定义了操作所有关系型数据库的统一标准&#xff0c;还为我们提供了强大的工具来管理、查…

TypeScript教程(四)type、interface、类型断言、非空断言

上一章我们讲解了Typescript的基础类型&#xff0c;接下来我们就来看看Typescript的、type、interface、类型断言、非空断言 type关键字(类型别名) type 关键字可以帮助我们为现有的类型创建别名&#xff0c;提高代码的可读性和可维护性 在前面&#xff0c;我们通过在类型注解…

一切计算皆AI,开放计算再破局

“OpenAI最差的决定就是没有开放它的大模型。”著名科技预言家凯文凯利在2024年最新演讲中强调开源对于AI发展的重要性。 的确&#xff0c;开源大模型近年来迸发出巨大的产业活力&#xff0c;推动了AI的协作与创新&#xff1a;2023年全球新发布的基础模型中有三分之二为开源模…

随笔二、OV5695摄像头测试

摘要&#xff1a;泰山派开发板SDK使用了GStreamer媒体框架作为音视频的编解码器&#xff0c;支持硬件编解码。开发板提供MIPI_CSI摄像头接口连接摄像头。 1. 摄像头信息 开发板MIPI-CPI接口是30pin、4lane&#xff1b;测试用的OV5696是2lane&#xff0c;像素500万&#xff0c;…

GPU云服务器有什么优点?

云服务器是一种通过互联网提供计算资源和服务的灵活、高性能的解决方案。而随着人工智能及数据密集型应用的迅猛发展&#xff0c;GPU&#xff08;图形处理器&#xff09;云服务器逐渐成为许多企业和个人的优选。下面将介绍GPU云服务器的几个优势。 1、GPU云服务器具备强大的计算…

线程的退出

线程退出方式总结&#xff1a; 1.pthread_exit; void pthread_exit(void *retval); 传的是退出状态值对应的地址 2.执行函数中return 3.pthread_cancel // int pthread_cancel(pthread_t thread); 4.在任何一个线程中调用了exit #include <stdio.h> #include <…

软件测试之Linux系统性能调优技巧

​ 大家好&#xff0c;我是程序员小羊&#xff01; 前言 Linux系统性能调优是一项复杂且系统性的任务&#xff0c;它涉及操作系统内核、硬件资源、应用程序、文件系统、网络设置等多个方面。通过合理的调优策略&#xff0c;可以有效提高Linux系统的性能&#xff0c;满足生产环境…

qt-10基本对话框(文件--颜色--字体)

基本对话框--输入对话框 DialogDialog.hDialog.cpp exdialog.hexdialog.hexdialog.cpp 运行图文件对话框颜色对话框字体对话框输入对话框-字符串输入对话框-选择 Item输入对话框-数字 Dialog Dialog.h #ifndef DIALOG_H #define DIALOG_H#include "exdialog.h"#inc…

数字文创产业园怎么凭借智慧园区建设出圈

在数字化浪潮席卷全球的当下&#xff0c;数字文创产业正以前所未有的速度崛起。而数字文创产业园若想在众多竞争对手中脱颖而出&#xff0c;凭借智慧园区建设出圈无疑是一条明智之路。 首先得明白什么是智慧园区建设&#xff1f; 智慧园区建设指的是通过现代信息技术和智能化手…