【ES】Elasticsearch常见问题与解决(持续更新)
目录
Elasticsearch常见问题
1. 集群健康问题
2. 性能问题
3. 映射问题
4. 分片问题
5. 内存问题
6. 硬件问题
7. 配置问题
8. 安全问题
9. 网络问题
10. 版本不兼容
Elasticsearch日常使用小结
【Q】离线告警,有IP已离线
【Q】统计某个应用的某个索引的节点使用率
【Q】测试环境两个索引关联查询, 贼慢
【Q】想缩容节点, 怎么操作嘞
【Q】可以存储嵌套对象吗
【Q】测试环境一些好久没使用的索引突然发现全红了
【Q】返回 SearchPhaseExecutionException: all shards failed 异常
【Q】如果调整es索引模板的分片数量,会导致前后索引文件的不同吗?对查询有什么影响吗
【Q】有一个数据节点的磁盘空间远大于其他节点,并且实际使用空间很低,可能通过加小节点,缩容大节点处理吗?
【Q】一个索引文件建议最大分片数有限制吗?
【Q】ES 集群与副本的关系/作用/互相影响
【Q】ES 模板 新增一个索引列会影响现有数据吗?
【Q】为何索引节点分布不均? 怎么解决?
Elasticsearch (ES) 是一个强大的开源搜索和分析引擎,广泛用于全文搜索、日志和数据分析等场景。由于其复杂性,用户可能会遇到各种问题。以下是一些常见的 Elasticsearch 问题以及相应的解决方法:
Elasticsearch常见问题
1. 集群健康问题
问题: ES 集群健康状态不是绿色(可能是黄色或红色)。
解决方法:
- 黄色: 通常意味着至少一个副本分片没有被正确分配。检查是否有足够的节点来承载副本分片。
- 红色: 表示至少一个主分片未被分配。检查节点日志,确定是否有硬件故障或网络问题。
- 使用 `GET /_cluster/health` 查看集群健康状态,并根据输出解决具体问题。
场景举例:
有次控制台报这个
org.elasticsearch.action.search.SearchPhaseExecutionException: all shards failed
Caused by: org.elasticsearch.index.query.QueryShardException: No mapping found for [order] in order to sort onorg.lasticsearch.action.search.SearchPhaseExecutionException:所有碎片都失败
由:org.lasticsearch/index.query.QueryShardException引起:找不到[order]的映射以便排序
查看管理台RED
然后分片改成3个,重建索引,重新发布,还是不行,
最后发现是索引没写进去数据,很简单,也很尴尬..
模拟代码
ClusterHealthResponse healthResponse = client.cluster().health(new ClusterHealthRequest(), RequestOptions.DEFAULT);
String clusterName = healthResponse.getClusterName();
ClusterHealthStatus status = healthResponse.getStatus();
2. 性能问题
问题: 查询慢,索引速度慢。
解决方法:
- 查询优化: 确保使用正确的查询类型,避免使用高成本操作如深度分页(deep pagination)。
- 索引优化: 使用批量(bulk)API进行索引操作,调整刷新频率和分片数量。
- 硬件检查: 检查是否硬件(如 CPU、内存、磁盘IO)成为瓶颈。
// 检索慢查询日志
GetSettingsRequest request = new GetSettingsRequest().indices("your_index").includeDefaults(true);
GetSettingsResponse response = client.indices().getSettings(request, RequestOptions.DEFAULT);
String slowLogThreshold = response.getSetting("your_index", "index.search.slowlog.threshold.query.warn");
3. 映射问题
问题: 映射错误导致无法索引数据。
解决方法:
- 映射定义: 在索引数据前定义好映射,确保数据类型与映射匹配。
- 动态映射: 如果不希望自动创建映射,可以在索引设置中禁用动态映射。
- 重建索引: 如果映射错误,可能需要创建新索引并重新导入数据。
// 获取映射
GetMappingsRequest request = new GetMappingsRequest().indices("your_index");
GetMappingsResponse getMappingResponse = client.indices().getMapping(request, RequestOptions.DEFAULT);
Map<String, MappingMetadata> allMappings = getMappingResponse.mappings();
4. 分片问题
问题: 分片数量不当。
解决方法:
- 分片数量调整: 分片数量过多会增加集群负担,过少则可能不利于性能。根据数据量调整分片大小。
- 使用分片分配: 调整 `index.number_of_shards` 和 `index.number_of_replicas` 配置来更改分片数量和副本数量。
// 调整分片
ResizeRequest request = new ResizeRequest("target_index", "source_index");
request.getTargetIndexRequest().settings(Settings.builder().put("index.number_of_shards", "new_number_of_shards").put("index.number_of_replicas", "new_number_of_replicas"));
client.indices().resize(request, RequestOptions.DEFAULT);
5. 内存问题
问题: JVM 堆内存不足。
解决方法:
- 堆大小调整: 增加 JVM 堆大小,但不要超过物理内存的 50% 或 32GB(由于压缩指针的限制)。
- 内存压力分析: 使用 ES 的节点状态API分析内存压力,并相应调整。
// 检查节点状态,包括内存使用情况
NodesStatsRequest request = new NodesStatsRequest();
NodesStatsResponse response = client.nodes().stats(request, RequestOptions.DEFAULT);
JvmStats jvmStats = response.getNodesMap().get("nodeId").getJvm();
6. 硬件问题
问题: 硬件资源不足导致性能瓶颈。
解决方法:
- 资源升级: 根据需求升级 CPU、内存或磁盘。
- 负载均衡: 确保集群中的负载均衡,避免个别节点过载。
7. 配置问题
问题: 不当的配置导致问题。
解决方法:
- 配置审查: 定期审查配置文件,确保所有配置项都是必要和优化的。
- 文档参考: 参考官方文档进行配置。
// 获取当前的索引设置
GetSettingsRequest request = new GetSettingsRequest().indices("your_index");
GetSettingsResponse response = client.indices().getSettings(request, RequestOptions.DEFAULT);
String numberOfShards = response.getSetting("your_index", "index.number_of_shards");
8. 安全问题
问题: 安全漏洞或未授权访问。
解决方法:
- 启用安全: 使用 X-Pack Security 或其他安全插件。
- 最小权限原则: 为用户配置适当的权限。
- 监控和警报: 启用监控,并设置警报系统以便在出现安全问题时及时响应。
9. 网络问题
问题: 集群节点间通信问题。
解决方法:
- 网络配置检查: 确保所有节点的网络配置正确,没有防火墙或其他网络设备阻止节点间通信。
- 使用专用网络: 如果可能,为 ES 集群使用专用网络。
10. 版本不兼容
问题: 升级后的版本不兼容。
解决方法:
- 渐进升级: 按照官方推荐的升级路径逐步升级。
- 备份数据: 在任何升级操作前备份数据。
// 获取 ES 版本信息
MainResponse response = client.info(RequestOptions.DEFAULT);
Version version = response.getVersion();
对于所有这些问题,查看 Elasticsearch 的日志文件通常是诊断问题的第一步。日志文件中的错误和警告信息可以提供问题的直接线索。此外,Elasticsearch 的社区和文档是解决问题的宝贵资源。记住,改变配置或硬件之前,最好先在非生产环境中测试。
Elasticsearch日常使用小结
【Q】离线告警,有IP已离线
描述:离线告警,有IP已离线,请关注;
影响:节点离线瞬间,最多出现1分钟抖动(master宕机)。若存在副本则业务无影响;若无副本,集群会存在不可用索引,请及时检查业务监控可能会出现好多yellow的索引,等恢复后,离线的节点会自动加回来还有联系运维就行
【Q】统计某个应用的某个索引的节点使用率
一般在应用列表查看节点信息, 后面一般会有磁盘占用率disk, 一般用于查看是否达到扩容标准
【Q】测试环境两个索引关联查询, 贼慢
经研究发现不是代码问题,由于公司降本增效,
测试环境集群是很多项目共用的,然后这个集群分片数太多,
换个集群数据重新写入下就OK了...
见笑了...
【Q】想缩容节点, 怎么操作嘞
首先在es平台查看当前的集群磁盘使用情况,
根据未来的大概使用情况的评估再去决定缩容多少,
还有参考节点的规格都是多大的磁盘(这边一般1T),
操作后, 缩容前会将数据迁移到其他节点,数据迁移完后才会去真正缩容节点还有集群最小3个节点哟...
【Q】可以存储嵌套对象吗
可以的, 但是我们这里的平台需要通过自定义导入添加
【Q】测试环境一些好久没使用的索引突然发现全红了
发现迁移过集群, 重建下索引就可以了
【Q】返回 SearchPhaseExecutionException: all shards failed 异常
查询报这个错, 搞点数据就行了...
【Q】如果调整es索引模板的分片数量,会导致前后索引文件的不同吗?对查询有什么影响吗
对现有查询没有影响,已生成的索引分片数不会改,不过新生成的索引分片数会变。在 Elasticsearch 中,索引模板定义了创建新索引时所应用的设置,包括分片数量。如果你调整了索引模板中的分片数量,这将会影响之后基于该模板创建的新索引。现有索引的分片数量不会受到影响,因为一旦索引被创建,其分片数量就是固定的。以下是关于调整分片数量的几个关键点:1. 新索引:模板中分片数量的更改只会影响在更改之后创建的索引。这意味着新索引将根据新的模板设置来设定其分片数量。2. 现有索引:对于已经存在的索引,分片数量保持不变。如果你需要改变现有索引的分片数量,你必须重新索引数据到一个新的索引,该新索引具有所需的分片数量。3. 查询影响:更改分片数量可能会对查询性能产生影响:- 减少分片:如果减少了分片数量,每个分片会存储更多的数据。这可能会导致查询单个分片变慢,因为每个分片处理的数据量增加了。但是,因为分片总数减少,所以总体上可能会降低协调节点的压力,因为它需要合并的结果集更少了。- 增加分片:增加分片数量会导致每个分片存储较少的数据,这可能会提高单个分片的查询性能。但是,如果分片数量过多,可能会增加协调节点合并结果的开销,从而影响查询性能。4. 索引文件不同:不同的分片数量意味着索引的数据分布方式不同,因此索引文件会不同。每个分片都是一个独立的 Lucene 索引,拥有自己的文件集。5. 水平扩展:分片是 Elasticsearch 进行水平扩展的基本单位。一个良好的分片策略可以帮助在多个节点间平衡数据和查询负载。6. 容错和恢复:分片数量也影响到集群的容错能力。更多的分片意味着在节点故障时,需要重新分配的数据更加分散,可能会加快恢复速度,但同时也增加了集群状态管理的复杂性。更改索引模板的分片数量是一个重要决策,应该基于对现有查询性能、数据增长预期、硬件资源等因素的综合考虑。在生产环境中进行此类更改前,建议进行充分的测试,以评估对查询性能和集群管理的影响。
【Q】有一个数据节点的磁盘空间远大于其他节点,并且实际使用空间很低,可能通过加小节点,缩容大节点处理吗?
本次处理:节点都是固定规格的,可以想办法共用其他集群在 Elasticsearch 中,如果你有一个数据节点的磁盘空间远大于其他节点,并且实际使用空间很低,你可能想要重新平衡集群以更有效地利用资源。以下是一些步骤和策略,你可以考虑实施以缩容大节点并通过添加更小的节点来平衡集群:1. 添加新的小节点
首先,你可以向集群中添加一个或多个小的数据节点。确保这些新节点的配置(如 CPU、内存、磁盘类型和网络连接)与现有节点相似,以保持集群的均衡性。2. 重新分配分片
添加新节点后,Elasticsearch 会自动开始重新分配分片以平衡集群。你可以通过以下方式帮助这个过程:- 使用 Shard Allocation Filtering:你可以通过设置分片分配过滤来鼓励 Elasticsearch 将分片从大节点移动到新的小节点。例如,你可以使用 `_cluster/settings` API 更新集群设置,为大节点设置一个权重,使其更不可能接收新分片。- 手动迁移分片:如果自动平衡不符合你的需求,你也可以手动迁移分片。通过 `_cluster/reroute` API,你可以强制将特定分片从一个节点移动到另一个节点。3. 缩容大节点
如果你希望缩小大节点的磁盘空间,这通常意味着你需要停止节点,更改硬件配置,然后重新加入集群。这是一个影响较大的操作,需要谨慎执行,并确保在操作期间集群的副本分片可以保持数据的完整性和可用性。
4. 优化分片数量和大小在 Elasticsearch 中,拥有适当大小和数量的分片对于集群性能和资源利用率至关重要。如果你注意到某个节点的磁盘使用率特别低,这可能是因为分片没有被均匀分布,或者整个集群的分片数量太多或太少。- 调整分片数量:你可以通过修改索引的分片数量来优化存储分布。对于新索引,你可以在创建时指定分片数量。对于现有索引,你需要使用重新索引(reindex)或分片调整大小(shrink/expand)的操作来调整分片数量。- 合并(force merge)分片:如果你的索引是静态的(不再写入新数据),你可以使用 force merge 操作来减少每个索引的分片数,这样可以提高查询效率并减少磁盘空间的使用。5. 调整分片分配策略Elasticsearch 允许你通过各种设置来控制分片是如何在集群中分配的。你可以使用分片分配感知(Shard Allocation Awareness)和强制感知(Forced Awareness)来确保分片均匀地分布在不同的节点上。- 使用分片分配感知:你可以配置集群,使其意识到节点的物理位置或其他属性,从而在不同的组或区域之间平衡分片。- 使用强制分片分配:在某些情况下,你可能需要强制集群将分片分配到特定的节点或节点组。这可以通过集群设置来实现。6. 监控和调整在对集群进行任何重大更改后,密切监控集群的性能和状态是非常重要的。使用 Elasticsearch 的监控工具,如 Kibana 中的 Stack Monitoring 功能,可以帮助你了解更改的影响。- 监控集群状态:确保集群状态保持在绿色,这意味着所有的分片都已正确分配且没有问题。- 监控节点和索引性能:查看各个节点的负载,以及索引和查询的性能。7. 清理和维护定期清理未使用的索引和优化现有索引可以帮助你更好地利用硬件资源。- 删除旧索引:定期删除不再需要的旧数据可以释放大量空间。- 使用 ILM(索引生命周期管理):自动化索引的生命周期管理,包括创建、优化和删除索引。8. 考虑使用热/温/冷架构如果你的数据访问模式具有明显的热度层次,可以考虑实施热/温/冷数据架构。在这种架构下,你可以将新数据(热数据)放在性能更高的节点上,而将访问频率较低的数据(冷数据)迁移到成本更低的存储上。9. 考虑 Elasticsearch 的最佳实践确保你遵循 Elasticsearch 的最佳实践,包括合理的分片大小(通常建议每个分片保持在几十 GB 的大小),以及合理的分片和副本数量。10. 集群重新平衡后的维护在集群重新平衡之后,持续监控并根据需要调整分片分配策略和集群配置。务必确保所有变更不会影响到集群的稳定性和性能。在进行任何重大更改之前,最好先在测试环境中模拟这些更改,以确保它们不会对生产环境造成意外的副作用。此外,始终确保在进行任何可能影响数据完整性的操作之前备份你的数据。
【Q】一个索引文件建议最大分片数有限制吗?
一个索引文件建议最大分片数有限制吗?当在每个分片数据都写满的情况下,分片数到达某个什么值的时候,才会做周期生成索引文件。还是周期索引和分片数量的多少,没有任何关系,只是周期索引更便于清理数据和根据业务的增长,调整以后索引文件的分片数?在 Elasticsearch 中,索引的分片数量应根据数据量、硬件资源、查询负载以及数据的生命周期来合理设置。没有硬性规定说一个索引的分片数量上限是多少,但是确实有一些最佳实践和考虑因素:分片大小的建议- 每个分片的大小:通常建议每个分片的大小保持在几十 GB(比如 20GB 到 50GB)以内。这样做的原因是为了保持分片的管理和恢复的效率。分片数量的考虑- 硬件资源:分片数量过多可能会导致节点上的文件句柄使用过多、内存压力增大以及集群状态信息过于庞大,这些都可能影响集群的性能和稳定性。- 查询性能:每个查询都需要在所有相关分片上执行,如果分片数量过多,可能会降低查询性能。- 数据写入:数据写入时,如果分片数过多,每个分片处理的文档数较少,可能会造成资源浪费。周期索引的使用周期索引(如按天、按周或按月分割的索引)通常与分片数量无直接关系,它们主要是为了:- 数据管理:周期索引使得数据的删除变得简单,你可以直接删除整个索引而不是删除特定日期范围内的文档。- 性能优化:随着时间的推移,你可以根据数据量和查询模式调整新周期索引的分片数量。- 热/温/冷架构:周期索引可以方便地实现不同数据温度的存储策略,如将旧的索引移动到成本更低的存储。索引生成的触发索引的生成通常是由以下因素触发的:- 时间周期:基于时间的索引策略会按照预定的周期创建新索引。
- 数据量:达到一定数据量后,可以选择创建新索引。
- 性能和维护:为了优化性能和维护的方便,可以定期创建新索引。结论总的来说,分片数量的多少和周期索引的创建是两个独立的考虑点,它们都应该基于你的业务需求和实际的使用情况来决定。周期索引是一种数据管理策略,而分片数量的设置则涉及到性能和资源利用的优化。在实践中,你可能需要根据索引的大小、查询的复杂性以及数据增长的速度来调整这些设置。
【Q】ES 集群与副本的关系/作用/互相影响
在 Elasticsearch 中,集群是由多个节点组成的,而副本是数据的冗余拷贝,分为主分片和副本分片。它们之间的关系、作用以及相互影响可以从以下几个方面来理解:集群与副本的关系集群:由一组节点组成,这些节点可以持有数据并对外提供搜索和索引功能。集群中的节点可以分为不同的角色,如主节点、数据节点、协调节点等。
副本:每个索引可以有一个或多个主分片,以及零个或多个副本分片。每个主分片的副本分片是其数据的精确拷贝。副本的作用高可用性:副本提供了数据的高可用性。如果主分片所在的节点失败,副本分片可以被提升为新的主分片,确保数据不会丢失。
读取扩展:副本可以提高读取(搜索)操作的吞吐量。搜索操作可以在主分片和副本分片上并行执行,从而提高搜索性能。
写入一致性:当数据被写入主分片后,它会被复制到所有的副本分片。这确保了数据在主分片和副本分片之间的一致性。集群与副本的互相影响资源消耗:副本分片需要占用额外的磁盘空间、内存和CPU资源。在设计集群时,需要考虑到副本对资源的需求。故障恢复:在节点或分片发生故障时,集群需要重新分配副本分片。这个过程可能会对集群的性能造成短暂影响,因为数据需要在节点之间移动以确保副本的数量和分布符合预期。但是,这也确保了数据的可用性和持久性。写入性能:尽管副本可以提高读取性能,但它们也会影响写入性能。每次写入操作都需要在主分片上完成,并复制到所有副本分片。因此,副本的数量会影响写入操作的延迟。集群扩展:副本分片可以在集群中的多个节点上分布,这有助于分散读取负载。随着集群的扩展,副本分片可以被分配到新的节点上,进一步增强读取性能和集群的容错能力。集群状态管理:副本分片的数量和状态会影响集群状态的管理。集群状态信息包括了所有分片的位置和健康状况,当副本数量很多时,集群状态信息可能变得很大,这可能会对集群管理和监控系统造成额外压力。数据一致性:在分布式系统中,数据一致性是一个核心问题。Elasticsearch 使用一致性模型确保数据在主分片和所有副本分片之间保持同步。但是,在网络分区或节点故障的情况下,保持数据一致性可能会变得复杂。副本配置:Elasticsearch 允许动态调整副本的数量。在数据量较小或读取压力不大时,可以减少副本的数量以节省资源。在读取压力增大时,可以增加副本的数量以提高查询性能。结论副本是 Elasticsearch 高可用和扩展性的关键组件。它们不仅确保了数据的安全,也提供了查询性能的提升。但是,副本也会对集群的资源消耗和写入性能产生影响。因此,合理配置副本的数量是 Elasticsearch 集群管理的重要方面。集群规划时,需要权衡副本带来的可用性和性能提升与其资源成本之间的关系,以确定最佳的副本策略。
【Q】ES 模板 新增一个索引列会影响现有数据吗?
在 Elasticsearch 中,模板(通常指索引模板)定义了索引的设置和映射。如果你在索引模板中新增一个字段(索引列),这将影响新创建的索引,而不会直接影响已经存在的索引中的数据。以下是关于如何处理索引模板更改和现有数据的几个关键点:1. 新索引:当你在模板中添加一个新字段后,此更改只会应用于之后基于该模板创建的新索引。这意味着新的字段会在新索引的映射中出现。2. 现有索引:对于已经存在的索引,模板的更改不会自动应用。已有索引的映射一旦创建后,字段就不能被删除,但可以添加新的字段。3. 添加字段到现有索引:如果你想在已有的索引中添加新字段,你需要使用 PUT mapping API 来显式地更新那个索引的映射。这可以在不中断服务的情况下完成,因为 Elasticsearch 支持动态映射更新。4. 数据兼容性:添加新字段通常不会影响到现有数据。现有文档中不会有这个新字段的值,除非你更新这些文档来包含它。对于新字段的搜索查询,如果字段不存在于某个文档中,Elasticsearch 会认为该字段在该文档中的值为 null。5. 重建索引:如果需要在现有索引中添加很多新字段或者需要改变字段的类型,通常的做法是创建一个新的索引,并将现有数据重新索引到这个新的索引中。6. 别名使用:在做这种更改时,使用别名可以避免对前端应用的影响。你可以将别名从旧索引转移到新索引,这样应用程序就不需要更改它们所指向的索引名。在对模板或映射进行更改时,始终建议在开发或者测试环境中先行测试,以确保更改不会对现有应用造成不良影响。此外,确保你有完整的数据备份,以防在更改过程中需要恢复数据。
【Q】为何索引节点分布不均? 怎么解决?
这里是由于 分片数不是节点N的倍数导致的,是倍数的话就会均匀些,
但已生成的固定索引就该改不了了,
对使用上影响不大 (如果磁盘使用率80%往上了, 主要得解决集群整体磁盘使用高的问题了),
比如把分片数改成3N个,已有索引的分片数不会改,
后面新的周期索引会变成3N个分片, 新的索引会根据新的模板生成,就会变分片数了. 下面对类似情况做些总结:Elasticsearch 索引数据分布不均衡可能由多种原因导致,这里列举一些常见原因以及相应的解决方案:原因1. 节点规格不一致:如果集群中的节点硬件规格(CPU、内存、磁盘大小和速度)不一致,可能会导致数据分布不均。2. 分片数量设置不当:索引的分片过多或过少都可能导致数据分布不均。3. 索引和分片设置不均衡:不同索引的分片数量和大小差异较大,可能会导致某些节点承载更多数据。4. 集群扩展:新节点加入集群时,现有的分片不会自动重新分布。5. 分片分配策略:Elasticsearch 的分片分配策略可能导致分片不均匀地分配到节点上。6. 写入模式:如果写入操作总是针对特定的索引,那么那些索引所在的节点将会有更高的负载。解决方案1. 硬件规格一致性:确保所有节点的硬件规格大致一致,以便于均匀地分配负载。2. 合理设置分片数量:根据数据量和查询负载合理设置分片数量。可以使用 Elasticsearch 的 `_shrink` 和 `_split` API调整现有索引的分片数量,或者在创建新索引时指定合适的分片数。3. 使用分片分配感知:配置分片分配感知(Shard Allocation Awareness),让 Elasticsearch 理解你的物理部署结构,并确保分片在不同的物理分组间均匀分配。4. 手动重新分配分片:使用 Elasticsearch 的集群 API 手动重新分配分片到不同的节点。5. 自动平衡:开启 Elasticsearch 的集群自动平衡(Cluster Rebalancing)功能,让集群自动调整分片的位置。6. 索引模板和别名:使用索引模板和别名来分散写入负载。例如,可以创建时间或大小基础上的滚动索引。7. 磁盘水位设置:调整磁盘水位设置,以防止某些节点因为磁盘空间不足而无法接收新分片。8. 使用 ILM 策略:如果是时间序列数据,可以使用索引生命周期管理(ILM)策略来自动管理
有用请点赞,养成良好习惯!
疑问、交流、鼓励请留言!
相关文章:
【ES】Elasticsearch常见问题与解决(持续更新)
目录 Elasticsearch常见问题 1. 集群健康问题 2. 性能问题 3. 映射问题 4. 分片问题 5. 内存问题 6. 硬件问题 7. 配置问题 8. 安全问题 9. 网络问题 10. 版本不兼容 Elasticsearch日常使用小结 【Q】离线告警,有IP已离线 【Q】统计某个应用的某个索引…...
2023.12.29 Python面向对象 封装_继承_多台
目录 1.封装-私有与公开权限 2.继承 2.1多继承 2.2继承多层传递 2.3重写父类方法 2.4继承链 2.5禁止私有继承 3.多态 4.总结 1.封装-私有与公开权限 公开属性、公开方法:随便调用 私有属性、私有方法: 只能在类定义的内部调用 以两个下划线开头__的…...
通过自然语言处理增强推荐系统:协同方法
一、介绍 自然语言处理 (NLP) 是人工智能的一个分支,专注于使机器能够以有意义且有用的方式理解、解释和响应人类语言。它包含一系列技术,包括情感分析、语言翻译和聊天机器人。 另一方面,推荐系统(RecSys)是旨在向用户…...
大创项目推荐 深度学习OCR中文识别 - opencv python
文章目录 0 前言1 课题背景2 实现效果3 文本区域检测网络-CTPN4 文本识别网络-CRNN5 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 **基于深度学习OCR中文识别系统 ** 该项目较为新颖,适合作为竞赛课题方向,…...
Python经典游戏 唤醒你童年记忆
这些游戏你玩过几个? 1.贪吃蛇2.吃豆人3.加农炮4.四子棋5. Fly Bird<font color #f3704ab>6.记忆:数字对拼图游戏(欢迎挑战!用时:2min)7.乒乓球8.上课划水必备-井字游戏(我敢说100%的人都…...
什么是骨传导耳机?骨传导能保护听力吗?
骨传导耳机是一种非常特殊的蓝牙耳机,它通过骨传导技术将声音直接传送到内耳。这种技术不同于传统耳机,它不通过空气传送声音,而是通过头骨的振动来传送声音。 并且骨传导耳机能够在一定程度上起到保护听力的作用,主要是因为它们不…...
使用electron属性实现保存图片并获取图片的磁盘路径
在普通的网页开发中,JavaScript由于安全性的考虑,通常是无法直接获取到客户端的磁盘路径的。浏览器出于隐私和安全原因对此类信息进行了限制。 在浏览器环境下,JavaScript主要通过Web APIs来与浏览器进行交互,而这些API通常受到浏…...
进击的奶牛
题目 进击的奶牛 题意 通过二分查找算法找到一个最小间距x,使得在数组a中选出的k个数两两之间的间距都不小于x,并且x尽可能大。最后输出这个最大的x值。 思路 程序通过循环依次获取了n个整数,存储在数组a中。.然后,程序对数组a进…...
12月27日,每日信息差
以下是2023年12月27日的8条信息差 第一、小米公司:小米汽车正式加入小米“人车家全生态”,随着小米汽车的即将发布,小米“人车家全生态”也实现了真正闭环 第二、吉利将于2024年初发射11颗卫星,吉利银河E8率先搭载卫星通信技术。…...
【赠书第14期】AI短视频制作一本通:文本生成视频+图片生成视频+视频生成视频
文章目录 前言 1 前期准备 2 拍摄与录制 3 后期编辑 4 技巧与注意事项 5 推荐图书 6 粉丝福利 前言 随着智能技术的迅猛发展,AI 短视频制作成为了一种新兴而创新的表达方式,广泛应用于社交媒体、广告营销、教育培训等领域。本文将介绍 AI 短视频…...
简单工厂设计模式(计算器实例优化)
简单工厂设计模式(计算器实例优化) 介绍为什么采用面向对象编程而不是面向过程呢?实例讲解业务层划分出来逻辑层继承简单工厂:(多态)业务层:(解耦合)主控制台 总结 介绍 …...
iconify图标集离线使用方案简介
1.需求描述 前端项目,技术栈使用Vue3Element Plus,参考了ruoyi-vue-pro项目与vue-element-plus-admin项目,封装了一个Icon组件,图标使用的是iconify,项目部署在内网环境,不能连接互联网,需要部署一套iconi…...
java基础之理解多态
目录 简单理解 满足多态的三个条件 有类继承或者接口实现 子类要重写父类的方法 父类的引用指向子类的对象。 代码示例 动态多态 静态多态 个人观点 简单理解 简单理解就是,同一操作作用于不同的对象,可以有不同的解释,产生不同的执…...
第二证券:A股市场放量反弹 跨年行情或启动
沪指日线等级放量反弹,周四收中阳线成功站上20日均线,底部结构或可树立。创业板指大涨近4%,日线MACD出现底违反,多方动能较强,中等级反弹行情或在酝酿。月线来看,12月创业板指探底上升出现较长下影…...
web漏洞与修复
一、web漏洞 检测到目标X-Content-Type-Options响应头缺失 详细描述X-Content-Type-Options HTTP 消息头相当于一个提示标志,被服务器用来提示客户端一定要遵循在 Content-Type 首部中对 MIME 类型 的设定,而不能对其进行修改。这就禁用了客户端的 MIM…...
基于Java+SpringBoot+vue实现图书借阅管理系统
基于JavaSpringBootvue实现图书借阅和销售商城一体化系统 🍅 作者主页 程序设计 🍅 欢迎点赞 👍 收藏 ⭐留言 📝 🍅 文末获取源码联系方式 📝 文章目录 基于JavaSpringBootvue实现图书借阅和销售商城一体化…...
xml文件学习(xml格式)可扩展标记语言(Extensible Markup Language)
XML 教程 文章目录 XML 文件学习1. XML 概述1.1 什么是 XML?1.2 XML 有什么作用? 2. XML 基本结构1. 声明2. 元素3. 属性4. 文本5. 注释 3. XML 高级知识3.1 XML 命名空间3.2 XML 架构3.3 XML 工具3.4 XML 技术 4. XML 应用实例 XML 文件学习 XML&#…...
nodejs+vue+ElementUi家政服务系统c90g5
项目中登录模块用到token家政服务平台有管理员,雇主,雇员三个角色。管理员功能有个人中心,雇主管理,雇员管理,资料认证管理,项目类型管理,服务项目管理,需求信息管理,服务…...
数据库(Database)基础知识
什么是数据库 数据库是按照数据结构来组织、存储和管理数据的仓库,用户可以通过数据库管理系统对存储的数据进行增删改查操作。 数据库实际上是一个文件集合,本质就是一个文件系统,以文件的方式,将数据保存在电脑上。 什么是数据…...
QT应用篇 二、QML用Image组件实现Progress Bar 的效果
QT应用篇 一、QT上位机串口编程 二、QML用Image组件实现Progress Bar 的效果 三、QML自定义显示SpinBox的加减按键图片及显示值效果 文章目录 QT应用篇前言一、qml需求二、使用组件1.Image组件2.Image中fillMode的使用例子 总结 前言 记录自己学习QML的一些小技巧方便日后查找…...
SElinux工作原理简介并演示chcon、semanage、restorecon的使用方法
目录 一.SElinux工作原理简介 1.system_u 2.object_r 3.httpd_sys_content_t 4.s0 二.SElinux策略的具体使用详情 1.restorecon 2.semanage 3.chcon 一.SElinux工作原理简介 通过mac方式管理进程,管理的目标是进程是否具有读取权限的文件(文件…...
表情串转换
前言 NWAFU 2021阶段二 D 一、题目描述 题目描述 在一个字符串中,设置了由‘/’前导字符和某些特定字母构成的转义子字符串,如“/s”、“/f”、“/c”等用于表示特殊表情符号。现要求编写一个函数,将给定字符串中的转义字符串转换为表情字…...
【娱乐小技巧】网页旋转90° 3步搞定
一、按F12,打开控制台; 二、点击号; 插入新body; 三、粘贴代码 -webkit-transform: rotate(90deg);小结,角度值可以自选; 代码的效果:...
移动管理系统软件哪家好?它是如何帮助企业降本增效的?
现在很多管理系统都可以用移动设备接入,最常见的就是手机。只要给管理系统创建一个微信小程序接口,那么要使用系统功能的时候直接打开微信小程序就可以了。例如我们小区的物业巡检就是通过微信扫码打开巡检工单记录信息的,直接用巡检保安自己…...
电脑表格文件丢失如何找回?3个方法拯救丢失的文件!
“太难了!我辛辛苦苦在电脑上做的表格,不知道什么原因突然就没有了,有什么方法可以找回丢失的表格文件吗?快帮帮我吧!” 在日常工作中,很多电脑用户可能都会用到表格文件,这往往记载了大量的重要…...
VSCode 如何安装插件的历史版本
背景 在日常开发过程中,我们可能会遇到新版VSCode插件存在问题,无法正常工作的情况。这种情况下,一种可行的解决方案就是安装插件的历史版本。VSCode 插件默认安装的都是插件最新的版本,例如下面 vscode-styled-compoents 插件 本…...
关于edge浏览器以及插件推荐
目录 广告拦截和隐私工具 密码管理器 生产力和组织工具 写作和语法工具 购物助手 娱乐和个性化 安全性和VPN 开发者工具 其他实用工具 Microsoft Edge 是一款基于Chromium开源项目的现代网络浏览器,由微软开发。它是Internet Explorer的继任者,…...
Vue Tinymce富文本组件自定义操作按钮
想实现如下效果 首先在init方法中的增加一插件 增加一个setup方法 代码 setup: function(editor) { editor.ui.registry.addButton(testButton, {text: 日记日期,tooltip: 插入日记日期,onAction: () > editor.insertContent("123456")});}, 操作效果࿰…...
论文阅读:Blind Super-Resolution Kernel Estimation using an Internal-GAN
这是发表在 2019 年 NIPS 上的一篇文章,那个时候还叫 NIPS,现在已经改名为 NeurIPS 了。文章中的其中一个作者 Michal Irani 是以色 Weizmann Institute of Science (魏茨曼科学研究学院) 的一名教授,对图像纹理的内在统计规律有着很深入的研…...
韩国Neowine车规认证加密芯片ALPU-CV
由工采网代理的ALPU-CV是韩国Neowine(纽文微)推出的一款高性能车规级加密芯片;也是ALPU系列中的高端IC,该芯片通过《AEC-Q100》认证,目前已经在国产前装车辆配件量产使用,主要用于版权license保护、设备防伪…...
网站上的高清动态图怎么做的/免费网络项目资源网
概述 在写程序时经常会进行一些配置,比如开启关闭某些功能、修改一些常量等,会反复去修改配置文件。实际上MKD可以将其变为配置界面,这样在修改时更加直观、方便。只需要根据configuration wizard的格式来编写我们的配置文件即可。 功能介绍 1.头尾 文件中的开头和结尾需…...
建网站和app/南城网站优化公司
关于SMBIOS一, 1.什么是SMBIOS? A: SMBIOS(System Management BIOS),是主板或者系统制造者以标准的格式显示产品管理信息所需遵循的统一规范.也就是不管你是怎么去实现的,结果 ...MySQL的数据库,数据表,数据的操作数据库简介 概念 什么是数据库?简单来…...
建设部资质上报系统网站/seo排名优化软件有用吗
2019独角兽企业重金招聘Python工程师标准>>> 实验目的 了解超声波模块的工作原理 学习使用超声波模块测量距离 实验器材 TPYBoard v202 1块 超声波模块(HC-SR04)1个 micro USB数据线 1条 杜邦线 若干 超声波模块的介绍 实物图 工作原理 (1) 采…...
wordpress显示分类文章/谷歌搜索引擎在线
这里为你提供了三种动态加载js的jquery实例代码哦,由于jquery是为用户提供方便的,所以利用jquery动态加载文件只要一句话$.getScript(\"test.js\");就OK了。 <!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" &q…...
网站设计制作报告/百度推广账号怎么注册
本节向大家讲解一下SVN提交更新的一些准则,上一节我们学习了SVN提交时遇到的一些问题及解决方法,这里和大家分享一下SVN提交更新的一些准则,欢迎大家一起来学习SVN提交更新问题。 记得有一次提交SVN更新,将Eclipse自动生成的文件也…...
网站建设工作讲话/百度风云榜官网
在使用Maven的过程中,经常会遇到几个核心的概念,准确的理解这些概念将会有莫大的帮助。 1. POM(Project Object Model)项目对象模型 POM 与 Java 代码实现了解耦,当需要升级版本时,只需要修改POM,而不需要更改Java代码…...