Python爬虫(48)基于Scrapy-Redis与深度强化学习的智能分布式爬虫架构设计与实践
目录
- 一、背景与行业痛点
- 二、核心技术架构设计
- 2.1 分布式爬虫基础架构
- 2.2 深度强化学习模块
- 三、生产环境实践案例
- 3.1 电商价格监控系统
- 3.2 学术文献采集系统
- 四、高级优化技术
- 4.1 联邦学习增强
- 4.2 神经架构搜索(NAS)
- 五、总结
- 🌈Python爬虫相关文章(推荐)

一、背景与行业痛点
在万物互联时代,企业需要处理的数据规模呈指数级增长。某头部电商比价平台曾面临以下核心挑战:
反爬对抗升级:目标站点部署AI驱动的反爬系统,传统规则引擎误封率达37%
动态内容陷阱:JavaScript渲染页面占比超65%,传统Scrapy解析失败率达42%
资源分配失衡:固定爬虫集群在闲时CPU利用率不足8%,忙时请求超时率飙升至23%
数据质量波动:重要页面因未及时重试导致数据完整率仅68%
基于此背景,我们创新性地提出将Scrapy-Redis分布式架构与深度强化学习(DRL)相结合,构建具备自我进化能力的智能爬虫系统。该方案使数据采集完整率提升至99.2%,反爬误封率降至0.8%,资源利用率优化至72%。
二、核心技术架构设计
2.1 分布式爬虫基础架构
关键组件说明:
Scrapy-Redis集群:
定制化调度器:实现优先级队列+重试队列双缓冲机制
动态去重策略:结合Bloom Filter与HyperLogLog,误判率<0.03%
智能代理池:
动态IP评分系统:根据延迟/成功率/匿名度三维度评分
异常IP自动隔离:连续失败5次自动进入隔离区(冷却时间指数增长)
渲染服务:
Chrome无头模式池化:通过Docker Swarm实现弹性伸缩
智能渲染决策:对含SPA页面自动触发渲染(基于页面特征分类器)
2.2 深度强化学习模块
import tensorflow as tf
from tensorflow.keras import layersclass DRLScheduler:def __init__(self):# 状态空间定义self.state_dim = 12 # 包含QPS/延迟/成功率等12维特征# 动作空间定义self.action_space = ['increase_concurrency','decrease_concurrency','switch_proxy','trigger_render','retry_later']# DQN网络结构self.model = tf.keras.Sequential([layers.Dense(64, activation='relu', input_shape=(self.state_dim,)),layers.Dense(32, activation='relu'),layers.Dense(len(self.action_space), activation='linear')])def get_action(self, state):q_values = self.model.predict(state.reshape(1, -1))return self.action_space[np.argmax(q_values)]
核心设计原则:
状态表示:
实时指标:当前QPS、平均响应时间、5xx错误率
历史特征:过5分钟窗口指标的移动平均
环境上下文:目标站点反爬策略版本(通过指纹识别)
奖励函数:
动态权重调整:根据业务优先级自动调节w1 ,w2 ,w3
探索策略:
ε-greedy改进版:ε值随训练进程动态衰减(从0.5→0.05)
经验回放:优先回放高TD误差的样本(PER机制)
三、生产环境实践案例
3.1 电商价格监控系统
场景描述:
需实时采集10万+商品SKU的价格/库存信息
目标站点采用IP轮询+设备指纹+行为验证三级防护
实施效果:
指标 | 传统方案 | DRL方案 | 提升幅度 |
---|---|---|---|
数据时效性 | 4小时 | 8分钟 | 3000% |
反爬误封率 | 32% | 0.9% | 97.2% |
资源利用率 | 15% | 68% | 353% |
月度封禁成本 | $8,200 | $120 | 98.5% |
关键技术决策:
动作空间扩展:增加change_user_agent和solve_captcha动作
奖励函数定制:增加-50 * 验证码出现次数惩罚项
冷启动策略:使用专家轨迹进行预训练(从历史日志提取优质决策序列)
3.2 学术文献采集系统
- 场景描述:
需采集万方、维普等学术站点的PDF全文
面临动态加载+登录验证+访问频控多重挑战
- 创新解决方案:
状态空间增强:
添加session_age特征(会话存活时间)
引入document_complexity特征(通过DOM树深度计算)
多层级决策:
第一层:选择爬取策略(直接请求/模拟登录/Cookie池)
第二层:动态调整请求头参数(Accept-Encoding/Cache-Control)
自动特征工程:
使用TSNE对历史状态进行降维可视化
通过SHAP值解释模型决策依据
- 实施效果:
文献采集完整率从62%提升至99.3%
平均每篇文档采集成本从0.18降至0.03
成功突破某学术站点新反爬策略(检测到72小时内自动适配)
四、高级优化技术
4.1 联邦学习增强
# 联邦学习服务器端核心逻辑
class FedAvgServer:def __init__(self, num_clients):self.client_models = [DQN() for _ in range(num_clients)]self.global_model = DQN()def aggregate(self):# 模型聚合算法(FedAvg变种)total_weight = sum(model.trainable_weights for model in self.client_models)for layer in self.global_model.layers:new_weights = []for i in range(len(layer.weights)):agg_weight = sum(model.layers[layer.name].weights[i] * model.sample_count for model in self.client_models) / total_weightnew_weights.append(agg_weight)layer.set_weights(new_weights)
实现价值:
跨爬虫节点模型聚合,解决数据孤岛问题
差分隐私保护:在模型更新时添加高斯噪声(σ=0.1)
模型版本控制:支持回滚至历史版本(保留最近5个检查点)
4.2 神经架构搜索(NAS)
# 基于ENAS的搜索空间定义
class SearchSpace:def __init__(self):self.layers = [{'type': 'conv2d', 'filters': [16,32,64]},{'type': 'lstm', 'units': [64,128,256]},{'type': 'attention', 'heads': [4,8,16]}]self.connections = [{'from': 0, 'to': [1,2]},{'from': 1, 'to': [2]}]# 控制器RNN
controller_rnn = tf.keras.Sequential([layers.Embedding(input_dim=100, output_dim=64),layers.LSTM(128),layers.Dense(len(search_space.layers)*3 + len(search_space.connections)*2)
])
技术优势:
自动搜索最优网络结构(发现比人工设计更优的Q网络)
搜索效率提升10倍(通过参数共享机制)
支持结构化输出(生成可解释的模型架构)
五、总结
本方案通过Scrapy-Redis与深度强化学习的深度融合,实现了:
智能进化:模型在生产环境持续学习,策略准确率周提升2.3%
自适应调度:根据实时流量自动调整爬取策略(响应时间<200ms)
成本最优:实现单位数据采集成本下降78%
🌈Python爬虫相关文章(推荐)
Python爬虫介绍 | Python爬虫(1)Python爬虫:从原理到实战,一文掌握数据采集核心技术 |
HTTP协议解析 | Python爬虫(2)Python爬虫入门:从HTTP协议解析到豆瓣电影数据抓取实战 |
HTML核心技巧 | Python爬虫(3)HTML核心技巧:从零掌握class与id选择器,精准定位网页元素 |
CSS核心机制 | Python爬虫(4)CSS核心机制:全面解析选择器分类、用法与实战应用 |
静态页面抓取实战 | Python爬虫(5)静态页面抓取实战:requests库请求头配置与反反爬策略详解 |
静态页面解析实战 | Python爬虫(6)静态页面解析实战:BeautifulSoup与lxml(XPath)高效提取数据指南 |
Python数据存储实战 CSV文件 | Python爬虫(7)Python数据存储实战:CSV文件读写与复杂数据处理指南 |
Python数据存储实战 JSON文件 | Python爬虫(8)Python数据存储实战:JSON文件读写与复杂结构化数据处理指南 |
Python数据存储实战 MySQL数据库 | Python爬虫(9)Python数据存储实战:基于pymysql的MySQL数据库操作详解 |
Python数据存储实战 MongoDB数据库 | Python爬虫(10)Python数据存储实战:基于pymongo的MongoDB开发深度指南 |
Python数据存储实战 NoSQL数据库 | Python爬虫(11)Python数据存储实战:深入解析NoSQL数据库的核心应用与实战 |
Python爬虫数据存储必备技能:JSON Schema校验 | Python爬虫(12)Python爬虫数据存储必备技能:JSON Schema校验实战与数据质量守护 |
Python爬虫数据安全存储指南:AES加密 | Python爬虫(13)数据安全存储指南:AES加密实战与敏感数据防护策略 |
Python爬虫数据存储新范式:云原生NoSQL服务 | Python爬虫(14)Python爬虫数据存储新范式:云原生NoSQL服务实战与运维成本革命 |
Python爬虫数据存储新维度:AI驱动的数据库自治 | Python爬虫(15)Python爬虫数据存储新维度:AI驱动的数据库自治与智能优化实战 |
Python爬虫数据存储新维度:Redis Edge近端计算赋能 | Python爬虫(16)Python爬虫数据存储新维度:Redis Edge近端计算赋能实时数据处理革命 |
反爬攻防战:随机请求头实战指南 | Python爬虫(17)反爬攻防战:随机请求头实战指南(fake_useragent库深度解析) |
反爬攻防战:动态IP池构建与代理IP | Python爬虫(18)反爬攻防战:动态IP池构建与代理IP实战指南(突破95%反爬封禁率) |
Python爬虫破局动态页面:全链路解析 | Python爬虫(19)Python爬虫破局动态页面:逆向工程与无头浏览器全链路解析(从原理到企业级实战) |
Python爬虫数据存储技巧:二进制格式性能优化 | Python爬虫(20)Python爬虫数据存储技巧:二进制格式(Pickle/Parquet)性能优化实战 |
Python爬虫进阶:Selenium自动化处理动态页面 | Python爬虫(21)Python爬虫进阶:Selenium自动化处理动态页面实战解析 |
Python爬虫:Scrapy框架动态页面爬取与高效数据管道设计 | Python爬虫(22)Python爬虫进阶:Scrapy框架动态页面爬取与高效数据管道设计 |
Python爬虫性能飞跃:多线程与异步IO双引擎加速实战 | Python爬虫(23)Python爬虫性能飞跃:多线程与异步IO双引擎加速实战(concurrent.futures/aiohttp) |
Python分布式爬虫架构实战:Scrapy-Redis亿级数据抓取方案设计 | Python爬虫(24)Python分布式爬虫架构实战:Scrapy-Redis亿级数据抓取方案设计 |
Python爬虫数据清洗实战:Pandas结构化数据处理全指南 | Python爬虫(25)Python爬虫数据清洗实战:Pandas结构化数据处理全指南(去重/缺失值/异常值) |
Python爬虫高阶:Scrapy+Selenium分布式动态爬虫架构实践 | Python爬虫(26)Python爬虫高阶:Scrapy+Selenium分布式动态爬虫架构实践 |
Python爬虫高阶:双剑合璧Selenium动态渲染+BeautifulSoup静态解析实战 | Python爬虫(27)Python爬虫高阶:双剑合璧Selenium动态渲染+BeautifulSoup静态解析实战 |
Python爬虫高阶:Selenium+Splash双引擎渲染实战与性能优化 | Python爬虫(28)Python爬虫高阶:Selenium+Splash双引擎渲染实战与性能优化 |
Python爬虫高阶:动态页面处理与云原生部署全链路实践(Selenium、Scrapy、K8s) | Python爬虫(29)Python爬虫高阶:动态页面处理与云原生部署全链路实践(Selenium、Scrapy、K8s) |
Python爬虫高阶:Selenium+Scrapy+Playwright融合架构 | Python爬虫(30)Python爬虫高阶:Selenium+Scrapy+Playwright融合架构,攻克动态页面与高反爬场景 |
Python爬虫高阶:动态页面处理与Scrapy+Selenium+Celery弹性伸缩架构实战 | Python爬虫(31)Python爬虫高阶:动态页面处理与Scrapy+Selenium+Celery弹性伸缩架构实战 |
Python爬虫高阶:Scrapy+Selenium+BeautifulSoup分布式架构深度解析实战 | Python爬虫(32)Python爬虫高阶:动态页面处理与Scrapy+Selenium+BeautifulSoup分布式架构深度解析实战 |
Python爬虫高阶:动态页面破解与验证码OCR识别全流程实战 | Python爬虫(33)Python爬虫高阶:动态页面破解与验证码OCR识别全流程实战 |
Python爬虫高阶:动态页面处理与Playwright增强控制深度解析 | Python爬虫(34)Python爬虫高阶:动态页面处理与Playwright增强控制深度解析 |
Python爬虫高阶:基于Docker集群的动态页面自动化采集系统实战 | Python爬虫(35)Python爬虫高阶:基于Docker集群的动态页面自动化采集系统实战 |
Python爬虫高阶:Splash渲染引擎+OpenCV验证码识别实战指南 | Python爬虫(36)Python爬虫高阶:Splash渲染引擎+OpenCV验证码识别实战指南 |
从Selenium到Scrapy-Playwright:Python动态爬虫架构演进与复杂交互破解全攻略 | Python爬虫(38)从Selenium到Scrapy-Playwright:Python动态爬虫架构演进与复杂交互破解全攻略 |
基于Python的动态爬虫架构升级:Selenium+Scrapy+Kafka构建高并发实时数据管道 | Python爬虫(39)基于Python的动态爬虫架构升级:Selenium+Scrapy+Kafka构建高并发实时数据管道 |
基于Selenium与ScrapyRT构建高并发动态网页爬虫架构:原理、实现与性能优化 | Python爬虫(40)基于Selenium与ScrapyRT构建高并发动态网页爬虫架构:原理、实现与性能优化 |
Serverless时代爬虫架构革新:Python多线程/异步协同与AWS Lambda/Azure Functions深度实践 | Python爬虫(42)Serverless时代爬虫架构革新:Python多线程/异步协同与AWS Lambda/Azure Functions深度实践 |
智能爬虫架构演进:Python异步协同+分布式调度+AI自进化采集策略深度实践 | Python爬虫(43)智能爬虫架构演进:Python异步协同+分布式调度+AI自进化采集策略深度实践 |
Python爬虫架构进化论:从异步并发到边缘计算的分布式抓取实践 | Python爬虫(44)Python爬虫架构进化论:从异步并发到边缘计算的分布式抓取实践 |
Python爬虫攻防战:异步并发+AI反爬识别的技术解密(万字实战) | Python爬虫(45)Python爬虫攻防战:异步并发+AI反爬识别的技术解密(万字实战) |
Python爬虫进阶:多线程异步抓取与WebAssembly反加密实战指南 | Python爬虫(46) Python爬虫进阶:多线程异步抓取与WebAssembly反加密实战指南 |
Python异步爬虫与K8S弹性伸缩:构建百万级并发数据采集引擎 | Python爬虫(47)Python异步爬虫与K8S弹性伸缩:构建百万级并发数据采集引擎 |
相关文章:

