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

nginx反向代理及负载均衡

华子目录

  • nginx反向代理功能
  • http反向代理
    • 反向代理配置参数
    • `proxy_pass`的注意事项
    • `案例`:`反向代理`单台`后端服务器`
    • 案例:`反向代理`实现`动静分离`
    • `案例`:`反向代理`的`缓存功能`
      • 非缓存场景下测压
      • 准备缓存
      • 缓存场景下测压
      • 验证缓存文件
  • `反向代理负载均衡(7层)`
    • `upstream`配置参数
    • 负载均衡算法
    • 案例:`反向代理`多台`web服务器`(`轮询`)
    • 案例:`反向代理`多台`web服务器`(`源地址hash调度`)
    • 案例:`反向代理`多台`web服务器`(`对uri进行hash调度`)
    • 案例:`反向代理`多台`web服务器`(`对cookie值进行hash调度`)
    • 案例:`反向代理`多台`web服务器`(`下线`)
  • `反向代理负载均衡(4层)`
    • `案例`:`基于udp`的`dns的负载均衡`
      • `先配置dns服务器`
      • `nginx配置`
    • `案例`:`基于tcp`的`MySQL的负载均衡`
      • 数据库配置
      • `nginx配置`

nginx反向代理功能

在这里插入图片描述

  • 反向代理reverse proxy,指的是代理外网用户的请求内部的指定的服务器,并将数据返回给用户一种方式,这是用的比较多一种方式
  • Nginx除了可以在企业提供高性能web服务之外,另外还可以将nginx本身不具备的请求通过某种预定义的协议转发至其它服务器处理不同的协议就是Nginx服务器其他服务器进行通信一种规范,主要在不同的场景使用以下模块实现不同的功能:
  • ngx_http_proxy_module 将客户端的请求以http协议转发至指定服务器进行处理
  • ngx_http_upstream_module 用于定义为proxy_pass,fastcgi_pass,uwsgi_pass等指令引用的后端服务器分组
  • ngx_stream_proxy_module 将客户端的请求以tcp协议转发至指定服务器处理
  • ngx_http_fastcgi_module 将客户端对php的请求以fastcgi协议转发至指定服务器助理
  • ngx_http_uwsgi_module 将客户端对Python的请求以uwsgi协议转发至指定服务器处理

逻辑调用关系:
在这里插入图片描述
访问逻辑图:
在这里插入图片描述

  • 同构代理用户不需要其他程序参与直接通过http协议或者tcp协议访问后端服务器
  • 异构代理用户访问资源时需要经过处理后才能返回,比如php,python等等,这种访问资源需要经过处理才能被访问

在这里插入图片描述

http反向代理

官方文档:https://nginx.org/en/docs/http/ngx_http_proxy_module.html

反向代理配置参数

  • proxy_pass 用来设置将客户端请求转发给的后端服务器的主机,
  • 可以是主机名:端口IP地址:端口
  • 也可以代理预先设置主机群组,需要模块ngx_http_upstream_module支持
  • proxy_hide_header field 用于nginx作为反向代理的时候,在返回给客户端http响应时,隐藏后端服务器相应头部的信息,可以设置在http,server或location块
#示例: 隐藏后端服务器ETag首部字段
location /web {index index.html;proxy_pass http://10.0.0.18:8080/;proxy_hide_header ETag;
}
  • proxy_pass_header field 透传,默认nginx在响应报文中不传递后端服务器的首部字段Date, Server, X-Pad, X-Accel等参数,如果要传递的话则要使用proxy_pass_header field声明将后端服务器返回的值传递给客户端
  • field 首部字段大小不敏感
#示例:透传后端服务器的Server和Date首部给客户端,同时不再响应报中显示前端服务器的Server字段
proxy_pass_header Server;
proxy_pass_header Date;
  • proxy_pass_request_body on | off 是否向后端服务器发送HTTP实体部分,可以设置在http,server或location块,默认即为开启
  • proxy_pass_request_headers on | off 是否将客户端的请求头部转发给后端服务器,可以设置在http,server或location块,默认即为开启
  • proxy_set_header 可更改或添加客户端的请求头部信息内容并转发至后端服务器,比如在后端服务器想要获取客户端的真实IP的时候,就要更改每一个报文的头部
