【大数据】MySQL与Elasticsearch的对比分析:如何选择适合的查询解决方案

news2025/1/22 22:31:49
目录
  • 引言
  • 一、全文检索(Full-text Search)
    • 1.1 Elasticsearch(ES)
    • 1.2 MySQL
    • 1.3 对比总结
  • 二、精确查询(Exact Match Queries)
    • 2.1 MySQL
    • 2.2 Elasticsearch
    • 2.3 对比总结
  • 三、复杂查询和聚合(Complex Queries & Aggregations)
    • 3.1 Elasticsearch
    • 3.2 MySQL
    • 3.3 对比总结
  • 四、数据量和性能(Data Volume and Performance)
    • 4.1 Elasticsearch (ES)
    • 4.2 MySQL
    • 4.3 对比总结
  • 五、实时性(Real-time Processing)
    • 5.1 MySQL
    • 5.2 Elasticsearch
    • 5.3 对比总结
  • 六、资源消耗(Resource Consumption)
    • 6.1 Elasticsearch
    • 6.2 MySQL
    • 6.3 对比总结:
  • 七、总结与建议
    • 7.1 选择建议
    • 7.2 性能优化建议
  • 总结

引言

在当今大数据时代,信息的快速检索和高效处理对于企业和开发者至关重要。无论是需要处理海量文本数据的全文检索,还是要求高效精确查询的数据库系统,选择合适的技术方案将直接影响系统的性能和用户体验。MySQL和Elasticsearch作为两种广泛使用的数据库技术,它们各自具有独特的优势和适用场景。本文将通过对比两者在不同查询场景下的表现,帮助您在实际应用中做出更明智的选择。

我们将从以下几个维度进行分析:全文检索、精确查询、复杂查询与聚合、大数据量处理、实时性、资源消耗等,并结合不同场景给出选择建议,帮助开发者在特定需求下做出最优决策。

一、全文检索(Full-text Search)

1.1 Elasticsearch(ES)

  • 专为全文检索设计:Elasticsearch 是一个基于 Apache Lucene 的搜索引擎,专为高效的全文搜索而设计。它利用 倒排索引 来加速搜索过程。倒排索引会将文档中的每个词汇映射到包含该词汇的文档集合中,从而使得查询能够迅速定位相关文档。
  • 强大的分词和分析功能:ES 配备了先进的文本分析器,支持对中文、英文等多语言的有效分词。这些分析器能够处理复杂的查询类型,包括模糊查询、通配符查询、短语查询等,表现尤为出色。对于中文等语言的特殊分词规则,ES 提供了针对性的支持。
  • 分布式架构:ES 的分布式设计使得它能够在大规模数据集下进行高效的检索,并在多节点之间分配数据,从而提高查询的并发处理能力和系统的伸缩性。

1.2 MySQL

  • 全文索引(FULLTEXT):从 MySQL 5.6 版本起,MySQL 引入了全文索引功能。它适用于简单的文本搜索,例如可以对某个字段使用全文索引,进行如 MATCH...AGAINST 的查询。
  • 适用场景:MySQL 的全文索引适合于中小规模的数据集,特别是查询不涉及复杂的分析和处理时。在数据量较小(如百万级)时,性能较好。
  • 性能瓶颈:尽管 MySQL 支持全文索引,但在面对大规模数据时,尤其是数据量达到千万级甚至更高时,性能会明显下降。索引建立与查询时的性能瓶颈主要体现在查询速度、查询的并发量以及维护成本上。

1.3 对比总结

  • 全文检索:当数据规模较小且查询简单时,MySQL 的全文索引足以满足需求。但在大规模数据和高并发场景下,Elasticsearch 的性能更为优秀,尤其是在处理复杂查询、模糊查询时,ES 的表现更具优势。