Python爬虫(48)基于Scrapy-Redis与深度强化学习的智能分布式爬虫架构设计与实践
目录 一、背景与行业痛点二、核心技术架构设计2.1 分布式爬虫基础架构2.2 深度强化学习模块 三、生产环境实践案例3.1 电商价格监控系统3.2 学术文献采集系统 四、高级优化技术4.1 联邦学习增强4.2 神经架构搜索(NAS) 五、总结🌈Python爬虫相…...
AtCoder Beginner Contest 407 E - Most Valuable Parentheses
AtCoder Beginner Contest 407 E - Most Valuable Parentheses E - Most Valuable Parentheses 反悔贪心算法 性质: 假设长度为 n n n, n ≡ 0 ( m o d 2 ) n \equiv 0 \pmod{2} n≡0(mod2) 的括号序列是合法的,那么有 n 2 \frac{n}{2}…...

(1-6-3)Java 多线程
目录 0.知识拓扑 1. 多线程相关概念 1.1 进程 1.2 线程 1.3 java 中的进程 与 线程概述 1.4 CPU、进程 与 线程的关系 2.多线程的创建方式 2.1 继承Thread类 2.2 实现Runnable接口 2.3 实现Callable接口 2.4 三种创建方式对比 3.线程同步 3.1 线程同步机制概述 …...

