ElasticSearch深入解析(六):集群核心配置
1.开发模式和生产模式
Elasticsearch默认运行在开发模式下,此模式允许节点在配置存在错误时照常启动,仅将警告信息写入日志文件。而生产模式则更为严格,一旦检测到配置错误,节点将无法启动,这是一种保障系统稳定性的安全机制。
两种模式的区分关键在于network.host
的配置:当修改该参数的默认值后,系统会自动从开发模式切换至生产模式。一般来说,个人搭建测试集群时,推荐使用开发模式;若处于企业级正式环境,则必须采用生产模式以确保系统安全可靠。
2.Linux前置配置
ElasticSearch的部署过程一般都是基于Linux操作系统进行的。
为了实现快速部署,我们要修改如下的基础配置:
(1)修改文件描述符数目
为什么要修改该配置呢?
首先,Elasticsearch在节点和HTTP客户端之间进行通信使用了大量的套接字,而套接字需要足够的文件描述符支持。其次,在许多Linux发行版本中,每个进程默认有1024个文件描述符,这对Elasticsearch节点来说实在是太低了,何况该节点要处理数以百计的索引,所以要调大这个默认值。
- 设置环境变量:设定同时打开文件数的最大值为65535,并使命令生效。
vim /etc/profile
ulimit -n 65535
source /etc/profile
- 修改limits.conf配置文件:在/etc/security/limits.conf增加如下内容,限制打开文件数为65535。
soft nofile 65535
hard nofile 65535
- 验证修改操作是否成功:切换到elastic用户,使用ulimit-a查看是否修改成功。
ulimit -a
(2)修改最大映射数量
Elasticsearch对各种文件混合使用了niofs(非阻塞文件系统)和mmapfs(内存映射文件系统),以实现对各种文件的优化处理。为了保证系统的顺畅运行,需要合理配置最大映射数量(MMP),以便有足够的虚拟内存可用于内存映射的文件。
关于niofs(非阻塞文件系统)和mmapfs(内存映射文件系统)的说明可以看最后一章的说明。
- 一种设置方式如下:
sysctl -w vm.max_map_count=262144
- 另一种设置方式则是在/etc/sysctl.conf修改vm.max_map_count,执行sysctl-p来使修改生效:
tail -f /etc/sysctl.conf
vm.max_map_count=262144
3.elasticsearch.yml配置文件解读
path.data配置注意事项:
1)不要修改data路径下的任何文件,手动修改会有数据损坏或丢失的风险。
2)不要尝试对数据目录进行备份,因为Elasticsearch不支持文件备份后的恢复操作。
3)使用快照snapshot命令对集群进行备份,使用restore命令进行恢复。
4)不要对数据路径进行病毒扫描,病毒扫描可能会阻止Elasticsearch工作,甚至修改数据目录内容。
4.jvm.option配置文件解读
Elasticsearch的堆内存配置在性能调优中非常重要。以下是一些关于Elasticsearch堆内存配置的要点:
- 分配合适的堆内存大小:
Elasticsearch的堆内存大小直接影响其性能。如果设置得太小,可能查询时内存不够而导致服务宕机;如果设置得太大,又会超过JVM用于压缩对象指针的阈值而导致内存浪费。建议将堆大小配置为服务器可用内存的50%,但不要超过30GB(压缩对象指针的阈值)。过小的堆内存会导致频繁的垃圾回收,而过大的堆内存可能会导致长时间的垃圾回收暂停,影响性能。
-Xms4g
-Xmx4g
Xms代表最小的堆内存大小,Xmx代表最大的堆内存大小,这两个值必须设置成一样的。
问题:为什么说堆内存不要超过机器内存的一半?
在Elasticsearch的性能优化中,内存分配是关键一环,而其中最需要平衡的是两大内存使用者:Elasticsearch堆和Lucene。
内存分配的本质是“协作而非独占”:Elasticsearch的性能优化并非“堆越大越好”,而是需要平衡自身运算需求与Lucene的缓存需求。通过为操作系统保留足够内存,让Lucene借助系统级缓存加速数据访问,才能实现整体性能的最大化。
(1)堆(Heap):ES的“运算大脑”
- 作用:堆是Elasticsearch自身的内存空间,用于存储各类动态数据结构(如缓存、实时数据等),支持快速读写操作。
- 重要性:堆的大小直接影响ES的实时处理能力,但若分配过大,会导致垃圾回收(GC)变慢,反而拖累性能。
(2)Lucene:依赖操作系统的“静态数据仓库”
Lucene是ES底层的搜索引擎库,其设计理念是利用操作系统的内存缓存机制来优化性能,核心特点如下:
- 数据存储形式:Lucene将数据存储在**不可变的段文件(Segment Files)**中(例如倒排索引、正排索引)。
- 倒排索引:用于全文搜索(如关键词匹配);
- 正排索引:用于聚合统计(如数值计算、分组分析)。
- 缓存优势:由于段文件一旦生成就不会修改,操作系统会自动将频繁访问的“热段”缓存到内存中,实现快速读取。
- 关键依赖:Lucene的性能高度依赖操作系统的内存分配。如果ES占用了全部内存,Lucene将无法利用缓存,导致搜索和聚合速度大幅下降。
(3)内存分配的黄金法则:50% vs 50%
- 标准策略:
将服务器可用内存的 50% 分配给ES堆,剩余 50% 留给操作系统(供Lucene缓存使用)。- 例:若服务器有32GB内存,ES堆设为16GB,剩下16GB由操作系统管理,用于缓存Lucene段文件。
- 背后逻辑:
- 留给Lucene的“空闲内存”并非真正空闲,而是由操作系统自动调度,优先缓存高频访问的数据段,提升查询效率;
- 限制堆大小可避免ES因内存过大导致GC卡顿,同时让Lucene充分利用系统级缓存,实现“双优”平衡。
(4)进阶优化:按需缩减堆大小
如果业务场景满足以下条件,可进一步减少堆内存:
- 无需对文本字段做聚合(如关闭
text
类型的fielddata
功能)。 - 优化效果:
- 更小的堆 → 更快的GC效率(减少停顿时间);
- 更多内存留给Lucene → 更多段文件被缓存,搜索和索引性能进一步提升。
5.附
(1)什么是niofs(非阻塞文件系统)
NIOFS(非阻塞文件系统)通常指基于 非阻塞I/O(Non-blocking I/O)技术 实现的文件系统或文件操作机制,其核心特点是允许在文件读写等操作过程中无需等待操作完成,即可继续处理其他任务,从而提升系统在高并发场景下的效率。
核心概念解析:
-
非阻塞I/O(NIO)
传统文件操作(如Java的InputStream
/OutputStream
)是阻塞式的:当程序读取或写入文件时,会一直等待操作完成,期间无法执行其他任务。
而NIO技术通过 通道(Channel) 和 缓冲区(Buffer) 实现异步操作,允许程序在等待文件操作时继续处理其他逻辑(如通过事件监听机制通知操作完成),显著减少线程阻塞带来的性能损耗。 -
NIOFS的典型应用
在Java生态中,java.nio.file
包(NIO.2)提供了基于NIO的文件系统API(如Path
、Files
类),支持异步文件操作(如异步读取、写入、文件属性查询等)。虽然底层文件系统(如EXT4、NTFS)本身仍是阻塞的,但通过NIO库的封装,上层应用可实现非阻塞的文件操作逻辑。 -
核心优势
- 高并发处理:适用于需要同时处理大量文件I/O的场景(如分布式文件系统、日志处理系统),避免线程因阻塞而被占用。
- 资源利用率:减少线程等待时间,降低内存和CPU资源消耗。
- 灵活性:支持更细粒度的文件操作控制(如文件锁、符号链接处理等)。
与传统阻塞文件系统的对比:
特性 | 阻塞式文件系统 | NIOFS(非阻塞文件系统) |
---|---|---|
操作方式 | 同步阻塞,需等待操作完成 | 异步非阻塞,可注册回调或事件监听 |
线程占用 | 每个I/O操作需独立线程或阻塞当前线程 | 少量线程可处理大量并发I/O |
适用场景 | 简单、低并发的文件操作 | 高并发、高性能要求的复杂文件操作 |
注意事项:
- 异步编程复杂度:NIOFS需要配合事件循环、回调机制或异步框架(如Java的
CompletionService
)使用,代码逻辑较传统阻塞方式更复杂。 - 底层限制:实际性能受限于物理文件系统的特性(如机械硬盘的寻道延迟难以通过NIO完全规避),固态存储(SSD)可更好发挥NIO优势。
NIOFS的本质是通过软件层面的设计(非阻塞API)优化文件操作的并发处理能力,而非特指某一种独立的物理文件系统,其核心价值在于提升应用层面对文件I/O的高效管理。
(2)什么是mmapfs(内存映射文件系统)
mmapfs并非独立的物理文件系统,而是一种通过 内存映射(Memory Mapping)技术 实现的文件操作机制。它将磁盘文件的内容直接映射到进程的虚拟地址空间,使应用程序能像访问内存一样读写文件,无需显式执行I/O系统调用(如read
/write
),从而大幅提升文件访问效率,尤其适用于大文件处理和高并发场景。
核心原理:内存映射技术(mmap)
-
系统调用实现
通过操作系统提供的mmap
系统调用(如Linux的mmap
、Windows的CreateFileMapping
),将文件的全部或部分内容映射到进程的虚拟内存地址空间。映射后,文件的逻辑结构与内存地址一一对应,对内存的修改会根据策略同步到磁盘文件(支持“写时复制”或实时同步)。 -
零拷贝(Zero-Copy)
传统文件I/O需在用户空间与内核空间之间多次拷贝数据(如read
→用户缓冲区→write
→内核缓冲区),而内存映射直接在内核空间完成文件与内存的映射,用户进程可直接操作内存地址,减少数据拷贝开销,提升I/O性能。
核心特点与优势
特性 | 说明 |
---|---|
访问方式 | 像操作内存一样读写文件(通过指针或内存地址),无需显式I/O系统调用。 |
性能优势 | - 减少用户态与内核态的上下文切换和数据拷贝,适合大文件随机访问(如数据库索引)。 - 支持多进程共享映射文件,实现高效的进程间通信(IPC)。 |
内存与文件同步 | - 私有映射(Private Mapping):修改内存不影响原文件(写时复制,Copy-on-Write)。 - 共享映射(Shared Mapping):修改内存会同步到文件,适合多进程数据共享。 |
适用场景 | - 大文件分块处理(如日志分析、视频处理)。 - 数据库系统(如MySQL的InnoDB缓冲池、Elasticsearch的mmap索引)。 - 高频次随机读写场景(避免 lseek +read 的低效组合)。 |
与传统文件I/O、内存文件系统的对比
-
vs 传统文件I/O(
read
/write
)- 传统方式:每次读写需系统调用,数据在用户空间与内核空间来回拷贝,适合小文件或顺序读写。
- mmapfs:通过内存地址直接操作,减少系统调用和数据拷贝,适合大文件随机读写,但需注意内存占用(映射文件大小受限于进程虚拟地址空间)。
-
vs 内存文件系统(如Linux的
tmpfs
)- tmpfs:完全基于内存的文件系统,数据不持久化到磁盘,适合临时文件存储。
- mmapfs:映射的是磁盘文件,数据会持久化,本质是优化文件访问方式,而非独立的文件系统。
典型应用与注意事项
应用示例
- 编程语言支持:Java的
MappedByteBuffer
、C的mmap
函数、Python的mmap
模块均提供内存映射文件接口。 - 数据库场景:MySQL使用内存映射读取数据文件,Elasticsearch通过mmap映射Lucene索引文件以加速检索。
- 日志处理:实时分析大日志文件时,通过内存映射避免逐行读取的I/O开销。
注意事项
- 内存占用:映射大文件可能消耗大量内存,需避免内存溢出(可通过
PROT_READ
等标志限制访问权限)。 - 同步策略:依赖操作系统的
msync
或munmap
控制数据落盘,需注意数据一致性(如异常断电可能导致未同步数据丢失)。 - 边界限制:映射区域需与文件大小对齐,访问越界可能导致段错误(Segmentation Fault)。
- 操作系统差异:不同系统对mmap的实现和限制不同(如Linux的
MAP_SHARED
/MAP_PRIVATE
标志,Windows的文件映射对象)。
相关文章:
ElasticSearch深入解析(六):集群核心配置
1.开发模式和生产模式 Elasticsearch默认运行在开发模式下,此模式允许节点在配置存在错误时照常启动,仅将警告信息写入日志文件。而生产模式则更为严格,一旦检测到配置错误,节点将无法启动,这是一种保障系统稳定性的安…...
Python 重构“策略”模式:用函数简化设计模式的实践
在软件设计中,设计模式是解决问题的通用模板。但随着编程语言特性的发展,某些经典模式可以通过更简洁的方式实现。本文以电商促销折扣场景为例,演示如何通过函数重构“策略”模式,减少代码量并提升可维护性。 经典策略模式实现 …...
MCP协议深度解析:原理、应用与物联网时代的机遇-优雅草卓伊凡
MCP协议深度解析:原理、应用与物联网时代的机遇-优雅草卓伊凡 一、MCP协议技术详解 1.1 MCP协议的定义与起源 MCP(Modbus Communication Protocol)是一种基于主从架构的串行通信协议,最初由Modicon公司(现为施耐德电…...
IOS 国际化词条 Python3 脚本
一、词条处理脚本---使用教程 (1)环境篇 1: 该脚本基于python3 环境,请确保你的mac 安装了python3 2: 包依赖,请在python3环境下安装 xlrd; pip3 install xlrd(2)使用篇 1: 桌面创建一个文件夹, 例如 wordEntry,将该脚本文件与下载的最新的 ’词条.xlsx‘…...
uniapp 支付宝小程序自定义 navbar 无效解决方案
如图: uniapp编译到支付宝小程序隐藏默认的导航栏失效了 解决方案: 在 pages.json 文件中找到 globalStyle 中加入以下代码: "mp-alipay": {"transparentTitle": "always","titlePenetrate":…...
uni-app - 微信小程序中,使用 navigateTo 传递非常大的数字传参精度丢失的问题
文章目录 🍉原因分析:JavaScript 数值精度限制🍉常用解决方法🍉代码示例🍉官方推荐与最佳实践🍉微信小程序环境注意事项🍉原因分析:JavaScript 数值精度限制 微信小程序(uni-app)中,参数是通过 URL 查询字符串传递的,其本质上仍由 JavaScript 进行处理。Jav…...
通信施工安全员B证适合哪些人考
通信施工安全员B证适合人群分析 一、适用岗位范围 通信工程施工人员 从事基站建设、光缆布放、管道施工等现场作业的技术工人 5G网络建设、室内分布系统安装等新型基础设施建设人员 项目管理岗位 通信工程项目经理、技术负责人 施工队长、班组长等现场管理人员 专职安全…...
vue3使用<el-date-picker分别设置开始时间和结束时间时,设置开始时间晚于当前时间,开始时间早于结束时间,结束时间晚于开始时间
vue3使用<el-date-picker分别设置开始时间和结束时间时,设置开始时间晚于当前时间,开始时间早于结束时间,结束时间晚于开始时间 为避免出现填写结束事件后再次修改开始时间,导致开始时间晚于结束时间,添加 change“…...
移远通信LG69T赋能零跑B10:高精度定位护航,共赴汽车智联未来
当前,汽车行业正以前所未有的速度迈向智能化时代,组合辅助驾驶技术已然成为车厂突出重围的关键所在。高精度定位技术作为实现车辆精准感知与高效协同的基石,其重要性日益凸显。 作为全球领先的物联网及车联网整体解决方案供应商,移…...
HTML应用指南:利用POST请求获取全国达美乐门店位置信息
达美乐比萨作为全球知名的披萨连锁品牌,自1960年创立以来,始终致力于为消费者提供高品质、快速配送的披萨体验。在中国市场,达美乐凭借其“30分钟必达”的承诺和经典美式风味,逐渐赢得了广大消费者的青睐。品牌通过不断拓展门店网…...
进程优先级以及切换调度
目录 进程优先级 基本概念 实操理解 优先级操作 竞争,独立,并行,并发 进程切换 寄存器 讲切换 linux进程调度算法 进程优先级 基本概念 cpu资源分配的先后顺序,就是指进程的优先权(priority)。优…...
揭开应用程序的神秘面纱:深入了解 AWS X-Ray
1.AWS X-Ray 概述: AWS X-Ray 是一项服务,它收集应用程序所处理请求的数据,并提供一些工具供您查看、筛选和深入了解这些数据,从而发现问题和优化机会。您不仅可以查看请求和响应的详细信息,还可以查看应用程序对下游…...
元宇宙2.0:当区块链成为数字世界的宪法
引言:当虚拟世界成为“新大陆” 清晨,你戴上VR设备进入一个由数字建筑构成的城市,这里的地皮属于全球玩家,街边的艺术品标着NFT认证码,咖啡馆里的人们用加密货币支付咖啡,而社区规则由持有代币的居民投票决…...
JVM调优实战(JVM Tuning Pactice)
JVM调优实战 JVM调优 JVM调优是指对Java虚拟机进行性能优化的实际应用。 JVM调优实战主要是通过优化JVM的内存管理、垃圾回收、线程管理、类加载、编译器等方面来提高Java应用程序的性能和稳定性。 JVM调优步骤 JVM调优实战通常需要经过以下步骤: 1.监控GC的状…...
网络原理 - 11(HTTP/HTTPS - 2 - 请求)
目录 HTTP 请求(Request) 认识 URL URL 基本格式 关于 URL encode 认识方法(method) 1. GET 方法 2. POST 方法 认识请求“报头”(header) Host Content-Length Content-Type User-Agent&…...
百度CarLife实现手机车机无缝互联
百度CarLife是百度推出的智能车联网解决方案,通过手机与车机互联技术,为用户提供安全便捷的车载互联网服务体验。 CarLife 实现手机与车机屏幕的无缝互联,让应用内容同步至车载系统,减少驾驶过程中操作手机的频率,提升…...
初识Redis · 缓存
目录 前言: 引入缓存 缓存更新策略 定期生成 实时生成 缓存注意事项 缓存预热 缓存穿透 缓存雪崩 缓存击穿 前言: 我们在Redis的学习中,逐渐了解到了Redis的用途是可以用来当作内存数据库,缓存,消息队列等&…...
Redis性能优化终极指南:从原理到实战的深度调优策略
一、内存优化:构建高效存储体系 1.1 三级过期键管理机制 Redis通过组合策略实现精准的内存回收: 定时删除(主动淘汰) 创建定时器在键到期时立即删除 优点:及时释放内存 缺点:高CPU消耗(每个…...
哈希表笔记(一 )
设计思路 核心功能和 API 设计 (Core Functionality & API Design): 基本操作: 必须提供核心的 put(key, value)(添加或更新键值对)、get(key)(根据键获取值)、remove(key)(根据键删除键值对)、contain…...
c网络库libevent的http常用函数的使用(附带源码)
Libevent HTTP 核心函数详解与实战 核心概念HTTP 服务器端常用函数1. 初始化与绑定2. 设置请求处理回调3. 在回调函数中处理请求4. 发送响应5. 启动与停止6. 清理资源 HTTP 客户端常用函数1. 初始化2. 创建连接3. 创建并发送请求4. 在回调函数中处理响应5. 启动事件循环与清理 …...
java练习3
随机生成20个数字(随机种子) 分别使用冒泡排序、二叉树排序、插入排序进行排序 并输出最终结果以及三种排序使用的时间 package a01_第一次练习.a03_排序;import java.time.Duration; import java.time.LocalDateTime; import java.util.TreeSet;publi…...
当 AI 成为 “数字新物种”:人类职业的重构与进化
一、AI 的 “替代清单”:从流水线到办公室的全面侵袭 在深圳某智能工厂,机械臂正以 0.01 毫米的精度完成手机组装,100 台机器人 24 小时运转,替代了 3000 名工人。这种场景正在全球制造业蔓延 —— 麦肯锡预测,到 203…...
HarmonyOS ArkUI交互事件与手势处理全解析:从基础到高级实践
文章目录 一、交互事件1.1 通用事件1.1.1 事件分发1.1.1.1 触摸测试1. 触摸测试基本流程2. 触摸测试控制3. 自定义事件拦截4. 禁用控制5. 触摸热区设置6. 安全组件 1.1.1.2 事件响应链收集 1.1.2 触屏事件1.1.3 键鼠事件1.1.3.1 鼠标事件1.1.3.2 按键事件 1.1.4 焦点事件1.1.5 …...
【计算机网络】面试常考——GET 和 POST 的区别
GET 和 POST 的区别 GET 和 POST 是 HTTP 协议中最常用的两种请求方法,它们的主要区别体现在 用途、数据传输方式、安全性、缓存机制 等方面。以下是详细对比: 1. 用途 GET POST 主要用于 获取数据(如查询、搜索)。 主要用于 提…...
AI编程工具“幻觉”风险与飞算JavaAl的破局之道
近年来,AI编程辅助工具迅速崛起,极大地提升了开发者的工作效率。然而,这些工具普遍存在一个被称为“幻觉”(hallucination)的风险——AI可能会生成看似合理但实际错误、不安全或低效的代码。这种现象在复杂业务逻辑和特定领域开发中尤为明显&…...
【Python零基础入门系列】第1篇:Python 是什么?怎么装环境?推荐哪些 IDE?
各位网友们,欢迎来到我的 Python 学习专栏! 前两天看到新闻英伟达为 CUDA 添加原生 Python 支持,意味着开发者可直接用 Python 操作 GPU,加速 AI 和高性能计算,降低门槛,让 Python 的应用范围更广、能力更强。 一直想写一系列文章教知友们从零开始学会 Python 编程,目…...
VPN访问SAP组服务器报登陆负载均衡错误88:无法连接到消息服务器(RC=9)
用户反馈用SAPGUI接入SAP时报错:登陆负载均衡错误88:无法连接到消息服务器(RC9) 经了解是通过VPN访问,但VPN没有放行ICMP访问,导致不能PING通,不能确认是网络问题还是什么问题。 解决方案: 1、VPN由原&am…...
Linux查看程序端口占用情况
大家好,欢迎来到程序视点!我是你们的老朋友.小二! 核心问题: Tomcat 8080端口启动失败,提示端口被占用,但常规检查未发现Tomcat进程占用该端口。 关键排查步骤: 初步检查 使用 ps -aux | gre…...
[C]基础14.字符函数和字符串函数
博客主页:向不悔本篇专栏:[C]您的支持,是我的创作动力。 文章目录 0、总结1、字符分类、转换函数2、strlen的使用和模拟实现2.1 strlen的使用2.2 strlen的模拟实现 3、strcpy的使用和模拟实现3.1 strcpy的使用3.2 strcpy的模拟实现 4、strcat…...
三种机器学习类型
本文讲介绍三种机器学习类型:①监督学习,②无监督学习,③强化学习。我们主要了解监督学习和无监督学习即可。 下图介绍这三种机器学习类型的区别: 1 用来预测未来的监督学习 从有标签的训练数据中学习一个模型,用来…...
UE5 Set actor Location和 Set World Location 和 Set Relative Location 的区别
在 Unreal Engine 的蓝图里,SetRelativeLocation、SetWorldLocation 和 SetActorLocation 三个节点虽然都能改变物体位置,但作用对象和坐标空间(Coordinate Space)不同: 1. SetActorLocation 作用对象:整个…...
Glide 如何加载远程 Base64 图片
最近有个需求,后端给出的图片地址并不是正常的 URL,而且需要一个接口去请求,但是返回的是 base64 数据流。这里不关心为啥要这么多,原因有很多,可能是系统的问题,也可能是能力问题。当然作为我们 Android 程…...
JVM对象存储格式
引言 在Java虚拟机(JVM)中,对象的内存布局是一个重要的底层概念,它直接影响对象在内存中的存储方式和占用空间。了解对象存储格式不仅有助于优化程序性能,还能帮助我们更好地理解JVM的工作原理。本文将详细探讨对象存…...
3D Gaussian Splatting部分原理介绍和CUDA代码解读
本系列旨在帮助无CUDA代码经验的读者、以及3DGS的初学者理解代码逻辑。 3D GS论文原文链接:https://arxiv.org/abs/2308.04079 论文笔记链接:【论文笔记】3D Gaussian Splatting for Real-Time Radiance Field Rendering 【论文笔记】A Survey on 3D Ga…...
日本IT行业|salesforce开发语言占据的地位
在日本的IT行业中,Salesforce 开发语言处于一个较为专业但稳步增长的细分领域,并不是主流开发语言(如 Java、Python、PHP),但其在某些行业和场景中地位越来越重要。 本篇以下是详细分析: Salesforce开发语言…...
1.1 点云数据获取方式——引言
图1-1-1点云建筑场景图 点云数据是指能够描述外部场景、对象表面的三维空间位置,并具有相关属性的点集,其每个离散点通常包括三维空间位置(x,y,z)以及强度、颜色等属性信息。大量分布的离散点集能够清晰而直接地描绘场景、对象的3…...
接入层架构演变
1、单体架构 请求过程 浏览器的请求通过 DNS Server 解析到指定的 IP 地址,浏览器通过 IP 地址访问 Web Server 缺点 当到达 Web Server 的性能瓶颈时(瓶颈受到CPU,内存,io,带宽影响),无法进…...
python:sklearn 主成分分析(PCA)
参考书:《统计学习方法》第2版 第16章 主成分分析(PCA)示例 编写 test_pca_1.py 如下 # -*- coding: utf-8 -*- """ 主成分分析(PCA) """ import matplotlib.pyplot as plt from skl…...
力扣-数据结构-二叉树
94. 二叉树的中序遍历 给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。 示例 1: 输入:root [1,null,2,3] 输出:[1,3,2]示例 2: 输入:root [] 输出:[]示例 3: 输入&#x…...
嵌入式音视频实时通话EasyRTC打造设备安装与调试的高效远程解决方案
一、背景 在数字化浪潮席卷全球的今天,实时音视频通信技术已经成为众多领域不可或缺的重要组成部分。从智能家居到智能安防,从在线教育到远程医疗,人们对于高效、便捷、稳定且低延迟的音视频通信解决方案的需求日益迫切。而EasyRTC作为一款卓…...
AI 的未来是开源?DeepSeek 正在书写新篇章!
AI 的未来是开源?DeepSeek 正在书写新篇章! 随着人工智能(AI)技术的迅猛发展,越来越多的企业和研究机构开始关注 AI 的开放性和透明度。开源不仅能够促进技术创新,还能加速知识的传播和应用。在这个背景下…...
抢先体验全新极小大模型Qwen3:0.6B
全民都在期待DeepSeek-R2的发布,但是一不小心被阿里截胡了,2025 年 4 月 29 日,阿里巴巴发布并开源了通义千问 Qwen3 系列大模型。据 大模型镜像网站 上关于Qwen3的介绍: Qwen3 是 Qwen 系列中最新一代的大型语言模型,提供一整套密集模型和混合专家 (MoE) 模型。Qwen3 基…...
部署一个自己的Spring Ai 服务(deepseek/通义千问)
Spring Boot 无缝接入 DeepSeek 和通义千问请求日志记录及其ip黑白名单 SpringBoot版本 3.2.0 JDK 版本为17 redis 3.2.0 mybatis 3.0.3 依赖引入 关键依赖 <dependency><groupId>org.springframework.ai</groupId><artifactId>spring-ai-openai-sp…...
第一讲 | 算法复杂度
算法复杂度 一、数据结构前言1、数据结构(DS)2、算法(Algorithm) 二、算法效率1、复杂度的概念 三、时间复杂度(1)、案例(2)、大O的渐进表示法(3)、时间复杂度…...
【运维】还原 Docker 启动命令的利器:runlike 与 docker-autocompose
🔍 还原 Docker 启动命令的利器:runlike 与 docker-autocompose 实用教程 在日常使用 Docker 时,我们常常通过 docker run 启动容器,但有时候过了一段时间就忘记了当初使用的具体参数(端口、挂载、环境变量等…...
IP属地是实时位置还是自己设置
刷微博、抖音时,评论区总能看到“IP属地”?这个突然冒出来的小标签,让不少网友摸不着头脑:IP属地是实时位置,还是可以自己设置?别急,今天咱们就来聊聊这个话题! 1、什么是IP属地…...
Android WIFI体系
先说说WifiLock、MulticastLock 、IWificond WifiLock 允许应用强制保持 WiFi 活跃,即便设备处于休眠状态。如WIFI_MODE_FULL_HIGH_PERF:保持高性能 WiFi 活跃状态,适用于高带宽需求,如视频通话、流媒体。经测试有的场景能减少10…...
什么是静态住宅ip,跨境电商为什么要用静态住宅ip
在数字时代,IP地址不仅是设备联网的“ID”,更是跨境电商运营中的关键工具。尤其对于需要长期稳定、安全操作的场景,静态住宅IP逐渐成为行业首选。 一、什么是静态住宅IP? 静态住宅IP(Static Residential IP࿰…...
常见位运算总结
目录 常见位运算总结 191:位1的个数 338:比特位计数 461:汉明距离 136:只出现一次的数字 260:只出现一次的数字III 常见位运算总结 191:位1的个数 链接:191. 位1的个数 - 力扣(LeetCode) class Sol…...
[密码学实战]SDF之对称运算类函数(四)
[密码学实战]SDF之对称运算类函数(四) 一、标准解读:GM/T 0018-2023核心要求 1.1 SDF接口定位 安全边界:硬件密码设备与应用系统间的标准交互层 功能范畴: #mermaid-svg-1jptduZFNFiRZ2lS {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16…...