#mermaid-svg-hw6VZzSvipD2cq9B {font-family:“trebuchet ms”,verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-hw6VZzSvipD2cq9B .error-icon{fill:#552222;}#mermaid-svg-hw6VZzSvipD2cq9B .error-text{fill:#552222;stroke:#552222;}#mermaid-svg-hw6VZzSvipD2cq9B .edge-thickness-normal{stroke-width:2px;}#mermaid-svg-hw6VZzSvipD2cq9B .edge-thickness-thick{stroke-width:3.5px;}#mermaid-svg-hw6VZzSvipD2cq9B .edge-pattern-solid{stroke-dasharray:0;}#mermaid-svg-hw6VZzSvipD2cq9B .edge-pattern-dashed{stroke-dasharray:3;}#mermaid-svg-hw6VZzSvipD2cq9B .edge-pattern-dotted{stroke-dasharray:2;}#mermaid-svg-hw6VZzSvipD2cq9B .marker{fill:#333333;stroke:#333333;}#mermaid-svg-hw6VZzSvipD2cq9B .marker.cross{stroke:#333333;}#mermaid-svg-hw6VZzSvipD2cq9B svg{font-family:“trebuchet ms”,verdana,arial,sans-serif;font-size:16px;}#mermaid-svg-hw6VZzSvipD2cq9B .label{font-family:“trebuchet ms”,verdana,arial,sans-serif;color:#333;}#mermaid-svg-hw6VZzSvipD2cq9B .cluster-label text{fill:#333;}#mermaid-svg-hw6VZzSvipD2cq9B .cluster-label span{color:#333;}#mermaid-svg-hw6VZzSvipD2cq9B .label text,#mermaid-svg-hw6VZzSvipD2cq9B span{fill:#333;color:#333;}#mermaid-svg-hw6VZzSvipD2cq9B .node rect,#mermaid-svg-hw6VZzSvipD2cq9B .node circle,#mermaid-svg-hw6VZzSvipD2cq9B .node ellipse,#mermaid-svg-hw6VZzSvipD2cq9B .node polygon,#mermaid-svg-hw6VZzSvipD2cq9B .node path{fill:#ECECFF;stroke:#9370DB;stroke-width:1px;}#mermaid-svg-hw6VZzSvipD2cq9B .node .label{text-align:center;}#mermaid-svg-hw6VZzSvipD2cq9B .node.clickable{cursor:pointer;}#mermaid-svg-hw6VZzSvipD2cq9B .arrowheadPath{fill:#333333;}#mermaid-svg-hw6VZzSvipD2cq9B .edgePath .path{stroke:#333333;stroke-width:2.0px;}#mermaid-svg-hw6VZzSvipD2cq9B .flowchart-link{stroke:#333333;fill:none;}#mermaid-svg-hw6VZzSvipD2cq9B .edgeLabel{background-color:#e8e8e8;text-align:center;}#mermaid-svg-hw6VZzSvipD2cq9B .edgeLabel rect{opacity:0.5;background-color:#e8e8e8;fill:#e8e8e8;}#mermaid-svg-hw6VZzSvipD2cq9B .cluster rect{fill:#ffffde;stroke:#aaaa33;stroke-width:1px;}#mermaid-svg-hw6VZzSvipD2cq9B .cluster text{fill:#333;}#mermaid-svg-hw6VZzSvipD2cq9B .cluster span{color:#333;}#mermaid-svg-hw6VZzSvipD2cq9B div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:“trebuchet ms”,verdana,arial,sans-serif;font-size:12px;background:hsl(80, 100%, 96.2745098039%);border:1px solid #aaaa33;border-radius:2px;pointer-events:none;z-index:100;}#mermaid-svg-hw6VZzSvipD2cq9B :root{–mermaid-font-family:“trebuchet ms”,verdana,arial,sans-serif;}#mermaid-svg-hw6VZzSvipD2cq9B .watermark>*{fill:#fff!important;stroke:none!important;font-size:15px!important;opacity:0.8!important;}#mermaid-svg-hw6VZzSvipD2cq9B .watermark span{fill:#fff!important;stroke:none!important;font-size:15px!important;opacity:0.8!important;}

CSDN @ 2136

Elasticsearch

倒排索引

分词与分析

MySQL

全文索引

性能瓶颈

CSDN @ 2136

二、精确查询(Exact Match Queries)

2.1 MySQL

  • 高效的精确查询:MySQL 在执行精确匹配查询时表现优异。对于使用了主键或唯一索引的查询,如 SELECT * FROM table WHERE id = 1,MySQL 能够通过索引快速定位记录,查询速度几乎是即时的。
  • 单表查询优化:在简单的单表查询场景中,MySQL 利用 B+ 树等数据结构进行快速索引查找,查询效率非常高。

2.2 Elasticsearch

  • 精确查询支持:ES 也能进行精确查询,特别是基于 term 查询的精确匹配。尽管 ES 在分布式环境下的查询可以处理更高的并发,但对于单表的精确查询,MySQL 的性能通常更优。ES 在精确查询时通常会有一定的额外开销,尤其是数据量较小的情况。
  • 分布式查询优势:ES 的优势主要体现在处理大规模数据时,它的分片机制和并行查询能极大提高查询效率,特别是跨多个字段和多个节点的复杂查询。

