MySQL + Elasticsearch:为什么要使用ES,使用场景与架构设计详解
MySQL + Elasticsearch:为什么要使用ES,使用场景与架构设计详解
- 前言
- 一、MySQL + Elasticsearch的背景与需求
- 1.1 为什么要使用Elasticsearch(ES)?
- 1.2 为什么MySQL在某些场景下不足以满足需求?
- 1.3 MySQL + Elasticsearch结合的必要性
- 二、MySQL + Elasticsearch的典型使用场景
- 2.1 全文搜索与复杂查询
- 2.2 实时数据分析
- 2.3 大数据处理与高并发查询
- 三、MySQL + Elasticsearch的优势与架构设计
- 3.1 为什么不单独使用 MySQL 或 Elasticsearch?
- 3.1.1 单独使用 MySQL 的不足
- 3.1.2 单独使用 Elasticsearch 的不足
- 3.2 MySQL + Elasticsearch的优势
- 3.2.1 性能与灵活性兼顾
- 3.2.2 可扩展性强
- 3.2.3 架构解耦与数据同步
- 3.2.4 实时分析与快速迭代
- 四、存储方案全景对比
- 五、高可用、高可靠与安全设计
- 5.1 MySQL 高可用
- 5.2 Elasticsearch 高可用
- 5.3 安全可靠
- 六、结合使用MySQL与Elasticsearch的存储与查询示例
- 6.1 Elasticsearch用于模糊搜索
- 6.2 MySQL用于精确分类条件查询
- 6.3 结合MySQL与Elasticsearch进行查询流程
前言
在现代企业级应用中,数据存储和检索是核心环节,尤其是涉及到大量数据存储和查询时,如何选择合适的存储系统成为了开发者和架构师的重要课题。MySQL 和 Elasticsearch(ES)是两种广泛使用的数据库系统,它们各自有其独特的优势,但在某些场景下,单独使用MySQL或ES可能无法满足业务需求。结合MySQL与Elasticsearch,不仅能够充分发挥两者的优势,还能更好地满足高并发、高可用、高可靠的业务需求。
一、MySQL + Elasticsearch的背景与需求
1.1 为什么要使用Elasticsearch(ES)?
Elasticsearch 是基于Lucene的开源搜索引擎,它被广泛应用于需要高效全文搜索、复杂查询和快速检索的场景中。与传统的关系型数据库相比,Elasticsearch提供了更高效的搜索引擎和更灵活的数据分析能力,具有以下几个显著特点:
-
快速搜索和查询:Elasticsearch采用倒排索引(Inverted Index)技术,极大地提高了大数据量下的搜索速度,尤其适用于需要全文搜索和复杂查询的场景。
-
横向扩展性:Elasticsearch是分布式系统,具有天然的横向扩展能力,支持数据的分片和多副本机制,能够在大规模数据处理时提供高效的服务。
-
实时搜索:ES具有近实时(1s延迟)的搜索能力,索引更新后几乎能够立刻被查询到,适用于需要实时查询的场景。
-
多样化的数据分析和聚合功能:ES提供了丰富的数据聚合功能,可以高效处理大规模数据的统计分析。
1.2 为什么MySQL在某些场景下不足以满足需求?
尽管MySQL是关系型数据库的典型代表,广泛应用于OLTP(在线事务处理)场景,但在处理大规模全文搜索、复杂查询、实时数据分析等任务时,MySQL存在一些限制:
-
性能瓶颈:传统的关系型数据库MySQL通常基于B树索引(B-Tree Index),在大规模数据检索、复杂查询和全文搜索时性能不如ES。
-
扩展性差:MySQL虽然可以通过主从复制和分库分表来进行扩展,但其水平扩展能力有限,特别是在面对大规模数据和高并发请求时,MySQL的性能可能会受到限制。
-
不支持高级搜索:MySQL并不适合做复杂的模糊查询、全文搜索等任务,这类任务在Elasticsearch中能通过倒排索引高效地实现。
1.3 MySQL + Elasticsearch结合的必要性
将MySQL和Elasticsearch结合使用,可以充分发挥两者的优势,补充彼此的不足。
-
MySQL负责存储结构化数据:MySQL作为关系型数据库,适合存储高结构化的数据,能够保证数据的一致性、事务性和完整性。
-
Elasticsearch负责全文搜索与高效查询:Elasticsearch则可以在高并发查询、复杂检索和实时搜索方面发挥优势,处理数据分析和查询负载。
二、MySQL + Elasticsearch的典型使用场景
2.1 全文搜索与复杂查询
在传统关系型数据库中,处理复杂的查询和全文搜索会面临性能瓶颈。Elasticsearch的倒排索引和分布式架构可以处理海量数据的快速检索,因此非常适合需要支持全文搜索、模糊查询等功能的场景。
-
电商平台:商品名称、描述、标签等字段经常需要进行全文检索,ES能够实现高效的搜索功能。
-
日志分析系统:日志数据量大且结构不固定,使用Elasticsearch进行日志数据的快速查询、聚合和分析是非常理想的。
2.2 实时数据分析
Elasticsearch的实时索引更新和近实时搜索能力使得它在处理需要实时更新的分析任务时表现优秀。
-
社交网络分析:实时跟踪用户活动并进行分析,如推文、评论的情感分析、热点话题的挖掘等。
-
用户行为分析:电商、广告等行业需要实时追踪用户行为,并提供精准的分析报告。
2.3 大数据处理与高并发查询
当系统需要处理大量并发查询时,单独使用MySQL可能无法满足要求,因为MySQL难以应对大量复杂查询的并发请求。Elasticsearch的分布式设计和并行处理能力则能轻松应对这些需求。
- 搜索引擎:例如新闻网站的搜索引擎,用户查询时需要快速返回与关键字相关的内容。ES能够通过并行处理、分布式索引来提供快速的响应。
三、MySQL + Elasticsearch的优势与架构设计
-
单独 MySQL:事务与关系强,但全文检索和水平扩展受限;
-
单独 Elasticsearch:检索性能优,但缺乏 ACID、关系约束且存储开销高;
-
二者结合:MySQL 负责 OLTP,保证数据一致性;Elasticsearch 负责 OLAP/搜索,提供毫秒级检索与实时聚合;通过异步/同步管道解耦写入与查询,既保证业务一致性,也满足高并发检索需求。
3.1 为什么不单独使用 MySQL 或 Elasticsearch?
3.1.1 单独使用 MySQL 的不足
-
性能瓶颈:MySQL 的全文检索基于 B-Tree 或 InnoDB/ MyISAM 全文索引,在大数据量和复杂查询时,响应速度远不如专为搜索设计的 Elasticsearch。
-
扩展性受限:虽然可通过主从复制或分库分表扩展读写,但水平扩展能力有限,面对 PB 级数据和高并发时,维护成本和一致性挑战显著增大。
-
高级搜索不友好:MySQL 缺乏模糊查询、同义词扩展、自动补全等高级功能;复杂分词或多字段相关度计算需大量自定义和优化。
3.1.2 单独使用 Elasticsearch 的不足
-
缺乏 ACID 事务:ES 天生弱一致性,不支持跨文档事务,难以满足金融、库存等对强一致性要求严格的业务场景。
-
数据完整性约束不足:不支持外键、唯一约束等关系型功能,必须在应用层手动维护数据一致性与完整性。
-
存储成本较高:倒排索引、分片与副本机制显著增加磁盘与 I/O 开销,不适合作为所有结构化数据的主存储库。
3.2 MySQL + Elasticsearch的优势
3.2.1 性能与灵活性兼顾
-
事务与一致性由 MySQL 承担:ACID 事务、复杂关联查询与约束由关系型数据库保障,读写操作安全可靠。
-
全文检索与分析由 Elasticsearch 支撑:基于倒排索引和分布式查询,能毫秒级处理模糊、分页、多字段相关度等复杂搜索。
3.2.2 可扩展性强
-
MySQL 横向扩展与高可用:利用 InnoDB Group Replication 或 Galera Cluster,实现多主/主从复制、读写分离与自动故障切换。
-
Elasticsearch 动态分片与副本:索引可自动拆分成主分片和副本,节点增删无需停机,线性扩展到 PB 级数据规模。
3.2.3 架构解耦与数据同步
-
灵活的同步管道:可选 Logstash JDBC 定时拉取、Debezium+Kafka 实时订阅 binlog,或应用层双写,将 MySQL 写入与 ES 索引的依赖解耦。
-
削峰与容灾机制:通过消息队列缓冲高峰期变更,批量写入 ES,并对失败记录重试或持久化至“死信队列”,确保“最终一致性”。
3.2.4 实时分析与快速迭代
-
近实时索引:ES 默认每秒刷新一次,新数据秒级可见,满足日志监控、推荐系统等实时需求。
-
内置聚合功能:无需离线 ETL,即时在 Kibana 或 API 上完成多维度分析、分组与时间序列统计。
四、存储方案全景对比
特性 | MySQL | Elasticsearch |
---|---|---|
数据结构 | 关系型表,支持外键、事务 | 文档(JSON),无事务,多分片与副本 |
查询语言 | SQL,支持 JOIN、事务查询 | Query DSL(JSON),擅长全文检索与聚合 |
扩展方式 | 分库分表、主从复制、Group Replication、Galera | 分片(Shard)与副本(Replica),自动负载均衡 |
实时性 | 非实时,适合 OLTP | 近实时(~1s),适合实时搜索与分析 |
一致性 | 强一致性(ACID) | 最终一致性,弱实时事务 |
检索性能 | 对结构化数据查询优异,全文检索性能一般 | 大规模全文搜索和聚合高效 |
运维复杂度 | 需手动管理分片、分库与主从 | 自动管理分片与路由,运维相对简化 |
五、高可用、高可靠与安全设计
5.1 MySQL 高可用
-
InnoDB Cluster / Group Replication:
每个 MySQL 节点运行 Group Replication,实现多主或单主模式下的数据同步与自动故障切换,无需人工干预即可恢复写入服务,消除单点故障 。
通过 AdminAPI 管理集群节点,支持弹性伸缩及在线升级,保证业务平滑无感知升级 。 -
Galera Cluster:
MariaDB 企业版的 Galera Cluster 提供真正的多主并行复制,所有节点均可读写,自动管理节点加入、成员故障移除与流控,确保事务不丢失且网络延迟低 。
-
异地灾备:
通过在不同地域部署异地从库或使用 MySQL 原生复制,将主库的 binlog 实时传输到远程,从而在主区域发生故障时快速切换,保障区域级别的高可用与数据持久性 。
5.2 Elasticsearch 高可用
-
分片与副本机制:
每个索引可分为若干主分片(primary)与副本分片(replica),当节点失效时,副本自动升级为主分片,确保查询和写入不中断;至少两节点即可保持“green”状态 。
-
跨集群复制(CCR):
采用主动—被动模式,将主集群的索引实时复制到一个或多个从集群中,不仅能就近服务用户,还能作为异地容灾备份;配置简单,基于 Elastic 官方 CCR 功能即可快速上线 。
-
监控与告警:
-
Elastic Stack Monitoring:内置采集集群、索引和节点级指标,配合 Kibana 仪表盘实时可视化。
-
Prometheus + Grafana:使用 Elastic 官方 Prometheus 导出器,将指标推送至 Prometheus,再由 Grafana 展示自定义监控大盘,可灵活设置告警规则。
-
日志与事件:结合 Watcher 或外部告警系统,对集群健康、节点重启、分片状态变化等关键事件进行及时告警。
-
5.3 安全可靠
-
MySQL 安全:
-
TLS 加密传输:强制客户端与服务端使用 SSL/TLS,防止中间人攻击与窃听。
-
基于角色的访问控制(RBAC):MySQL Enterprise Edition 提供细粒度用户/角色管理,限制各用户仅访问必要的数据库或表。
-
审计日志插件:开启 Audit Log 插件,记录所有登录、DDL/DML 操作与权限变更,支持日志加密,满足合规审计需求。
-
-
Elasticsearch 安全:
-
X-Pack Security:内置 TLS 加密、用户认证、角色映射及密码策略;支持文档级与字段级安全控制,保证多租户及敏感数据隔离。
-
审计日志:记录所有认证、授权、索引及查询事件,可定向输出到安全团队或 SIEM 系统进行深度分析。
-
最小安全配置:快速启动时可使用 Elastic Docs 的 Minimal Setup,仅启用基本认证与加密,后续再逐步强化。
-
-
运维自动化:
-
Terraform + Ansible:推荐用 Terraform 管理云端基础设施(网络、虚拟机、存储等),再用 Ansible 做系统配置、软件安装与服务编排,清晰分离“基础设施”与“配置”职责,增强可审计性与可回滚性。
-
版本控制 & CI/CD:将 Terraform 脚本与 Ansible Playbook 存入 Git,结合 CI/CD 管道实现自动化测试、审查与部署,确保配置一致性与快速恢复。
-
六、结合使用MySQL与Elasticsearch的存储与查询示例
为了更清楚地了解如何将MySQL和Elasticsearch结合使用,将通过以下几个具体示例(题库)来说明两者的实际应用场景和查询逻辑。
6.1 Elasticsearch用于模糊搜索
Elasticsearch擅长全文检索、模糊查询和快速检索。当我们需要根据题干内容、标签、关键词等进行模糊搜索时,Elasticsearch非常高效,尤其是在面对大量题目数据时,能够快速返回相关结果。
示例:模糊搜索“二战”相关的题目
假设我们需要根据关键词“二战”和“历史”来查找题目。通过Elasticsearch,我们可以进行如下的查询:
GET /questions/_search
{"query": {"bool": {"must": [{ "match": { "content": "二战" } },{ "match": { "tags": "历史" } }]}}
}
解析:
content
:题目的文本内容,Elasticsearch将基于内容中的关键字进行搜索。tags
:题目所属的标签,Elasticsearch将搜索与标签“历史”相关的题目。
此查询会返回所有题目内容中包含“二战”且标签为“历史”的题目,利用了Elasticsearch的强大文本处理和快速查询能力。
6.2 MySQL用于精确分类条件查询
当我们需要按照特定的分类、学科或其他结构化数据进行筛选时,使用MySQL会更为合适,因为它能够处理复杂的表关系和结构化查询。此时,我们首先通过MySQL查询出符合特定条件的题目ID,再利用这些ID在Elasticsearch中查询题目详情。
示例:查询“数学”学科下的题目ID
假设我们要查找属于“数学”学科的所有题目,可以先通过MySQL查询出所有符合条件的题目ID:
SELECT question_id
FROM questions
WHERE category_id = (SELECT category_id FROM categories WHERE name = '数学');
解析:
category_id
:我们首先通过查询“数学”学科对应的category_id
,然后用这个category_id
去筛选所有属于“数学”学科的题目ID。
示例:根据ID在Elasticsearch中查询题目详情
一旦我们得到了所有“数学”学科下的题目ID(假设是 [1, 2, 3, 4, 5]
),就可以通过这些ID在Elasticsearch中查询题目的详细内容,如下所示:
GET /questions/_mget
{"ids": [1, 2, 3, 4, 5]
}
解析:
_mget
:这是Elasticsearch的多文档获取接口,用于根据提供的一组ID查询多个文档。返回结果将包括这些题目的详细信息,如题目内容、选项等。
6.3 结合MySQL与Elasticsearch进行查询流程
通过结合MySQL和Elasticsearch的优势,您可以实现更高效、更灵活的查询功能。例如,用户可能希望查询“数学”学科下的题目,并且这些题目内容中包含“代数”相关的内容。具体流程如下:
步骤 1:通过MySQL查询学科下的题目ID
首先,我们使用MySQL查询出属于“数学”学科的所有题目ID:
SELECT question_id
FROM questions
WHERE category_id = (SELECT category_id FROM categories WHERE name = '数学');
步骤 2:通过Elasticsearch查询详细内容
然后,我们将这些题目ID传递给Elasticsearch,查询出题目的详细内容,包括题干、选项等:
GET /questions/_mget
{"ids": [1, 2, 3, 4, 5]
}
步骤 3:根据关键词进行模糊搜索
接下来,我们可以进一步在Elasticsearch中对题目内容进行模糊搜索。假设用户查询的是“代数”相关的内容,可以通过以下查询来查找符合条件的题目:
GET /questions/_search
{"query": {"match": {"content": "代数"}}
}
总结:
-
MySQL 用于处理结构化数据、精准查询以及关系型操作,适用于根据学科、难度、类别等条件筛选题目ID。
-
Elasticsearch 用于高效的全文搜索、模糊匹配和快速检索,适合处理题干内容、选项等字段的模糊查询,尤其在面对大量数据时更具优势。
相关文章:

MySQL + Elasticsearch:为什么要使用ES,使用场景与架构设计详解
MySQL Elasticsearch:为什么要使用ES,使用场景与架构设计详解 前言一、MySQL Elasticsearch的背景与需求1.1 为什么要使用Elasticsearch(ES)?1.2 为什么MySQL在某些场景下不足以满足需求?1.3 MySQL Elas…...
Node.js vs 浏览器中的JavaScript:区别全解析
JavaScript 最初是专为浏览器设计的脚本语言,但 Node.js 的出现让它突破了前端的边界。虽然语法相同,但运行环境的不同导致它们在功能、API 和应用场景上存在显著差异。 本文将通过通俗易懂的对比和代码示例,带你彻底理解它们的区别。 文章目…...

从投入产出、效率、上手难易度等角度综合对比 pytest 和 unittest 框架
对于选择python作为测试脚本开发的同学来说,pytest和python unittest是必需了解的两个框架。那么他们有什么区别?我们该怎么选?让我们一起来了解一下吧! 我们从投入产出、效率、上手难易度等角度综合对比 pytest 和 unittest 框架…...

关于汇编语言与程序设计——单总线温度采集与显示的应用
一、实验要求 (1)握码管的使用方式 (2)掌握DS18B20温度传感器的工作原理 (3)掌握单总线通信方式实现 MCU与DS18B20数据传输 二、设计思路 1.整体思路 通过编写数码管显示程序和单总线温度采集程序,结合温度传感报警,利用手指触碰传感器,当…...