#示例:
location ~ /web {proxy_pass http://172.25.254.20:80;proxy_hide_header ETag;proxy_pass_header Server;proxy_pass_request_body on;proxy_pass_request_headers on;proxy_set_header X-Forwarded-For $remote_addr;
}
  • proxy_connect_timeout time 配置nginx服务器与后端服务器尝试建立连接的超时时间,默认为60秒
#用法如下:proxy_connect_timeout 60s;
#60s为自定义nginx与后端服务器建立连接的超时时间,超时会返回客户端504响应码
  • proxy_read_timeout time 配置nginx服务器向后端服务器或服务器组发起read请求后,等待的超时时间,默认60s
  • proxy_send_timeout time 配置nginx项后端服务器或服务器组发起write请求后,等待的超时 时间,默认60s
  • proxy_http_version 1.0 用于设置nginx提供代理服务的HTTP协议的版本,默认http 1.0
  • proxy_ignore_client_abort off 当客户端网络中断请求时,nginx服务器中断其对后端服务器的请求。即如果此项设置为on开启,则服务器、会忽略客户端中断并一直等着代理服务执行返回,如果设置为off,则客户端中断后Nginx也会中断客户端请求并立即记录499日志,默认为off

proxy_pass的注意事项

location /web {index index.html;proxy_pass  http://172.25.254.30:8080;
}
#8080后面无uri,即无/符号,会将location后面的url加到proxy_pass指定的url后面,此行为类似于root
#proxy_pass指定的uri不带斜线将访问/web下的内容
  • 如果location定义其uri时使用了正则表达式模式(包括~,~*,但不包括^~),则proxy_pass之后必须不能使用uri。即不能/用户请求时传递的uri直接附加后端服务器之后
location /web {index index.html;proxy_pass  http://172.25.254.30:8080/;
}
#8080后面有uri,即/符号,此行为类似于alias
#proxy_pass指定的uri带斜线等于访问http://172.25.254.30:8080/index.html
  • location中的proxy_pass只能有一个,不能有多个,否则会报错

案例反向代理单台后端服务器

  • nginx服务器172.25.254.100 www.huazi.org
  • web1服务器172.25.254.10