2.3 对比总结

  • 精确查询:对于简单的精确查询,MySQL 通常表现更好,尤其是在表结构优化良好并且有合适索引的情况下。对于小规模数据,MySQL 的查询速度几乎即时。而 Elasticsearch 更适合处理复杂的精确查询,特别是在需要横向扩展的场景中。

三、复杂查询和聚合(Complex Queries & Aggregations)

3.1 Elasticsearch

  • 复杂查询支持:Elasticsearch 非常擅长处理复杂查询,包括多条件查询、范围查询、嵌套查询等。它提供了强大的查询 DSL,可以灵活地组合多个查询条件,实现高效的查询。
  • 聚合查询:ES 在聚合方面的表现尤为出色。它支持复杂的聚合查询,可以在单次请求中实现多层级的数据统计、分组、排序等操作。例如,可以对数据进行 分组聚合求平均值最大值/最小值 等操作。ES 的聚合框架非常高效,尤其在数据量庞大的情况下,能够快速返回结果。
  • 高并发查询:由于 Elasticsearch 采用了分布式架构,它能够在高并发查询和大数据量环境下保持高效性能,处理多种类型的复杂查询。

3.2 MySQL

  • 复杂查询支持:MySQL 支持各种复杂查询,包括多表联接(JOIN)、子查询、分组(GROUP BY)、排序(ORDER BY)等操作。对于小数据集或中等规模数据的复杂查询,MySQL 能够提供良好的性能。
  • 聚合查询:MySQL 也能进行聚合查询(如使用 COUNT()SUM()AVG() 等函数),并能通过索引优化这些查询。然而,当数据量增大时,尤其是涉及多表联接、大范围分组和排序时,MySQL 的性能会显著下降。
  • 性能瓶颈:在处理复杂查询时,MySQL 可能会遇到性能瓶颈,尤其是在查询涉及多个大表连接、复杂的 JOIN 操作或大量数据聚合时。

3.3 对比总结

  • 复杂查询与聚合:在处理复杂查询和聚合方面,Elasticsearch 相对于 MySQL 具有显著的优势。特别是在面对大规模数据和高并发请求时,ES 的分布式架构能够有效提升查询性能。而 MySQL 在处理中小规模数据时也能很好地支持复杂查询,但在大数据量下会逐渐暴露出性能瓶颈。