java31
1.网络编程 三要素: 网址实质上就是ip InetAddress: UDP通信程序: 多个接收端的地址都要加入同一个组播地址,这样发送端发信息,全部接收端都能接受到数据 广播的代码差不多,就是地址不一样而已 TCP通信程序…...
多模态之智能数字人
多模态下智能数字人的开发是一个复杂且系统性的工程,它融合了人工智能(AI)、计算机图形学、自然语言处理(NLP)、语音技术、计算机视觉(CV)等多个前沿领域。 多模态下智能数字人的开发流程规范 目标: 构建一个能够理解并生成多模态信息(文本、语音、视觉等),具备智…...

界面组件DevExpress WPF中文教程:Grid - 如何识别行和卡片?
DevExpress WPF拥有120个控件和库,将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序,这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件…...

【HarmonyOS Next之旅】DevEco Studio使用指南(三十)
目录 1 -> 部署云侧工程 2 -> 通过CloudDev面板获取云开发资源支持 3 -> 通用云开发模板 3.1 -> 适用范围 3.2 -> 效果图 4 -> 总结 1 -> 部署云侧工程 可以选择在云函数和云数据库全部开发完成后,将整个云工程资源统一部署到AGC云端。…...

AI基础知识(LLM、prompt、rag、embedding、rerank、mcp、agent、多模态)
AI基础知识(LLM、prompt、rag、embedding、rerank、mcp、agent、多模态) 1、LLM大语言模型 --基于深度学习技术,通过海量文本数据训练而成的超大规模人工智能模型,能够理解、生成和推理自然语言文本 --产品&…...