[root@web1 ~]# yum install httpd -y
[root@web1 ~]# echo 172.25.254.10 > /var/www/html/index.html
[root@web1 ~]# systemctl start httpd
[root@nginx-node1 ~]# vim /usr/local/nginx/conf.d/vhosts.conf
server {listen 80;server_name www.huazi.org;location / {proxy_pass http://172.25.254.10:80;}
}[root@nginx-node1 ~]# nginx -s reload

测试:当访问www.huazi.org时,nginx会将请求代理到web1
在这里插入图片描述

案例:反向代理实现动静分离

在这里插入图片描述

  • nginx服务器172.25.254.100 www.huazi.org
  • web1服务器172.25.254.10
  • web2服务器172.25.254.20
[root@web1 ~]# yum install php -y
[root@web1 ~]# vim /var/www/html/index.php
<?phpphpinfo();
?>[root@web1 ~]# systemctl restart httpd
[root@web2 ~]# yum install httpd -y[root@web2 ~]# mkdir -p /var/www/html/static[root@web2 ~]# echo static 172.25.254.20 > /var/www/html/static/index.html[root@web2 ~]# systemctl start httpd
[root@nginx-node1 ~]# vim /usr/local/nginx/conf.d/vhosts.conf
server {listen 80;server_name www.huazi.org;location ~ \.php$ {proxy_pass http://172.25.254.10:80;}location /static {proxy_pass http://172.25.254.20:80;}
}[root@nginx-node1 ~]# nginx -s reload

测试
在这里插入图片描述

在这里插入图片描述

案例反向代理缓存功能

  • proxy_cache zone_name | off; 默认off 指明调用的缓存,或关闭缓存机制
  • zone_name表示缓存的名称,需要由proxy_cache_path事先定义
  • proxy_cache_key string 缓存中用于“键”的内容,默认值:proxy_cache_key $scheme$proxy_host$request_uri;
  • proxy_cache_valid [code ...] time; 定义对特定响应码的响应内容的缓存时长,定义在http{...}中
  • 示例: proxy_cache_valid 200 302 10m; 对于 HTTP 响应状态码为 200(OK)和 302(Found,通常用于临时重定向)的响应,它们将被缓存,并且缓存有效期为 10 分钟(10m)
  • proxy_cache_path 路径 定义可用于proxy功能的缓存
  • proxy_cache_use_stale error | timeout | invalid_header | updating | http_500 | http_502 | http_503 | http_504 | http_403 | http_404 | off ; 默认是off 在被代理的后端服务器出现哪种情况下,可直接使用过期的缓存响应给客户端
  • 示例 proxy_cache_use_stale error http_502 http_503;
  • proxy_cache_methods GET | HEAD | POST ...; 对哪些客户端请求方法对应的响应进行缓存,GET和HEAD方法总是被缓存
#示例:在http配置定义缓存信息
proxy_cache_path  /var/cache/nginx/proxy_cache  levels=1:2:2  keys_zone=proxycache:20m  inactive=120s   max_size=10g;#/var/cache/nginx/proxy_cache  定义缓存保存路径,proxy_cache会自动创建
#levels=1:2:2  定义缓存目录结构层次,1:2:2可以生成2^4x2^8x2^8=2^20=1048576个目录
#keys_zone=proxycache:20m   定义了一个名为proxycache的缓存键区域,并为其分配了20MB的内存,一般1M可存放8000个左右的key
#inactive=120s    缓存有效时间
#max_size=10g    最大磁盘占用空间,磁盘存入文件内容的缓存空间最大值#调用缓存功能,需要定义在相应的配置段,如server{...};或者location等
proxy_cache proxycache;
proxy_cache_key $request_uri; #对指定的数据进行MD5的运算做为缓存的key
proxy_cache_valid 200 302 301 10m; #指定的状态码返回的数据缓存多长时间,10分钟
proxy_cache_valid any 1m; #除指定的状态码返回的数据以外的缓存多长时间,必须设置,否则不会缓存

非缓存场景下测压

[root@web2 ~]# ab -n 1000 -c 100 http://www.huazi.org/static/index.html

在这里插入图片描述

准备缓存

  • 在主配置文件中
[root@nginx-node1 ~]# vim /usr/local/nginx/conf/nginx.conf

在这里插入图片描述

  • proxycache名字可以自定义
[root@nginx-node1 ~]# vim /usr/local/nginx/conf.d/vhosts.conf

在这里插入图片描述

[root@nginx-node1 ~]# nginx -s reload

缓存场景下测压

[root@web2 ~]# ab -n 1000 -c 100 http://www.huazi.org/static/index.html

在这里插入图片描述

  • 发现请求变快了

验证缓存文件

在这里插入图片描述

在这里插入图片描述

反向代理负载均衡(7层)

  • 官方文档: https://nginx.org/en/docs/http/ngx_http_upstream_module.html
  • 上面的案例Nginx可以将客户端请求转发至单台后端服务器但是无法转发特定的一组服务器,而且不能对后端服务器提供相应的服务器状态监测
  • Nginx可以基于ngx_http_upstream_module模块提供服务器分组转发、权重分配、状态监测、调度算法高级功能

upstream配置参数

http {upstream name {server ip:port [params];......................}server {location / {proxy_pass   http://name;}}
}
  • upstream中的server支持的params如下
weight=number   #设置权重,默认为1,实现类似于LVS中的WRR,WLC等
max_conns=number   #给当前后端server设置最大活动链接数,默认为0表示没有限制
max_fails=number   #后端服务器的下线条件,当客户端访问时,对本次调度选中的后端服务器连续进行检测多少次,如果都失败就标记为不可用,默认为1次,当客户端访问时,才会利用TCP触发对探测后端服务器健康性检查,而非周期性的探测
fail_timeout=time   #后端服务器的上线条件,对已经检测到处于不可用的后端服务器,每隔此时间间隔再次进行检测是否恢复可用,如果发现可用,则将后端服务器参与调度,默认为10秒
backup   #设置为备份服务器,当所有后端服务器不可用时,才会启用此备用服务器
down    #标记为down状态,可以平滑下线后端服务器
resolve   #当server定义的是主机名的时候,当A记录发生变化会自动应用新IP而不用重启

负载均衡算法

Nginx支持多种负载均衡算法常见的包括

  • 轮询Round Robin):默认算法,按照顺序请求依次分发到后端服务器
  • 权重Weighted Round Robin):为每个后端服务器设置权重权重高服务器分配的请求更多
  • IP 哈希ip_hash):根据客户端 IP 哈希值决定分发到哪台后端服务器,适用于需要保持会话一致性场景
  • 最少连接least_conn):将请求分配给当前连接数最少后端服务器
  • hash指定字段哈希):基于指定请求字段(如URL、Cookie等)来分配请求