#mermaid-svg-oPIZFpdVObVYKa6g {font-family:“trebuchet ms”,verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-oPIZFpdVObVYKa6g .error-icon{fill:#552222;}#mermaid-svg-oPIZFpdVObVYKa6g .error-text{fill:#552222;stroke:#552222;}#mermaid-svg-oPIZFpdVObVYKa6g .edge-thickness-normal{stroke-width:2px;}#mermaid-svg-oPIZFpdVObVYKa6g .edge-thickness-thick{stroke-width:3.5px;}#mermaid-svg-oPIZFpdVObVYKa6g .edge-pattern-solid{stroke-dasharray:0;}#mermaid-svg-oPIZFpdVObVYKa6g .edge-pattern-dashed{stroke-dasharray:3;}#mermaid-svg-oPIZFpdVObVYKa6g .edge-pattern-dotted{stroke-dasharray:2;}#mermaid-svg-oPIZFpdVObVYKa6g .marker{fill:#333333;stroke:#333333;}#mermaid-svg-oPIZFpdVObVYKa6g .marker.cross{stroke:#333333;}#mermaid-svg-oPIZFpdVObVYKa6g svg{font-family:“trebuchet ms”,verdana,arial,sans-serif;font-size:16px;}#mermaid-svg-oPIZFpdVObVYKa6g .label{font-family:“trebuchet ms”,verdana,arial,sans-serif;color:#333;}#mermaid-svg-oPIZFpdVObVYKa6g .cluster-label text{fill:#333;}#mermaid-svg-oPIZFpdVObVYKa6g .cluster-label span{color:#333;}#mermaid-svg-oPIZFpdVObVYKa6g .label text,#mermaid-svg-oPIZFpdVObVYKa6g span{fill:#333;color:#333;}#mermaid-svg-oPIZFpdVObVYKa6g .node rect,#mermaid-svg-oPIZFpdVObVYKa6g .node circle,#mermaid-svg-oPIZFpdVObVYKa6g .node ellipse,#mermaid-svg-oPIZFpdVObVYKa6g .node polygon,#mermaid-svg-oPIZFpdVObVYKa6g .node path{fill:#ECECFF;stroke:#9370DB;stroke-width:1px;}#mermaid-svg-oPIZFpdVObVYKa6g .node .label{text-align:center;}#mermaid-svg-oPIZFpdVObVYKa6g .node.clickable{cursor:pointer;}#mermaid-svg-oPIZFpdVObVYKa6g .arrowheadPath{fill:#333333;}#mermaid-svg-oPIZFpdVObVYKa6g .edgePath .path{stroke:#333333;stroke-width:2.0px;}#mermaid-svg-oPIZFpdVObVYKa6g .flowchart-link{stroke:#333333;fill:none;}#mermaid-svg-oPIZFpdVObVYKa6g .edgeLabel{background-color:#e8e8e8;text-align:center;}#mermaid-svg-oPIZFpdVObVYKa6g .edgeLabel rect{opacity:0.5;background-color:#e8e8e8;fill:#e8e8e8;}#mermaid-svg-oPIZFpdVObVYKa6g .cluster rect{fill:#ffffde;stroke:#aaaa33;stroke-width:1px;}#mermaid-svg-oPIZFpdVObVYKa6g .cluster text{fill:#333;}#mermaid-svg-oPIZFpdVObVYKa6g .cluster span{color:#333;}#mermaid-svg-oPIZFpdVObVYKa6g div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:“trebuchet ms”,verdana,arial,sans-serif;font-size:12px;background:hsl(80, 100%, 96.2745098039%);border:1px solid #aaaa33;border-radius:2px;pointer-events:none;z-index:100;}#mermaid-svg-oPIZFpdVObVYKa6g :root{–mermaid-font-family:“trebuchet ms”,verdana,arial,sans-serif;}#mermaid-svg-oPIZFpdVObVYKa6g .watermark>*{fill:#fff!important;stroke:none!important;font-size:15px!important;opacity:0.8!important;}#mermaid-svg-oPIZFpdVObVYKa6g .watermark span{fill:#fff!important;stroke:none!important;font-size:15px!important;opacity:0.8!important;}

CSDN @ 2136

Elasticsearch

复杂查询支持

聚合查询

MySQL

多表查询

复杂聚合

CSDN @ 2136

四、数据量和性能(Data Volume and Performance)

4.1 Elasticsearch (ES)

  • 分布式架构:Elasticsearch 采用分布式架构,数据通过分片进行分布存储,并支持副本机制。这使得它非常适合处理大规模数据,可以在多个节点间分担查询和索引负载,从而提升查询性能。
  • 横向扩展:随着数据量的增长,Elasticsearch 通过增加节点(横向扩展)来处理更大规模的数据。横向扩展使得它可以在多台机器之间分配负载,保持查询性能,即便在数据量激增的情况下也能高效工作。

4.2 MySQL

  • 单机架构:MySQL 本身是基于单机架构的数据库,虽然可以通过分区、分库和分表的方式处理大数据,但这些操作通常需要复杂的管理和调优。在面对庞大数据集时,性能可能会受到瓶颈限制,尤其是当数据量达到一定规模时。
  • 性能瓶颈:MySQL 在处理非常大数据量的查询时,尤其是涉及到多表 JOIN 或复杂的聚合操作时,可能会遭遇性能瓶颈。对比于分布式系统,MySQL 的扩展性较差,且其性能提升有限。

4.3 对比总结

  • 数据量和性能:Elasticsearch 在处理大规模数据时表现更为优异,尤其是在分布式架构下,通过横向扩展能够保持较高的查询性能。MySQL 在大数据量的场景下,可能会面临单机架构的性能瓶颈,尤其是涉及复杂查询时。

五、实时性(Real-time Processing)

5.1 MySQL

  • OLTP 优势:MySQL 非常适合处理在线事务处理(OLTP)场景,支持事务机制,可以保证数据的一致性和可靠性。它在实时写入和快速查询方面表现出色,适合需要频繁更新和快速查询的应用。
  • ACID 特性:MySQL 提供了完整的 ACID(原子性、一致性、隔离性、持久性)支持,确保数据一致性和事务的可靠性,非常适合处理要求严格数据一致性的场景。