[蓝桥杯]高僧斗法
高僧斗法 题目描述 古时丧葬活动中经常请高僧做法事。仪式结束后,有时会有"高僧斗法"的趣味节目,以舒缓压抑的气氛。 节目大略步骤为:先用粮食(一般是稻米)在地上"画"出若干级台阶(…...

pycharm F2 修改文件名 修改快捷键
菜单:File-> Setting, Keymap中搜索 Rename, 其中,有 Refactor-> Rename,右键添加快捷键,F2,删除原有快捷键就可以了。...

Python Flask中启用AWS Secrets Manager+AWS Parameter Store配置中心
问题 最近需要改造一个Python的Flask项目。需要在这个项目中添加AWS Secrets Manager作为配置中心,主要是数据库相关配置。 前提 得预先在Amazon RDS里面新建好数据库用户和数据库,以AWS Aurora为例子,建库和建用户语句类似如下࿱…...

机器学习与深度学习10-支持向量机02
目录 前文回顾6.如何构建SVM7.SVM与多分类问题8.SVM与逻辑回归9.SVM的可扩展性10.SVM的适用性和局限性 前文回顾 上一篇文章链接:地址 6.如何构建SVM 选择合适的核函数和超参数来构建支持向量机(SVM)模型通常需要一定的经验和实验。以下是…...
《深入解析UART协议及其硬件实现》-- 第二篇:UART硬件架构设计与FPGA实现
第二篇:UART硬件架构设计与FPGA实现 1. 模块化架构设计 1.1 系统级框图与时钟域划分 核心模块划分 : 发送模块(TX) :负责数据帧组装与串行输出。 接收模块(RX) :负责串行数据采样与…...
java swing 晃动鼠标改变背景颜色
import java.awt.Color; import java.awt.Component; import java.awt.event.MouseEvent; import java.awt.event.MouseMotionListener;import javax.swing.*; public class testA extends JFrame {testA(){super("晃动鼠标改变背景颜色");setBounds(600, 200, 600, …...

HikariCP 可观测性最佳实践
HikariCP 介绍 HikariCP 是一个高性能、轻量级的 JDBC 连接池,由 Brett Wooldridge 开发。它以“光”命名,象征快速高效。它支持多种数据库,配置简单,通过字节码优化和智能管理,实现低延迟和高并发处理。它还具备自动…...

简简单单探讨下starter
前言 今天其实首先想跟大家探讨下:微服务架构,分业务线了,接入第三方服务、包啥的是否自己定义一个stater更好? 一、starter是什么? 在 Spring Boot 中,Starter 是一种特殊的依赖模块,用于快速…...

PyTest框架学习
0. 优先查看学习教程 超棒的学习教程 1. yield 语句 yield ptc_udp_clientyield:在 Pytest fixture 中,yield 用于分隔设置和清理代码。yield 之前的代码在测试用例执行前运行,yield 之后的代码在测试用例执行后运行。ptc_udp_client&…...

SIP、SAP、SDP、mDNS、SSH、PTP
🌈 一、SIP 会话初始协议 会话初始协议 SIP 是一个在 IP 网络上进行多媒体通信的应用层控制协议,它被用来创建、修改和终结 1 / n 个参加者参加的会话进程。SIP 不能单独完成呼叫功能,需要和 RTP、SDP 和 DNS 配合来完成。 1. SIP 协议的功…...

【AI学习笔记】Coze工作流写入飞书多维表格(即:多维表格飞书官方插件使用教程)
背景前摇: 今天遇到一个需求,需要把Coze平台大模型和用户的对话记录保存进飞书表格,这个思路其实不难,因为官方提供了写入飞书表格和多维表格的插件,但是因为平台教程和案例的资料匮乏,依据现有的官方文档…...
System.Threading.Timer 和 System.Timers.Timer
在 .NET 中,System.Threading.Timer 和 System.Timers.Timer 都是用于定时任务的类,但它们的实现方式、使用场景和特性有所不同。以下是它们的 核心区别 和 使用示例: 1. System.Threading.Timer 特点 轻量级,基于线程池…...

在 Windows 系统下配置 VSCode + CMake + Ninja 进行 C++ 或 Qt 开发
在 Windows 系统下配置 VSCode CMake Ninja 进行 C 或 Qt 开发,是一个轻量级但功能强大的开发环境。下面我将分步骤详细说明如何搭建这个开发环境,支持纯 C 和 Qt 项目。 🧰 所需工具安装 1. 安装 Visual Studio Code(VSCode&…...
`tokenizer.decode` 出现乱码或异常输出,怎么处理
tokenizer.decode 出现乱码或异常输出,怎么处理 在使用 Hugging Face Transformers 库进行大语言模型(LLM)开发时,tokenizer.decode 出现乱码或异常输出,通常和模型输出的 token 序列、分词器对齐逻辑、特殊 token 处理有关。以下从模型侧、分词器侧、后处理环节给出解决…...
几何绘图与三角函数计算应用
几何绘图与三角函数计算应用 设计思路 左侧为绘图控制面板,右侧为绘图区域支持绘制点、线、矩形、圆、多边形等基本几何图形实现三角函数计算器(正弦、余弦、正切等)包含角度/弧度切换和常用数学常数历史记录功能保存用户绘图 完整实现代码…...

leetcode 二叉搜索树中第k小的元素 java
中序遍历 定义一个栈,用于存取二叉树中的元素 Deque<TreeNode> stack new ArrayDeque<TreeNode>();进入while循环while(! stack.isEmpty()|| root ! null){}将root的左节点入栈,直到rootnull while(rootnull){stack.push(root);root ro…...

5.1 初探大数据流式处理
在本节中,我们深入探讨了大数据流式处理的基础知识和关键技术。首先,我们区分了批式处理和流式处理两种大数据处理方式,了解了它们各自的适用场景和特点。流式处理以其低延迟和高实时性适用于需要快速响应的场景,而批式处理则适用…...
基于 Android 和 JBox2D 的简单小游戏
以下是一个基于 Android 和 JBox2D 的简单小游戏开发示例,实现一个小球在屏幕上弹跳的效果: 1. 添加 JBox2D 依赖 在项目的 build.gradle 文件中添加 JBox2D 的依赖: dependencies {implementation org.jbox2d:jbox2d-library:2.3.1 } 2.…...

传输层协议 UDP 介绍 -- UDP 协议格式,UDP 的特点,UDP 的缓冲区
目录 1. 再识的端口号 1.1 端口号范围划分 1.2 知名端口号(Well-Know Port Number) 2. UDP 协议 2.1 UDP 协议格式 2.2 UDP 的特点 2.3 UDP 的缓冲区 2.4 一些基于 UDP 的应用层协议 传输层(Transport Layer)是计算机网络…...
Python try-except-else 语句详解
try-except-else 是 Python 中用于异常处理的重要结构,它允许你优雅地处理可能出现的错误,并在没有错误发生时执行特定代码。下面我将详细解释这个结构及其用法。 基本语法 try:# 可能引发异常的代码块 except [ExceptionType]:# 异常处理代码块 else:…...

ApacheSuperset CVE-2023-27524
前言:CVE-2023-27524 是一种远程代码执行漏洞,攻击者通过该漏洞可在受影响系统上执行任意代码,从而获得未授权访问权 CVE-2023-27524 GitHubhttps://github.com/horizon3ai/CVE-2023-27524 任务一 代理 | 拉取镜像 vi /etc/proxychains4.conf //最下面修…...
Windows Server部署Vue3+Spring Boot项目
在Windows Server 上部署Vue3 Spring Boot前后端分离项目的详细步骤如下: 一、环境准备 安装JDK 17 下载JDK MSI安装包(如Oracle JDK 或 OpenJDK) 双击安装,配置环境变量: JAVA_HOME:JDK安装路径…...