在这里插入图片描述

案例:反向代理多台web服务器轮询

  • 需要location块中的proxy_pass参数upstream块配合使用
  • upstream块server块同级的
[root@nginx-node1 ~]# vim /usr/local/nginx/conf.d/vhosts.conf
upstream webcluster {server 172.25.254.10:80 fail_timeout=15s max_fails=3;server 172.25.254.20:80 fail_timeout=15s max_fails=3;server 172.25.254.100:80 backup;
}server {listen 80;server_name www.huazi.org;location / {proxy_pass  http://webcluster;}
}
  • max_fails=number 后端服务器的下线条件,当客户端访问时,对本次调度选中的后端服务器连续进行检测多少次,如果都失败就标记为不可用,默认为1次,当客户端访问时,才会利用TCP触发对探测后端服务器健康性检查,而非周期性的探测
  • fail_timeout=time 后端服务器的上线条件,对已经检测到处于不可用的后端服务器,每隔此时间间隔再次进行检测是否恢复可用如果发现可用,则将后端服务器参与调度,默认为10秒
  • backup关键字意味着只有当webcluster组中的其他所有服务器不可用时,Nginx才会向这个服务器发送请求
[root@nginx-node1 ~]# nginx -s reload

测试:
在这里插入图片描述

案例:反向代理多台web服务器源地址hash调度

  • ip_hash,就不能有backup
[root@nginx-node1 ~]# vim /usr/local/nginx/conf.d/vhosts.conf
upstream webcluster {ip_hash;server 172.25.254.10:80 fail_timeout=15s max_fails=3;server 172.25.254.20:80 fail_timeout=15s max_fails=3;
}server {listen 80;server_name www.huazi.org;location / {proxy_pass  http://webcluster;}
}
[root@nginx-node1 ~]# nginx -s reload

测试:

在这里插入图片描述

案例:反向代理多台web服务器对uri进行hash调度

[root@nginx-node1 ~]# vim /usr/local/nginx/conf.d/vhosts.conf
upstream webcluster {hash $request_uri consistent;server 172.25.254.10:80 fail_timeout=15s max_fails=3;server 172.25.254.20:80 fail_timeout=15s max_fails=3;
}server {listen 80;server_name www.huazi.org;location / {proxy_pass  http://webcluster;}
}[root@nginx-node1 ~]# nginx -s reload
[root@web1 ~]# mkdir -p /var/www/html/static/
[root@web1 ~]# echo 172.25.254.10 static > /var/www/html/static/index.html

在这里插入图片描述

案例:反向代理多台web服务器对cookie值进行hash调度

[root@nginx-node1 ~]# vim /usr/local/nginx/conf.d/vhosts.conf
upstream webcluster {hash $cookie_huazi;server 172.25.254.10:80 fail_timeout=15s max_fails=3;server 172.25.254.20:80 fail_timeout=15s max_fails=3;
}server {listen 80;server_name www.huazi.org;location / {proxy_pass  http://webcluster;}
}[root@nginx-node1 ~]# nginx -s reload

在这里插入图片描述

案例:反向代理多台web服务器下线

upstream webcluster {hash $cookie_huazi;server 172.25.254.10:80 fail_timeout=15s max_fails=3 down;server 172.25.254.20:80 fail_timeout=15s max_fails=3;
}server {listen 80;server_name www.huazi.org;location / {proxy_pass  http://webcluster;}
}[root@nginx-node1 ~]# nginx -s reload

在这里插入图片描述

反向代理负载均衡(4层)

stream {upstream backend {server backend1.example.com:3306;server backend2.example.com:3306;}server {listen 3306;proxy_pass backend;}
}
  • Nginx1.9.0版本开始支持tcp模式负载均衡,在1.9.13版本开始支持udp协议负载udp主要用于DNS域名解析,其配置方式指令http代理类似,其基于ngx_stream_proxy_module模块实现tcp负载,另外基于模块ngx_stream_upstream_module实现后端服务器分组转发、权重分配、状态监测、调度算法等高级功能
  • 如果编译安装,需要指定--with-stream选项才能支持ngx_stream_proxy_module模块
  • 官方文档:https://nginx.org/en/docs/stream/ngx_stream_proxy_module.html

案例基于udpdns的负载均衡

  • nginx服务器172.25.254.100 www.huazi.org
  • dns1服务器172.25.254.10
  • dns2服务器172.25.254.20

先配置dns服务器

[root@web1 ~]# yum install bind -y[root@web1 ~]# vim /etc/named.conf

在这里插入图片描述

[root@web1 ~]# vim /etc/named.rfc1912.zones

在这里插入图片描述

[root@web1 ~]# cd /var/named/
[root@web1 named]# cp -a named.localhost /var/named/huazi.com.zone
[root@web1 named]# vim huazi.com.zone

在这里插入图片描述

[root@web1 named]# systemctl start named[root@web1 named]# dig www.huazi.com @172.25.254.10

在这里插入图片描述

[root@web2 ~]# yum install bind -y[root@web2 ~]# vim /etc/named.conf

在这里插入图片描述

[root@web2 ~]# vim /etc/named.rfc1912.zones

在这里插入图片描述

[root@web2 ~]# cd /var/named/
[root@web2 named]# cp -a named.localhost /var/named/huazi.com.zone
[root@web2 named]# vim huazi.com.zone

在这里插入图片描述

[root@web2 named]# systemctl start named[root@web2 named]# dig www.huazi.com @172.25.254.20

在这里插入图片描述

nginx配置

  • udp和tcp的负载均衡要写在http块之外
#修改主配置文件
[root@nginx-node1 ~]# vim /usr/local/nginx/conf/nginx.conf

在这里插入图片描述

[root@nginx-node1 ~]# mkdir -p /usr/local/nginx/tcpconf.d/[root@nginx-node1 ~]# vim /usr/local/nginx/tcpconf.d/dns.conf
stream {upstream dns {server 172.25.254.10:53 fail_timeout=15s max_fails=3;server 172.25.254.20:53 fail_timeout=15s max_fails=3;}server {listen 53 udp reuseport;proxy_timeout 20s;proxy_pass dns;}
}[root@nginx-node1 ~]# nginx -s reload

测试

在这里插入图片描述

  • 100上没有dns服务dig却可以指定100,通过100进行代理

案例基于tcpMySQL的负载均衡

  • nginx服务器172.25.254.100 www.huazi.org
  • MySQL1服务器172.25.254.10
  • MySQL2服务器172.25.254.20

数据库配置

[root@web1 ~]# yum install mariadb-server -y[root@web2 ~]# yum install mariadb-server -y
[root@web1 ~]# vim /etc/my.cnf.d/mariadb-server.cnf

在这里插入图片描述

[root@web2 ~]# vim /etc/my.cnf.d/mariadb-server.cnf

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

nginx配置

[root@nginx-node1 ~]# vim /usr/local/nginx/tcpconf.d/dns.conf

在这里插入图片描述

[root@nginx-node1 ~]# nginx -s reload
  • 下载MySQL的客户端
[root@nginx-node1 ~]# yum install mariadb -y

测试

在这里插入图片描述

相关文章:

nginx反向代理及负载均衡

华子目录 nginx反向代理功能http反向代理反向代理配置参数proxy_pass的注意事项案例&#xff1a;反向代理单台后端服务器案例&#xff1a;反向代理实现动静分离案例&#xff1a;反向代理的缓存功能非缓存场景下测压准备缓存缓存场景下测压验证缓存文件 反向代理负载均衡&#x…...

单片机实物成品-011 火灾监测

火灾监测&#xff08;20个版本&#xff09; 版本20&#xff1a; oled显示温湿度烟雾浓度火焰传感器天然气浓度窗户风扇水泵排气系统声光报警语音播报按键WIFI模块 ----------------------------------------------------------------------------- https://www.bilibili.com…...

使用 Docker 在 Alpine Linux 下部署 Caddy 服务器

简介 在现代 web 开发中&#xff0c;选择合适的 web 服务器至关重要。Caddy 是一个功能强大的现代化 HTTP/2 服务器&#xff0c;支持自动 HTTPS&#xff0c;配置简单&#xff0c;适合开发和生产环境。Docker 则为我们提供了一种轻量级的容器化技术&#xff0c;使得应用程序的部…...

每日十题八股-2025年1月12日

1.为什么四次挥手之后要等2MSL? 2.服务端出现大量的timewait有哪些原因? 3.TCP和UDP区别是什么&#xff1f; 4.TCP为什么可靠传输 5.怎么用udp实现http&#xff1f; 6.tcp粘包怎么解决&#xff1f; 7.TCP的拥塞控制介绍一下&#xff1f; 8.描述一下打开百度首页后发生的网络过…...

Python中定位包含特定文本信息的元素

目录 一、为什么需要定位包含文本信息的元素 二、使用Selenium定位包含文本的元素 1. 使用find_element_by_link_text 2. 使用find_element_by_partial_link_text 3. 使用XPath定位包含文本的元素 4. 使用CSS选择器定位包含文本的元素 三、使用BeautifulSoup定位包含文本…...

uniapp实现H5页面内容居中与两边留白,打造类似微信公众号阅读体验

在 UniApp 中&#xff0c;由于需要兼容多端应用&#xff0c;我们通常使用 rpx 作为尺寸单位。然而&#xff0c;在某些情况下&#xff0c;如需要实现内容居中且两边留白时&#xff0c;直接使用 rpx 可能会带来一些限制。这时&#xff0c;我们可以考虑使用 px 或 rem 等单位&…...

极品飞车6里的赛道简介

极品飞车里有很多赛道,赛道分为前向赛道Forward、后向赛道Backward。前向赛道Forward是从A点到B点;后向赛道Backward是前向赛道的逆过程,即从B点到A点。这里介绍极品飞车6的赛道长度、中英文名称翻译、难度等级。 序号赛道英文名赛道中文名总长(km)急弯难度等级1Alpine Trai…...

SAP推出云端ERP解决方案,加速零售行业数字化转型

2025年1月9日&#xff0c;SAP发布了一款专为零售行业设计的云端ERP行业解决方案——S/4HANA Cloud Public Edition&#xff0c;进一步推动企业向云端迁移。这款解决方案旨在集中运营数据&#xff0c;整合财务、采购和商品管理流程&#xff0c;以帮助零售企业优化运营效率。 核…...

Python爬虫进阶——案例:模拟bilibili登录)

主要内容&#xff1a;模拟bilibili账号密码登录&#xff0c;不要实现的的实现功能是单击登录按钮&#xff0c;切换登录方式&#xff0c; 输入账号和密码&#xff0c;然后完成图片点击验证&#xff0c;最后单击立即登录按钮。 1、第一步&#xff1a;通过selenium模块访问bilibi…...

什么是数据分析?

什么是数据分析&#xff1f; 数据分析&#xff08;Data Analysis&#xff09;是指通过对数据进行收集、整理、处理、建模和解读&#xff0c;以揭示数据中的有用信息、支持决策和解决实际问题的过程。它是一门将数据转化为知识的学科&#xff0c;广泛应用于商业、科学研究、医疗…...

基于springboot的课程作业管理系统源码(springboot+vue+mysql)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的课程作业管理系统。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 项目简介&#xff1a; 可以管理首页、个人中心…...

多线程之旅:属性及其基本操作

上次分享到了&#xff0c;多线程中是是如何创建的&#xff0c;那么接下来&#xff0c;小编继续分享下多线程的相关知识。 多线程中的一些基本属性。 基本属性 属性获取方法IDgetId()名称getName()状态getState()优先级getPriority()是否后台线程isDemo()是否存活isAlive()是…...

数据表中的数据插入、更新和删除

文章目录 一、表的插入二、更新表中的数据记录三、删除表中的数据记录 一、表的插入 插入数据记录是常见的数据操作&#xff0c;可以显示向表中增加的新的数据记录。在MySQL中可以通过“INSERT INTO”语句来实现插入数据记录&#xff0c;该SQL语句可以通过如下4种方式使用&…...

Q_OBJECT宏报错的问题

在Qt中继承QObject&#xff0c;并且加上Q_OBJECT宏&#xff0c;有时候会报错&#xff0c;比如我的错误&#xff1a; error: debug/httpmgr.o:httpmgr.cpp:(.rdata$.refptr._ZTV7HttpMgr[.refptr._ZTV7HttpMgr]0x0): undefined reference to vtable for HttpMgr 意思是没有虚…...

提升性能300ms:深入解析Spring多表联接查询优化与SQL调优实战

优化所需知识点&#xff08;必须掌握&#xff09; 索引篇 explain命令 重点&#xff1a;这是后续分析是否使用索引以及使用是否恰当的工具 作用&#xff1a;查看sql的执行计划&#xff0c;可以看sql语句是否使用了索引&#xff0c;索引的使用情况&#xff0c;以及sql的性能。 …...

增量导入和全量导入的区别是什么?

定义 全量导入&#xff1a;是指将数据源中的所有数据一次性全部导入到目标系统中。例如&#xff0c;一个电商公司要将其旧数据库中的所有商品信息&#xff08;包括商品名称、价格、库存等&#xff09;全部迁移到新的数据库系统中&#xff0c;这个过程就是全量导入。这种方式会覆…...

【百度智能云客悦智能客服】搭建AI agent智能对话 - 购车推荐

前期准备 平台链接&#xff1a;https://keyue.cloud.baidu.com/ 一、开始创建 二、会话流程配置 我们以购车推荐的案例&#xff0c;来进行 AI agent 配置演示 1.添加开场白 在 起始主题 画布中&#xff0c;我们可以配置 AI agent 的开场白&#xff0c;画布左侧默认有 开始 …...

【HTML+CSS+JS+VUE】web前端教程-3-标题标签

标题介绍与应用 标题是通过<h1>-<h6>标签进行定义的 <h1>定义最大的标题 <h6>定义最小的标题<h1...

逐笔成交逐笔委托Level2高频数据下载和分析:20250102

level2逐笔成交逐笔委托下载 链接: https://pan.baidu.com/s/1p7OOj5p-QGFrWkt6KKoYng?pwd7f4g 提取码: 7f4g Level2逐笔成交逐笔委托数据分享下载 通过Level2逐笔成交和逐笔委托这种每一笔的毫秒级别的数据可以分析出很多有用的点&#xff0c;包括主力意图&#xff0c;虚假动…...

JavaEE之线程池

前面我们了解了多个任务可以通过创建多个线程去处理&#xff0c;达到节约时间的效果&#xff0c;但是每一次的线程创建和销毁也是会消耗计算机资源的&#xff0c;那么我们是否可以将线程进阶一下&#xff0c;让消耗计算机的资源尽可能缩小呢&#xff1f;线程池可以达到此效果&a…...

java 中 main 方法使用 KafkaConsumer 拉取 kafka 消息如何禁止输出 debug 日志

pom 依赖&#xff1a; <dependency><groupId>org.springframework.kafka</groupId><artifactId>spring-kafka</artifactId><version>2.5.14.RELEASE</version> </dependency> 或者 <dependency><groupId>org.ap…...

【后端面试总结】Golang可能的内存泄漏场景及应对策略

Golang可能的内存泄漏场景及应对策略 一、引言 Golang作为一种高性能、并发友好的编程语言&#xff0c;其内置的垃圾回收机制极大地简化了内存管理。然而&#xff0c;这并不意味着开发者可以完全忽视内存泄漏问题。在实际开发中&#xff0c;由于不当的资源管理、循环引用、以…...

Java 反射机制详解

在 Java 编程世界中&#xff0c;反射机制犹如一把神奇的钥匙&#xff0c;它能够打开许多隐藏在代码深处的 “大门”&#xff0c;让开发者突破常规的限制&#xff0c;实现一些极具灵活性的功能。今天&#xff0c;就跟随我一同深入探究 Java 反射机制的奥秘。 一、什么是反射 反…...

【k8s】scc权限 restricted、anyuid、privileged

文章目录 概述1. 内置的scc2. OpenShift如何确定pod的scc2.1 Pod未带SCC标签的情况2.2. Pod带有SCC标签的情况 参考 概述 在OpenShift&#xff08;后文简称OCP&#xff09;中&#xff0c;很早就一个概念&#xff1a;Security Context Constraints &#xff0c;简称SCC&#xf…...

2025华数杯国际赛A题完整论文讲解(含每一问python代码+数据+可视化图)

大家好呀&#xff0c;从发布赛题一直到现在&#xff0c;总算完成了2025“华数杯”国际大学生数学建模竞赛A题Can He Swim Faster的完整的成品论文。 本论文可以保证原创&#xff0c;保证高质量。绝不是随便引用一大堆模型和代码复制粘贴进来完全没有应用糊弄人的垃圾半成品论文…...

ThreadLocal 的使用场景

在现代电商平台中&#xff0c;ThreadLocal 常用于以下场景&#xff0c;特别是与线程隔离相关的业务中&#xff0c;以提高性能和简化上下文传递。 1. 用户上下文信息管理 场景&#xff1a;在用户发起的每次请求中&#xff0c;需要携带用户 ID、角色、权限等信息&#xff0c;而这…...

后端开发 Springboot整合Redis Spring Data Redis 模板

目录 redis 配置 RedisConfig 类 完整代码 代码讲解 1. 类定义和注解 2. 定义 RedisTemplate Bean 3. 配置 JSON 序列化 4. 配置 Redis 的 key 和 value 序列化方式 5. 完成配置并返回 RedisTemplate 总结 redis 服务接口实现类 类级别 注入 RedisTemplate 常用 Re…...

代码随想录算法训练营第 4 天(链表 2)| 24. 两两交换链表中的节点19.删除链表的倒数第N个节点 -

一、24. 两两交换链表中的节点 题目&#xff1a;24. 两两交换链表中的节点 - 力扣&#xff08;LeetCode&#xff09; 视频&#xff1a;帮你把链表细节学清楚&#xff01; | LeetCode&#xff1a;24. 两两交换链表中的节点_哔哩哔哩_bilibili 讲解&#xff1a;代码随想录 dummy-…...

【RDMA学习笔记】1:RDMA(Remote Direct Memory Access)介绍

从帝国理工的PPT学习。 什么是RDMA Remote Direct Memory Access&#xff0c;也就是Remote的DMA&#xff0c;是一种硬件机制&#xff0c;能直接访问远端结点的内存&#xff0c;而不需要处理器介入。 其中&#xff1a; Remote&#xff1a;跨node进行数据传输Direct&#xff…...

网络安全常见的35个安全框架及模型

大家读完觉得有帮助记得关注和点赞&#xff01;&#xff01;&#xff01; 01、概述 网络安全专业机构制定的一套标准、准则和程序&#xff0c;旨在帮助组织了解和管理面临的网络安全风险。优秀的安全框架及模型应该为用户提供一种可靠方法&#xff0c;帮助其实现网络安全建设…...

个人网站开发要多久/站长之家端口扫描

?当linux运行久点&#xff0c;会产生很多不必要的cache或者buff,导致占用太多的内存&#xff0c;其实这可以手动去释放它。[rootDD-Server-9F ~]# freetotal used free shared buff/cache availableMem: 8073628 1374360 2004964 385620 4694304 5820840Swap: 8388604 0 83886…...

重庆网站制作公司 /电话营销话术

对于一个 Linux 驱动使一个进程睡眠是一个容易做的事情. 但是, 有几个规则必须记住以安全的方式编码睡眠. 这些规则的第一个是: 当你运行在原子上下文时不能睡眠. 我们在第 5 章介绍过原子操作; 一个原子上下文只是一个状态, 这里多个步骤必须在没有任何类型的并发存取的情况下…...

怎么制造网站/重庆公司seo

void ExitProcess( UINT uExitCode ); ExitProcess是一个API函数&#xff0c;它会结束当前应用程序的执行&#xff0c;并设置它的退出代码。uExitCode是此程序的退出代码。虽然可以在程序的任何地方去调用ExitProcess&#xff0c;强制当前程序的执行立即结束。对于操作系统来说…...

21年网站搭建公司排行榜/seo报名在线咨询

文章目录一、Json数据交互介绍1.keyvalue形式2.Json形式二、测试Json数据交互1.导入项目需要的jar包2.Json测试页面3.Handler处理器4.pojo类5.Json数据交互测试一、Json数据交互介绍 客户端在向handler处理器发送请求时&#xff0c;有两种形式&#xff1a; keyvalue形式Json形式…...

厦门网站建设官网/自己创建网页

《一次函数的图像与性质》这节课主要是在学生学习了一次函数的概念&#xff0c;一般形式&#xff0c;以及掌握一次函数图像画法的基础上&#xff0c;安排学生通过几组函数图像的特点和函数解析式之间关系归纳总结函数图像的一般规律。掌握一次函数的图像和性质。掌握一次函数两…...

植物园门户网站建设方案/游戏搜索风云榜

xx转载于:https://www.cnblogs.com/lxzl/p/11184540.html...