5.2 Elasticsearch

  • OLAP 优势:Elasticsearch 主要用于在线分析处理(OLAP),尤其在处理大规模数据查询时表现优越。尽管它也支持写入操作,但写入的延迟相对较高,因此更适用于查询密集型任务,尤其是涉及全文检索和大规模分析时。
  • 近实时搜索:Elasticsearch 提供近实时(NRT)搜索能力,这意味着它的数据更新在小时间延迟后即可对外提供服务,但与 MySQL 的实时写入相比,Elasticsearch 的写入延迟较高。

5.3 对比总结

  • 实时性:MySQL 更适合处理高频繁的写入和实时事务,确保低延迟的实时数据处理。而 Elasticsearch 更擅长于近实时的数据查询和分析,适合数据量大且查询要求高的应用场景。

六、资源消耗(Resource Consumption)

6.1 Elasticsearch

  • 内存消耗较大:作为一个分布式系统,Elasticsearch 通常需要较高的内存和计算资源,尤其是在处理大规模数据时。为确保查询性能,Elasticsearch 需要合理配置较强的硬件资源,特别是在启用缓存、分片等机制时。
  • 计算密集型:Elasticsearch 在执行复杂查询、聚合操作时对 CPU 和内存的消耗较大,尤其在查询大型数据集时,可能需要更强的硬件支持。

6.2 MySQL

  • 资源消耗较低:MySQL 在资源消耗方面相对较轻,特别是在数据集较小或中等规模时,资源消耗远低于 Elasticsearch。在单机模式下,MySQL 对硬件要求相对较低。

6.3 对比总结:

  • 资源消耗:MySQL 更适合在硬件资源有限的环境中使用,尤其是在数据量相对较小或对实时性要求较高的场景。Elasticsearch 在处理大规模数据和复杂查询时需要更多的内存和计算资源,因此适合硬件资源充足的场景。

七、总结与建议

场景

Elasticsearch (ES)

MySQL

全文检索

更快,倒排索引优化全文检索

性能不如 ES,适合小规模文本查询

精确查询

可以处理,但性能不如 MySQL

对于精确查询性能优秀,特别是在使用索引时

复杂查询和聚合

优势明显,能高效处理多条件查询和聚合

支持复杂查询,但数据量增大时性能下降

大数据处理

支持分布式架构,横向扩展性能优异,适合大数据量

在大数据量下性能瓶颈明显,尤其是多表JOIN操作

实时性

适合近实时数据查询,写入延迟稍高

适合OLTP,实时事务写入和查询性能优秀

资源消耗

高,尤其在大数据和复杂查询场景下

资源消耗较低,适合资源受限的场景

7.1 选择建议

  1. 当应用需求是复杂的全文检索或需要快速处理大量文本数据时

    • 选择 Elasticsearch,它专为大规模文本数据的搜索与分析设计,提供优化的全文检索性能,尤其在多条件查询和复杂查询下表现优秀。
  2. 当应用需要进行精确的关系型数据查询、事务处理和高频繁写入时

    • 选择 MySQL,它在处理结构化数据、事务和精确查询时具有优势,适合保证数据一致性的 OLTP 场景。
  3. 当数据量达到数百万、甚至数十亿时

    • 选择 Elasticsearch,它的分布式架构和横向扩展能力使其能够有效应对大数据量的查询请求,而 MySQL 在这类场景中可能遭遇性能瓶颈,尤其是多表 JOIN 或复杂聚合时。
  4. 当实时性要求较高时(例如,高频写入和低延迟查询)

    • 选择 MySQL,它的事务性支持和低延迟写入能力使其非常适合需要快速写入和实时处理的应用。Elasticsearch 更适合用于近实时数据查询,但写入延迟较高。
  5. 当资源受限或硬件条件较差时

    • 选择 MySQL,它的资源消耗较低,适合在硬件资源有限的环境下使用。Elasticsearch 需要较强的硬件支持,特别是在处理大数据和复杂查询时。