spring中的@Inject注解详情
在 Spring 框架中,Inject 是 Java 依赖注入标准(JSR-330) 的核心注解,与 Spring 原生的 Autowired 类似,但具备更标准化的跨框架特性。以下从功能特性、使用场景及与 Spring 原生注解的对比进行详细解析: 一…...
DA14585墨水屏学习
一、do_min_word void do_min_work(void) {timer_used_min app_easy_timer(APP_PERIPHERAL_CTRL_TIMER_DELAY_MINUTES, do_min_work);current_unix_time time_offset;time_offset 60;// if (isconnected 1)// {// GPIO_SetActive(GPIO_LED_PORT, GPIO_LED_PIN);// …...

Vue基础(8)_监视属性、深度监视、监视的简写形式
监视属性(watch): 1.当被监视的属性变化时,回调函数(handler)自动调用,进行相关操作。 2.监视的属性必须存在,才能进行监视!! 3.监视的两种写法: (1).new Vue时传入watch配置 (2).通过vm.$watc…...
计算机网络八股文--day1
从浏览器输入url到显示主页的过程? 1. 浏览器查询域名的IP地址 2. 浏览器和服务器TCP三次握手 3. 浏览器向服务器发送一个HTTP请求 4. 服务器处理请求,返回HTTP响应 5. 浏览器解析并且渲染页面 6. 断开连接 其中使用到的协议有DNS协议(…...

TCP IP
TCP/IP 通信协议,不是单一协议,是一组协议的集合 TCP IP UDP 1.建立链接 三次握手 第一步:客户端发送一个FIN报文,SEQX,等待服务器回应 第二步:服务器端受到,发送ackx1,seqy, 等待客户端回应 第三步&am…...
CNG汽车加气站操作工岗位职责
CNG(压缩天然气)汽车加气站操作工是负责天然气加气设备操作、维护及安全管理的重要岗位。以下是该岗位的职责、技能要求、安全注意事项及职业发展方向的详细说明: *主要职责 加气操作 按照规程为车辆加注CNG,检查车辆气瓶合格证…...

(四)毛子整洁架构(Presentation层/Authentiacation/Authorization)
文章目录 项目地址一、Presentation 层1.1 数据库migration1. 添加数据库连接字符串2. 创建自动Migration/Seed3.修改Entity添加private 构造函数4. 执行迁移 1.2 全局错误处理中间件1.3 Controller 添加1. Apartments2. Bookings3. 测试 二、Authentiacation2.1 添加Keycloak服…...

K8S服务的请求访问转发原理
开启 K8s 服务异常排障过程前,须对 K8s 服务的访问路径有一个全面的了解,下面我们先介绍目前常用的 K8s 服务访问方式(不同云原生平台实现方式可能基于部署方案、性能优化等情况会存在一些差异,但是如要运维 K8s 服务,…...
5.1 神经网络: 层和块
1 层(Layer) 1.1 定义 层是深度学习模型中的基本构建单元,它由一组神经元组成,负责对输入数据进行特定的数学运算和变换,以提取数据的某种特征或表示。每一层可以看作是一个函数,它接收输入数据ÿ…...

20250510解决NanoPi NEO core开发板在Ubuntu core22.04.3系统下适配移远的4G模块EC200A-CN的问题
1、h3-eflasher-friendlycore-jammy-4.14-armhf-20250402.img.gz 在WIN10下使用7-ZIP解压缩/ubuntu20.04下使用tar 2、Win32DiskImager.exe 写如32GB的TF卡。【以管理员身份运行】 3、TF卡如果已经做过会有3个磁盘分区,可以使用SD Card Formatter/SDCardFormatterv5…...

Linux系统之----模拟实现shell
在前面一个阶段的学习中,我们已经学习了环境变量、进程控制等等一系列知识,也许有人会问,学这个东西有啥用?那么,今天我就和大家一起综合运用一下这些知识,模拟实现下shell! 首先我们来看一看我…...
2025年数维杯赛题C题专家 组委会C题专家疑集锦
1、段前段后距,行间距有要求嘛 C题专家:一般是单倍行距 2、请问参考文献和附录上方也要有图示页眉吗?ai使用报告放在附录里还是附录之后? C题专家:附录 3、第三问的那个三天都在一个城市可以吗?这样我们列两份城市的清明自由行,还是说…...

TCP黏包解决方法
1. 问题描述 TCP客户端每100ms发送一次数据,每次为16006字节的数据长度。由于TCP传输数据时,为了达到最佳传输效能,数据包的最大长度需要由MSS限定(MSS就是TCP数据包每次能够传输的最大数据分段),超过这个长度会进行自动拆包。也就是说虽然客户端一次发送16006字节数据,…...

vue访问后端接口,实现用户注册
文章目录 一、后端接口文档二、前端代码请求响应工具调用后端API接口页面函数绑定单击事件,调用/api/user.js中的函数 三、参考视频 一、后端接口文档 二、前端代码 请求响应工具 /src/utils/request.js //定制请求的实例//导入axios npm install axios import …...
[原创](现代Delphi 12指南):[macOS 64bit App开发]: 如何获取自身程序的所在的目录?
[作者] 常用网名: 猪头三 出生日期: 1981.XX.XX 企鹅交流: 643439947 个人网站: 80x86汇编小站 编程生涯: 2001年~至今[共24年] 职业生涯: 22年 开发语言: C/C++、80x86ASM、Object Pascal、Objective-C、C#、R、Python、PHP、Perl、 开发工具: Visual Studio、Delphi、XCode、…...

Nginx性能调优与深度监控
目录 1更改进程数与连接数 (1)进程数 (2)连接数 2,静态缓存功能设置 (1)设置静态资源缓存 (2)验证静态缓存 3,设置连接超时 4,日志切割 …...
机器学习第四讲:无监督学习 → 给无标签积木自由组合,发现隐藏规律
机器学习第四讲:无监督学习 → 给无标签积木自由组合,发现隐藏规律 资料取自《零基础学机器学习》。 查看总目录:学习大纲 关于DeepSeek本地部署指南可以看下我之前写的文章:DeepSeek R1本地与线上满血版部署:超详细…...
2025年5月计划(linux+Gpu精粹催眠+UE独立游戏)
终于步入正轨了,4月份为了各种面试,一会学这,一会学那。 现在,有大量的业余时间了,也该干点正事了。 按照规划, 1,ue独立游戏(十分钟的视频即可) 2,linux-&…...

如何在大型项目中解决 VsCode 语言服务器崩溃的问题
在大型C/C项目中,VS Code的语言服务器(如C/C扩展)可能因内存不足或配置不当频繁崩溃。本文结合系统资源分析与实战技巧,提供一套完整的解决方案。 一、问题根源诊断 1.1 内存瓶颈分析 通过top命令查看系统资源使用情况ÿ…...
从爬虫到网络---<基石9> 在VPS上没搞好Docker项目,把他卸载干净
1.停止并删除所有正在运行的容器 docker ps -a # 查看所有容器 docker stop $(docker ps -aq) # 停止所有容器 docker rm $(docker ps -aq) # 删除所有容器如果提示没有找到容器,可以忽略这些提示。 2.删除所有镜像 docker images # 查看所有镜像 dock…...

AutoDL实现端口映射与远程连接AutoDL与Pycharm上传文件到远程服务器(李沐老师的环境)
文章目录 以上配置的作用前提AutoDL实现端口映射远程连接AutoDLPycharm上传文件到远程服务器以上配置的作用 使用AutoDL的实例:因本地没有足够强的算力,所以需要使用AutoDL AutoDL端口映射:当在实例上安装深度学习的环境,但因为实例的linux系统问题,无法图形化显示d2l中的文件…...
LeetCode 热题 100 24. 两两交换链表中的节点
LeetCode 热题 100 | 24. 两两交换链表中的节点 大家好,今天我们来解决一道经典的链表问题——两两交换链表中的节点。这道题在 LeetCode 上被标记为中等难度,要求两两交换链表中的相邻节点,并返回交换后链表的头节点。 问题描述 给你一个链…...

13.thinkphp的Session和cookie
一.Session 1. 在使用Session之前,需要开启初始化,在中间件文件middleware.php; // Session 初始化 \think\middleware\SessionInit::class 2. TP6.0不支持原生$_SESSION的获取方式,也不支持session_开头的函数&…...
好用的播放器推荐
以下是一些好用的播放器推荐,按照不同平台和使用场景分类: 电脑端 VLC Media Player 特点:开源、跨平台,支持几乎所有的音视频格式,无需额外安装解码器。具备强大的功能,如播放列表管理、视频和音频滤镜、…...

多线程获取VI模块的YUV数据
一.RV1126 VI模块采集摄像头YUV数据的流程 step1:VI模块初始化 step2:启动VI模块工作 step3:开启多线程采集VI数据并保存 1.1初始化VI模块: VI模块的初始化实际上就是对VI_CHN_ATTR_S的参数进行设置、然后调用RK_MPI_VI_SetC…...

[ctfshow web入门] web68
信息收集 highlight_file被禁用了,使用cinclude("php://filter/convert.base64-encode/resourceindex.php");读取index.php,使用cinclude("php://filter/convert.iconv.utf8.utf16/resourceindex.php");可能有些乱码,不…...