7.2 性能优化建议

  1. Elasticsearch 性能优化

    • 索引优化:合理设计索引结构,尽量减少不必要的字段和映射。选择合适的分词器和分析器来提高查询效率。
    • 缓存机制:合理配置缓存,尤其在查询频繁的场景中,利用 Elasticsearch 的节点缓存、字段缓存和过滤缓存来提升性能。
    • 数据分片:确保合理的分片设计。分片过多或过少都会影响查询性能,应该根据数据量和查询负载动态调整分片数。
    • 集群扩展:随着数据量的增加,考虑横向扩展 Elasticsearch 集群,增加节点数来分担查询和写入压力。
  2. MySQL 性能优化

    • 索引优化:确保常用查询字段已创建索引,避免全表扫描。尤其在多表连接查询中,合理使用联合索引。
    • 查询优化:使用 EXPLAIN 分析查询执行计划,避免不必要的全表扫描和嵌套查询,必要时可将复杂查询拆分成多个小查询。
    • 数据库分区和分库分表:对于大数据量表,使用分区表减少扫描范围。对于超大规模应用,考虑使用分库分表来分担负载。
    • 缓存机制:引入外部缓存(如 Redis)缓存热点数据,减少数据库负载,尤其是对于频繁查询的数据。

总结

  • Elasticsearch:适用于大规模文本数据的快速全文检索和复杂聚合分析,能够处理大数据量且具有优秀的分布式架构支持。特别适合需要高效搜索、实时数据分析和日志处理的场景。

  • MySQL:对于需要精确查询、强事务支持(ACID)、以及实时写入的应用场景,MySQL无疑是更为合适的选择。它在数据结构简单、查询要求较为直接的系统中表现优异。

每种技术都有其独特的优势,选择合适的数据库和搜索引擎应依据具体的应用场景、性能需求和数据规模。合理的技术选型不仅能够优化系统性能,还能提升用户体验,实现业务目标的最大化。


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

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

相关文章

学习ASP.NET Core的身份认证(基于JwtBearer的身份认证8)

为进一步测试通过请求头传递token进行身份验证,在main.htm中增加layui的数据表格组件,并调用后台服务分页显示数据,后台分页查询数据接口如下所示(测试时,直接将数据写死到代码中,没有查询数据库&#xff0…

Python新春烟花

目录 系列文章 写在前面 技术需求 完整代码 下载代码 代码分析 1. 程序初始化与显示设置 2. 烟花类 (Firework) 3. 粒子类 (Particle) 4. 痕迹类 (Trail) 5. 烟花更新与显示 6. 主函数 (fire) 7. 游戏循环 8. 总结 注意事项 写在后面 系列文章 序号直达链接爱…

【leetcode 24】151.翻转字符串里的单词==❗没看懂❗==

思路: 一些同学会使用split库函数,分隔单词,然后定义一个新的string字符串,最后再把单词倒序相加,那么这道题题目就是一道水题了,失去了它的意义。 所以这里我还是提高一下本题的难度:不要使用辅…

STM32+W5500+以太网应用开发+003_TCP服务器添加OLED(u8g2)显示状态

STM32W5500以太网应用开发003_TCP服务器添加OLED(u8g2)显示状态 实验效果3-TCP服务器OLED1 拷贝显示驱动代码1.1 拷贝源代码1.2 将源代码添加到工程1.3 修改代码优化等级1.4 添加头文件路径1.5 修改STM32CubeMX工程 2 修改源代码2.1 添加头文件2.2 main函…

Oracle审计

审计是监控选定的用户数据库操作的过程 审计的目的: 调查可疑的数据库活动: 审计可以帮助检测和跟踪潜在的 security breaches、未授权的访问尝试或其他异常行为。通过分析审计日志,可以确定可疑活动的来源、时间、频率和影响。 收集特定数…

智能新浪潮:亚马逊云科技发布Amazon Nova模型

在2024亚马逊云科技re:Invent全球大会上,亚马逊云科技宣布推出新一代基础模型Amazon Nova,其隶属于Amazon Bedrock,这些模型精准切入不同领域,解锁多元业务可能,为人工智能领域带来革新。 带你认识一起了解Amazon Nova…

2025 OWASP十大智能合约漏洞

随着去中心化金融(DeFi)和区块链技术的不断发展,智能合约安全的重要性愈发凸显。在此背景下,开放网络应用安全项目(OWASP)发布了备受期待的《2025年智能合约十大漏洞》报告。 这份最新报告反映了不断演变的…

力扣面试经典题

目录 前言 一、合并两个有序数组 二、移除元素 三、删除有序数组的重复项 四、删除有序数组的重复项Ⅱ 五、取数组中出现次数大于数组长度/2的元素 六、移动数组元素 七、计算数组中相差最大的值 八、字母异位词分组 九、最长连续序列 十、移动0 十一、盛水最多的容…

【RabbitMq】RabbitMq高级特性-延迟消息

延迟消息 什么是延迟消息死信交换机延迟消息插件-DelayExchange其他文章 什么是延迟消息 延迟消息:发送者发送消息时指定一个时间,消费者不会立刻收到消息,而是在指定时间之后才收到消息。 延迟任务:设置在一定时间之后才执行的任…

抖音小程序一键获取手机号

前端代码组件 <button v-if"!isFromOrderList"class"get-phone-btn" open-type"getPhoneNumber"getphonenumber"onGetPhoneNumber">一键获取</button>// 获取手机号回调onGetPhoneNumber(e) {var that this tt.login({f…

CSS:语法、样式表、选择器

目录 一、语法 二、创建 外部样式表 内部样式表 内联样式 三、选择器 ID选择器 类选择器 伪类选择器 :hover a:link a:active a:visited 属性选择器 伪元素选择器 ::first-letter ::first-line ::selection ::placeholder ::before 和::after 通配选择器 标…

配电自动化中的进线监控技术

进线监控技术是配电网自动化中的一项关键技术&#xff0c;它主要用于对配电网进线变电站的开关状态以及母线电压、电流、有功功率、无功功率及电度量等参数进行实时监测。以下是对进线监控技术的详细介绍&#xff1a; 一、技术原理 进线监控技术基于传感器技术、数据采集技术、…

【三维分割】Gaga:通过3D感知的 Memory Bank 分组任意高斯

文章目录 摘要一、引言二、主要方法2.1 3D-aware Memory Bank2.2 三维分割的渲染与下游应用 三、实验消融实验应用: Scene Manipulation 地址&#xff1a;https://www.gaga.gallery 标题&#xff1a;Gaga: Group Any Gaussians via 3D-aware Memory Bank 来源&#xff1a;加利福…

《王者荣耀》皮肤爬虫源码

1.爬取网页 https://pvp.qq.com/web201605/herolist.shtml 2.python代码 import requests from bs4 import BeautifulSoup import os import threading from queue import Queuedef mul(x):if not os.path.exists(x):os.mkdir(x)print("目录创建成功")else:pass h…

iconfont等图标托管网站上传svg显示未轮廓化解决办法

打开即时设计 即时设计 - 可实时协作的专业 UI 设计工具 导入图标后拖入画板里面&#xff0c;右键选择轮廓化 将图标导出

【Linux系列】查看服务器是否使用了 SSD 的多种方法

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

【AIGC】ChatGPT 的 Prompt Hacker 技巧:让简历轻松通过 AI 筛选

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: AIGC | ChatGPT 文章目录 &#x1f4af;前言&#x1f4af;背景简化简历格式 &#x1f4af;简化 Prompt Hacker 的逻辑使用 Prompt Hacker 技巧**示例 Prompt&#xff1a;引导 AI 筛选简历**如何利用 Prompt 优化简历筛…

AI News(1/21/2025):OpenAI 安全疏忽:ChatGPT漏洞引发DDoS风险/OpenAI 代理工具即将发布

1、OpenAI 的安全疏忽&#xff1a;ChatGPT API 漏洞引发DDoS风险 德国安全研究员 Benjamin Flesch 发现了一个严重的安全漏洞&#xff1a;攻击者可以通过向 ChatGPT API 发送一个 HTTP 请求&#xff0c;利用 ChatGPT 的爬虫对目标网站发起 DDoS 攻击。该漏洞源于 OpenAI 在处理…

windows下使用docker执行器并配置 hosts 解析

本篇目录 1. 问题背景2. 环境准备2.1 云上开通windows 2022 英文版机器2.1.1 安装 git2.1.2 安装 runner2.1.3 装docker2.1.4 注册runner并使用docker执行器 3. 项目信息3.1 编写window bat脚本3.2 项目.gitlab-ci.yml文件 4. 测试结论4.1 运行流水线 5. troubleshooting问题1&…

centos9编译安装opensips 二【进阶篇-定制目录+模块】推荐

环境&#xff1a;centos9 last opensips -V version: opensips 3.6.0-dev (x86_64/linux) flags: STATS: On, DISABLE_NAGLE, USE_MCAST, SHM_MMAP, PKG_MALLOC, Q_MALLOC, F_MALLOC, HP_MALLOC, DBG_MALLOC, CC_O0, FAST_LOCK-ADAPTIVE_WAIT ADAPTIVE_WAIT_LOOPS1024, MAX_RE…