[{"data":1,"prerenderedAt":3668},["ShallowReactive",2],{"search-docs":3,"doc-\u002Finterview\u002Fmysql":886},[4,8,12,16,20,24,28,32,36,40,44,48,52,56,60,64,68,72,76,80,84,88,92,96,100,104,108,112,116,120,124,128,132,136,140,144,148,152,156,159,162,165,169,172,175,178,182,186,190,194,198,202,206,210,214,218,222,226,230,234,238,242,246,250,254,258,262,266,269,273,277,281,285,288,291,294,298,301,304,307,310,313,316,319,322,325,329,332,336,340,344,348,352,356,359,362,365,368,371,374,377,380,383,386,389,393,396,399,402,405,408,411,414,417,420,424,428,432,435,438,442,446,450,454,458,462,466,470,474,477,480,483,487,491,494,497,500,504,507,511,515,518,521,524,527,530,533,536,539,542,545,548,551,554,557,560,563,566,569,572,575,579,583,587,591,595,599,603,606,610,614,617,620,623,626,629,633,637,640,643,646,649,652,655,658,661,664,667,670,673,676,679,682,685,688,691,694,697,700,703,706,709,712,716,720,724,728,732,736,740,744,748,752,756,760,764,768,772,775,779,783,787,790,793,796,799,802,805,808,811,814,818,822,825,829,832,835,838,841,844,848,851,854,858,862,865,869,873,876,879,882],{"path":5,"title":6,"description":7},"\u002Fabout\u002Fauthor","作者相关","只想纯粹的做一个程序员...",{"path":9,"title":10,"description":11},"\u002Fabout\u002Fjourney","心路历程","",{"path":13,"title":14,"description":15},"\u002Fai\u002Fagent\u002Fframeworks","Agent 框架","主流 Agent 框架：LangChain、LlamaIndex、AutoGen、CrewAI",{"path":17,"title":18,"description":19},"\u002Fai\u002Fagent\u002Fhooks","Agent Hooks 与自动化","Claude Agent 的 Hooks 生命周期、事件类型、典型自动化场景",{"path":21,"title":22,"description":23},"\u002Fai\u002Fagent\u002Fintroduction","AI Agent 概述","AI Agent 核心概念：感知、规划、执行、记忆",{"path":25,"title":26,"description":27},"\u002Fai\u002Fagent\u002Fpractice","Agent 实战","AI Agent 实战：构建自主任务执行系统",{"path":29,"title":30,"description":31},"\u002Fai\u002Fagent\u002Fsdk","Claude Agent SDK 开发","使用 Claude Agent SDK 构建自定义 AI Agent：架构、API、生命周期",{"path":33,"title":34,"description":35},"\u002Fai\u002Fagent\u002Fsubagents","Subagents 子代理","用 Subagents 分解复杂任务、并发执行、隔离上下文",{"path":37,"title":38,"description":39},"\u002Fai\u002Fagent\u002Ftool-use","工具调用","AI Agent 工具调用：Function Calling、Tool Use 原理与实践",{"path":41,"title":42,"description":43},"\u002Fai\u002Ffundamentals\u002Fdeep-learning","深度学习入门","深度学习基础知识：前向传播、反向传播、损失函数、优化器",{"path":45,"title":46,"description":47},"\u002Fai\u002Ffundamentals\u002Fml-basics","机器学习基础","机器学习核心概念：监督学习、无监督学习、强化学习",{"path":49,"title":50,"description":51},"\u002Fai\u002Ffundamentals\u002Fneural-networks","神经网络原理","神经网络架构：CNN、RNN、注意力机制",{"path":53,"title":54,"description":55},"\u002Fai\u002Fgetting-started","AI 学习路线","AI 技术学习路线图，从基础到实战的完整指南",{"path":57,"title":58,"description":59},"\u002Fai\u002Fllm\u002Ffine-tuning","模型微调","大模型微调技术：LoRA、QLoRA、全量微调、RLHF",{"path":61,"title":62,"description":63},"\u002Fai\u002Fllm\u002Fintroduction","大模型概述","大语言模型发展历程、核心能力与主流模型对比",{"path":65,"title":66,"description":67},"\u002Fai\u002Fllm\u002Flocal-deploy","本地部署","大模型本地部署：Ollama、vLLM、llama.cpp",{"path":69,"title":70,"description":71},"\u002Fai\u002Fllm\u002Ftransformer","Transformer 架构","Transformer 架构详解：自注意力机制、位置编码、多头注意力",{"path":73,"title":74,"description":75},"\u002Fai\u002Fmcp\u002Fclient","MCP Client 开发","MCP Client 开发指南：连接、调用、集成",{"path":77,"title":78,"description":79},"\u002Fai\u002Fmcp\u002Fdebugging","MCP 调试与排错","MCP Server 开发与集成过程中的常见问题、日志分析、诊断工具",{"path":81,"title":82,"description":83},"\u002Fai\u002Fmcp\u002Fintroduction","MCP 概述","Model Context Protocol 协议概述：架构、核心概念、应用场景",{"path":85,"title":86,"description":87},"\u002Fai\u002Fmcp\u002Fserver","MCP Server 开发","MCP Server 开发指南：资源、工具、提示词的实现",{"path":89,"title":90,"description":91},"\u002Fai\u002Fmcp\u002Ftools","MCP Tools 深入","深入理解 MCP Tools：与 Resources\u002FPrompts 的差异、Schema 设计、Annotations 与权限控制",{"path":93,"title":94,"description":95},"\u002Fai\u002Fprompt\u002Fadvanced","高级 Prompt 模式","高级 Prompt 设计模式：Tree-of-Thought、自我反思、多轮对话策略",{"path":97,"title":98,"description":99},"\u002Fai\u002Fprompt\u002Fbasics","Prompt 基础","Prompt Engineering 入门：基本概念、角色设定、输出格式控制",{"path":101,"title":102,"description":103},"\u002Fai\u002Fprompt\u002Ftechniques","提示词技巧","常用提示词技巧：Few-shot、Chain-of-Thought、ReAct",{"path":105,"title":106,"description":107},"\u002Fai\u002Frag\u002Fembedding","文本嵌入","文本嵌入模型：Embedding 原理、模型选择、相似度计算",{"path":109,"title":110,"description":111},"\u002Fai\u002Frag\u002Fintroduction","RAG 概述","检索增强生成（RAG）架构原理、优势与应用场景",{"path":113,"title":114,"description":115},"\u002Fai\u002Frag\u002Fpractice","RAG 实战","RAG 应用实战：文档问答系统、知识库搭建",{"path":117,"title":118,"description":119},"\u002Fai\u002Frag\u002Fvector-database","向量数据库","主流向量数据库对比：Milvus、Pinecone、Chroma、Weaviate",{"path":121,"title":122,"description":123},"\u002Fai\u002Fskills\u002Fbest-practices","Skill 最佳实践","编写高质量 Skill 的设计原则、常见陷阱与优化技巧",{"path":125,"title":126,"description":127},"\u002Fai\u002Fskills\u002Fcreating","创建自定义 Skill","从零编写一个可被 Agent 自动发现和调用的 Skill",{"path":129,"title":130,"description":131},"\u002Fai\u002Fskills\u002Fintroduction","Agent Skills 概述","Claude Agent Skills 概念、工作原理、与 Tools\u002FMCP 的区别",{"path":133,"title":134,"description":135},"\u002Fgolang\u002Fadvanced\u002Fconcurrency","Go - 并发深入","深入理解 Go 并发编程的核心机制。",{"path":137,"title":138,"description":139},"\u002Fgolang\u002Fadvanced\u002Fgc","Go - 垃圾回收","理解 Go 的垃圾回收机制，掌握 GC 调优方法。",{"path":141,"title":142,"description":143},"\u002Fgolang\u002Fadvanced\u002Fgmp","Go - GMP 调度模型","GMP 是 Go 运行时调度器的核心模型，理解它对于编写高性能 Go 程序至关重要。",{"path":145,"title":146,"description":147},"\u002Fgolang\u002Fadvanced\u002Fgo-concurrency","Go - 并发编程","Go 的并发是其核心特性之一，通过 Goroutine 和 Channel 实现。",{"path":149,"title":150,"description":151},"\u002Fgolang\u002Fadvanced\u002Fmemory","Go - 内存模型","理解 Go 的内存分配机制和内存模型。",{"path":153,"title":154,"description":155},"\u002Fgolang\u002Fadvanced\u002Fprofiling","Go - 性能分析","掌握 Go 的性能分析工具：pprof、trace、benchmark。",{"path":157,"title":158,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-basic","Go - 基础语法",{"path":160,"title":161,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-composite","Go - 复合类型",{"path":163,"title":164,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-control","Go - 流程控制",{"path":166,"title":167,"description":168},"\u002Fgolang\u002Fcore\u002Fgo-error","Go - 错误处理","Go 使用显式的错误返回值来处理错误，而不是异常机制。",{"path":170,"title":171,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-function","Go - 函数",{"path":173,"title":174,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-install","Go - 环境搭建",{"path":176,"title":177,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-interface","Go - 接口",{"path":179,"title":180,"description":181},"\u002Fgolang\u002Fcore\u002Fgo-module","Go - 包管理","Go Modules 是 Go 1.11 引入的官方依赖管理方案，Go 1.16 后成为默认模式。",{"path":183,"title":184,"description":185},"\u002Fgolang\u002Fdistributed\u002Fgrpc","Go - gRPC","gRPC 是 Google 开发的高性能 RPC 框架，使用 Protocol Buffers 作为序列化协议。",{"path":187,"title":188,"description":189},"\u002Fgolang\u002Fdistributed\u002Fmicroservice","Go - 微服务","微服务架构的核心组件：服务发现、负载均衡、熔断降级。",{"path":191,"title":192,"description":193},"\u002Fgolang\u002Fdistributed\u002Fmq","Go - 消息队列","使用 Go 操作 Kafka 和 RabbitMQ。",{"path":195,"title":196,"description":197},"\u002Fgolang\u002Fdistributed\u002Fredis","Go - Redis","使用 go-redis 操作 Redis，实现缓存、分布式锁等功能。",{"path":199,"title":200,"description":201},"\u002Fgolang\u002Fengineering\u002Fconfig","Go - 配置管理","使用 viper 进行配置管理，支持多种配置格式和配置中心。",{"path":203,"title":204,"description":205},"\u002Fgolang\u002Fengineering\u002Fdocker","Go - Docker 部署","使用 Docker 容器化部署 Go 应用。",{"path":207,"title":208,"description":209},"\u002Fgolang\u002Fengineering\u002Fkubernetes","Go - Kubernetes 部署","在 Kubernetes 上部署和管理 Go 应用。",{"path":211,"title":212,"description":213},"\u002Fgolang\u002Fengineering\u002Flogging","Go - 日志系统","使用 zap 和 logrus 构建高性能结构化日志系统。",{"path":215,"title":216,"description":217},"\u002Fgolang\u002Fengineering\u002Ftesting","Go - 单元测试","Go 内置了强大的测试框架，掌握测试是编写高质量代码的基础。",{"path":219,"title":220,"description":221},"\u002Fgolang\u002Fstdlib\u002Fbufio","bufio","在 Go 语言中，bufio 包提供了带缓冲的 I\u002FO 操作，能够提高读写性能。以下是一些常用的 bufio 包 API 及其详细说明：",{"path":223,"title":224,"description":225},"\u002Fgolang\u002Fstdlib\u002Fcontainer","container","在Go语言标准库中，container 包提供了几种常用的数据结构实现，这些数据结构对于高效地管理和操作数据非常有用。以下是 container 包中主要的数据结构：",{"path":227,"title":228,"description":229},"\u002Fgolang\u002Fstdlib\u002Fcrypto","crypto","在 Go 语言中，crypto 包提供了一组用于加密和解密的功能。以下是一些常用的 crypto 包及其子包的 API 及其详细说明：",{"path":231,"title":232,"description":233},"\u002Fgolang\u002Fstdlib\u002Fencoding-csv","encoding\u002Fcsv","在 Go 语言中，encoding\u002Fcsv 包提供了对 CSV（逗号分隔值）文件进行读写的功能。以下是一些常用的 encoding\u002Fcsv 包的 API 及其详细说明：",{"path":235,"title":236,"description":237},"\u002Fgolang\u002Fstdlib\u002Fencoding-json","encoding\u002Fjson","在 Go 语言中，encoding\u002Fjson 包提供了对 JSON 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fjson 包的 API 及其详细说明：",{"path":239,"title":240,"description":241},"\u002Fgolang\u002Fstdlib\u002Fencoding-xml","encoding\u002Fxml","在 Go 语言中，encoding\u002Fxml 包提供了对 XML 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fxml 包的 API 及其详细说明：",{"path":243,"title":244,"description":245},"\u002Fgolang\u002Fstdlib\u002Fflag","flag","在Go语言中，flag 包是用于处理命令行参数的标准库，它提供了一种简单而直接的方式来解析和使用命令行参数。下面是关于 flag 包的一些基本介绍和常用功能：",{"path":247,"title":248,"description":249},"\u002Fgolang\u002Fstdlib\u002Ffmt","fmt","在 Go 语言的标准库中，fmt 包是非常重要的，它提供了处理格式化输入和输出的基本工具。以下是一些 fmt 包内常用的API：",{"path":251,"title":252,"description":253},"\u002Fgolang\u002Fstdlib\u002Fhttp","net\u002Fhttp","在 Go 语言中，net\u002Fhttp 包提供了用于构建 HTTP 客户端和服务器的强大工具。以下是一些常用的 net\u002Fhttp 包的 API 及其详细说明：",{"path":255,"title":256,"description":257},"\u002Fgolang\u002Fstdlib\u002Fio","io","在 Go 语言中，io 包提供了基本的输入输出功能。以下是一些常用的 io 包的 API 及其详细说明：",{"path":259,"title":260,"description":261},"\u002Fgolang\u002Fstdlib\u002Flog","log","在 Go 语言中，log 包提供了简单的日志记录功能。以下是一些常用的 log 包的 API 及其详细说明：",{"path":263,"title":264,"description":265},"\u002Fgolang\u002Fstdlib\u002Fmath","math","在 Go 语言中，math 包提供了基本的数学函数和常量。以下是一些常用的 math 包的 API 及其详细说明：",{"path":267,"title":268,"description":11},"\u002Fgolang\u002Fstdlib\u002Fnet","net",{"path":270,"title":271,"description":272},"\u002Fgolang\u002Fstdlib\u002Fos","os","在Go语言中，os 包是一个非常重要且常用的标准库，它提供了与操作系统交互的功能，包括文件操作、环境变量管理、进程管理等。下面是一些 os 包中常用的功能和API：",{"path":274,"title":275,"description":276},"\u002Fgolang\u002Fstdlib\u002Fsort","order","在 Go 语言中，sort 包提供了对切片和用户定义的集合进行排序的函数。它实现了常见的排序算法，如快速排序（Quicksort）和堆排序（Heapsort），并且为自定义集合提供了接口，使得用户可以根据特定的需求进行排序。",{"path":278,"title":279,"description":280},"\u002Fgolang\u002Fstdlib\u002Fstrconv","strconv","在 Go 语言中，strconv 包提供了字符串和基本数据类型之间的转换函数，例如将整数转换为字符串、字符串转换为整数，以及其他类型之间的转换。这些功能非常有用，特别是在处理用户输入或从外部数据源读取数据时。",{"path":282,"title":283,"description":284},"\u002Fgolang\u002Fstdlib\u002Ftime","time","在 Go 语言中，time 包提供了处理时间和日期的功能。以下是一些常用的 time 包的 API 及其详细说明：",{"path":286,"title":287,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ferror","Gin - 错误处理",{"path":289,"title":290,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ffile","Gin - 文件处理",{"path":292,"title":293,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fmiddleware","Gin - 中间件",{"path":295,"title":296,"description":297},"\u002Fgolang\u002Fweb\u002Fgin\u002Fquickstart","Gin - 快速开始","Gin 是目前最流行的 Go Web 框架，以高性能和简洁 API 著称。",{"path":299,"title":300,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frequest","Gin - 请求处理",{"path":302,"title":303,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fresponse","Gin - 响应处理",{"path":305,"title":306,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frouter","Gin - 路由",{"path":308,"title":309,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fvalidation","Gin - 参数校验",{"path":311,"title":312,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fassociation","GORM - 关联关系",{"path":314,"title":315,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fcrud","GORM - CRUD 操作",{"path":317,"title":318,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fmodel","GORM - 模型定义",{"path":320,"title":321,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fperformance","GORM - 日志与性能",{"path":323,"title":324,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquery","GORM - 高级查询",{"path":326,"title":327,"description":328},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquickstart","GORM - 快速开始","GORM 是 Go 语言最流行的 ORM 库，功能强大，使用简单。",{"path":330,"title":331,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Ftransaction","GORM - 事务与 Hook",{"path":333,"title":334,"description":335},"\u002Finterview\u002Fbasic","计算机基础面经","本章节汇总了面试中常见的通用技术概念，不局限于特定语言或数据库，是考察技术内功的关键考点。",{"path":337,"title":338,"description":339},"\u002Finterview\u002Fgolang","Golang 面试题","Go 语言面试高频考点，覆盖基础语法、数据结构、并发编程、内存管理、GC、调度器等核心知识。",{"path":341,"title":342,"description":343},"\u002Finterview\u002Fk8s","Kubernetes 面试题","Kubernetes（K8s）面试高频考点，覆盖架构原理、核心资源、网络存储、调度策略、运维监控等核心知识。",{"path":345,"title":346,"description":347},"\u002Finterview\u002Fmysql","MySQL 面试题","MySQL 数据库面试高频考点，覆盖索引、事务、锁、优化、主从复制等核心知识。",{"path":349,"title":350,"description":351},"\u002Finterview\u002Fredis","Redis 面试题","Redis 面试高频考点，覆盖数据结构、持久化、集群、缓存一致性、性能优化等核心知识。",{"path":353,"title":354,"description":355},"\u002Finterview\u002Frocketmq","RocketMQ 面试题","RocketMQ 面试高频考点，覆盖消息模型、可靠性、顺序消息、事务消息、存储与高可用等核心知识。",{"path":357,"title":358,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-arraylist","List - ArrayList 源码解析",{"path":360,"title":361,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-linkedlist","List - LinkedList 源码解析",{"path":363,"title":364,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-stack","List - Satck源码解析",{"path":366,"title":367,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-vectore","List - Vector 源码解析",{"path":369,"title":370,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-hashmap","Map - HashMap 源码解析",{"path":372,"title":373,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-linkedhashmap","Map - LinkedHashMap 源码解析",{"path":375,"title":376,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-treemap","Map - TreeMap 源码解析",{"path":378,"title":379,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-deque","Queue - Deque 接口解析",{"path":381,"title":382,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-queue","Queue - Queue 接口解析",{"path":384,"title":385,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-hashset","Set - HashSet源码解析",{"path":387,"title":388,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-linkedhashset","Set - LinkedHashSet 源码解析",{"path":390,"title":391,"description":392},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-treeset","Set - TreeSet源码解析","TreeSet 是一个 Set 集合接口的实现类，与 HashSet 类似，其底层也是通过维护了一个 TreeMap 对象来封装了一些实现方法，故本篇不再对 TreeSet 的底层原理进行详细说明，仅对常用 API 做简单介绍，如需了解 TreeMap 的底层实现原理，请移步 Map - HashMap 源码解析",{"path":394,"title":395,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fannotation","Java核心 - 注解",{"path":397,"title":398,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fbasic-grammar","Java核心 - 基础语法",{"path":400,"title":401,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fclass-and-object","Java核心 - 面向对象",{"path":403,"title":404,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fcommon-classes","Java核心 - 常用类",{"path":406,"title":407,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fexception","Java核心 - 异常处理",{"path":409,"title":410,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fgenerics","Java核心 - 泛型",{"path":412,"title":413,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fjdk-env-path","Java核心 - 环境搭建",{"path":415,"title":416,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Freflection","Java核心 - 反射",{"path":418,"title":419,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fstring","Java核心 - String 字符串",{"path":421,"title":422,"description":423},"\u002Fother\u002Fjava\u002Fio\u002Fbuffer-stream","Java IO - 缓冲流","缓冲流是对基本流的包装，通过内置缓冲区减少系统调用次数，大幅提升读写效率。",{"path":425,"title":426,"description":427},"\u002Fother\u002Fjava\u002Fio\u002Fbyte-stream","Java IO - 字节流","字节流是 Java IO 中最基本的流类型，以字节（byte）为单位进行数据读写，可以处理任意类型的文件。",{"path":429,"title":430,"description":431},"\u002Fother\u002Fjava\u002Fio\u002Fchar-stream","Java IO - 字符流","字符流以字符为单位进行读写，专门用于处理文本文件。相比字节流，字符流能够正确处理字符编码，避免中文乱码问题。",{"path":433,"title":434,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Ffile","Java IO - File 类",{"path":436,"title":437,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Fio-stream-system","Java IO - IO流概述",{"path":439,"title":440,"description":441},"\u002Fother\u002Fjava\u002Fio\u002Fnio","Java IO - NIO","NIO（New IO）是 JDK 1.4 引入的新 IO 模型，提供了更高效的 IO 操作方式，支持非阻塞 IO 和多路复用。",{"path":443,"title":444,"description":445},"\u002Fother\u002Fjava\u002Fjvm\u002Fclass-loading","类加载机制","类加载机制是 JVM 将 .class 文件加载到内存，并对数据进行校验、转换解析和初始化，最终形成可被 JVM 直接使用的 Java 类型的过程。",{"path":447,"title":448,"description":449},"\u002Fother\u002Fjava\u002Fjvm\u002Fgarbage-collection","垃圾回收","垃圾回收（Garbage Collection，GC）是 JVM 自动管理内存的机制，负责回收不再使用的对象所占用的内存。",{"path":451,"title":452,"description":453},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-memory","JVM 内存结构","JVM 在执行 Java 程序时，会把它管理的内存划分为若干个不同的数据区域。这些区域有各自的用途、创建和销毁时间。",{"path":455,"title":456,"description":457},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-tuning","JVM 调优","JVM 调优是优化 Java 应用性能的重要手段，主要包括参数配置、性能监控和问题排查。",{"path":459,"title":460,"description":461},"\u002Fother\u002Fjava\u002Fthread\u002Fatomic","原子类","Java 原子类（Atomic Classes）提供了一种无锁的线程安全方式，基于 CAS（Compare-And-Swap）操作实现。",{"path":463,"title":464,"description":465},"\u002Fother\u002Fjava\u002Fthread\u002Fcompletable-future","CompletableFuture","CompletableFuture 是 JDK 8 引入的异步编程工具，实现了 Future 和 CompletionStage 接口，支持函数式编程和链式调用。",{"path":467,"title":468,"description":469},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-collections","并发集合","Java 并发包提供了多种线程安全的集合类，用于替代传统的同步集合（如 Collections.synchronizedList）。",{"path":471,"title":472,"description":473},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-utils","并发工具类","Java 并发包提供了多种实用的并发工具类，用于控制线程之间的协调与同步。",{"path":475,"title":476,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fsynchronized-lock","同步机制",{"path":478,"title":479,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-basic","线程基础",{"path":481,"title":482,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-pool","线程池",{"path":484,"title":485,"description":486},"\u002Fother\u002Fspring-series\u002Fspring\u002Fannotations-beans","Spring - 基于注解管理Bean","从 Java 5 开始，Java 增加了对注解（Annotation）的支持，它是代码中的一种特殊标记，可以在编译、类加载和运行时被读取，执行相应的处理。开发人员可以通过注解在不改变原有代码和逻辑的情况下，在源代码中嵌入补充信息。",{"path":488,"title":489,"description":490},"\u002Fother\u002Fspring-series\u002Fspring\u002Fimplement-ioc","Spring - 原理手写IoC","Spring 框架的 IOC 是基于 Java 反射机制实现的，在学习手写 IoC 之前，你需要具备一定的 Java 反射相关的知识，参考本站内的 Java 教程。",{"path":492,"title":493,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fintroduction-case","Spring - 入门案例",{"path":495,"title":496,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aop","Spring - 面向切面AOP",{"path":498,"title":499,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aot","Spring - AOT提前编译",{"path":501,"title":502,"description":503},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-data-validation","Spring - 数据校验","在开发中，我们经常遇到参数校验的需求，比如用户注册的时候，要校验用户名不能为空、用户名长度不超过20个字符、手机号是合法的手机号格式等等。如果使用普通方式，我们会把校验的代码和真正的业务处理逻辑耦合在一起，而且如果未来要新增一种校验逻辑也需要在修改多个地方。而spring validation允许通过注解的方式来定义对象校验规则，把校验和业务逻辑分离开，让代码编写更加方便。Spring Validation其实就是对Hibernate Validator进一步的封装，方便在Spring中使用。",{"path":505,"title":506,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-i18n","Spring - 国际化i18n",{"path":508,"title":509,"description":510},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-ioc","Spring - IOC容器","IoC 是 Inversion of Control 的简写，译为“控制反转”，它不是一门技术，而是一种设计思想，是一个重要的面向对象编程法则，能够指导我们如何设计出松耦合、更优良的程序。",{"path":512,"title":513,"description":514},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-junit","Spring - 单元测试JUnit","在之前的测试方法中，几乎都能看到以下的两行代码：",{"path":516,"title":517,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-resources","Spring - 资源操作",{"path":519,"title":520,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-summarize","Spring - Spring概述",{"path":522,"title":523,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-transaction","Spring - 事务",{"path":525,"title":526,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fxml-beans","Spring - 基于XML管理Bean",{"path":528,"title":529,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-config","SpringBoot - 配置详解",{"path":531,"title":532,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-data","SpringBoot - 数据访问",{"path":534,"title":535,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-quickstart","SpringBoot - 快速入门",{"path":537,"title":538,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-web","SpringBoot - Web 开发",{"path":540,"title":541,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-config","SpringCloud - 配置中心",{"path":543,"title":544,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-discovery","SpringCloud - 服务注册与发现",{"path":546,"title":547,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-feign","SpringCloud - 服务调用",{"path":549,"title":550,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-gateway","SpringCloud - 服务网关",{"path":552,"title":553,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-introduction","SpringCloud - 微服务概述",{"path":555,"title":556,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-sentinel","SpringCloud - 服务保护",{"path":558,"title":559,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-databind","SpringMVC - 数据绑定与转换",{"path":561,"title":562,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-exception","SpringMVC - 异常处理",{"path":564,"title":565,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-interceptor","SpringMVC - 拦截器",{"path":567,"title":568,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-introduction","SpringMVC - 简介与环境搭建",{"path":570,"title":571,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-request","SpringMVC - 请求处理",{"path":573,"title":574,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-response","SpringMVC - 响应处理",{"path":576,"title":577,"description":578},"\u002Fproject\u002Frocket-leaf\u002Farchitecture","项目架构","Rocket-Leaf 的目录结构、模块划分、数据流向，以及各层之间的依赖关系。",{"path":580,"title":581,"description":582},"\u002Fproject\u002Frocket-leaf\u002Fbackend-layers","后端分层设计","Rocket-Leaf 的 model \u002F rocketmq \u002F service 三层结构，以及服务之间的依赖关系与设计取舍。",{"path":584,"title":585,"description":586},"\u002Fproject\u002Frocket-leaf\u002Fclient-manager","RocketMQ 客户端管理器","AdminClientManager 的多客户端池、默认连接懒加载、自动重连重试的设计与实现。",{"path":588,"title":589,"description":590},"\u002Fproject\u002Frocket-leaf\u002Fencryption","连接信息加密存储","AES-256-GCM + SHA-256 字段级派生密钥的实现，以及如何在不破坏兼容性的前提下为历史明文数据做透明迁移。",{"path":592,"title":593,"description":594},"\u002Fproject\u002Frocket-leaf\u002Ffrontend","前端结构与类型绑定","React + Vite 目录组织、自动生成的 Wails 绑定、api 薄封装与自定义 hooks 的职责划分。",{"path":596,"title":597,"description":598},"\u002Fproject\u002Frocket-leaf","项目简介","Rocket-Leaf 是一款基于 Wails v3 构建的跨平台 RocketMQ 桌面管理客户端，Go 后端 + React 前端。本文档系列拆解它的架构与关键实现。",{"path":600,"title":601,"description":602},"\u002Fproject\u002Frocket-leaf\u002Fwails-v3","Wails v3 入门","Wails v3 的核心概念、Service 绑定机制，以及 Rocket-Leaf 是如何用它把 Go 后端和 React 前端打通的。",{"path":604,"title":605,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-basic","Docker - 入门基础",{"path":607,"title":608,"description":609},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-compose","Docker - Compose","在部署应用时，常常使用到不止一个容器，那么在部署容器的时候就需要一个一个进行部署，这样的部署过程也相对来说比较繁琐复杂，也容易出问题，那么有没有一种更为简单的方法呢？",{"path":611,"title":612,"description":613},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-container-connection","Docker - 容器互联","在上一个章节中我们学习了 Docker 容器的端口映射，可以将 Docker 容器和本地以及网络中的端口进行连接起来。",{"path":615,"title":616,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-dockerfile","Docker - Dockerfile",{"path":618,"title":619,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-helloworld","Docker - HelloWorld",{"path":621,"title":622,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-install","Docker - 安装",{"path":624,"title":625,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-introduce","Docker - 简介",{"path":627,"title":628,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-object","Docker - 镜像、容器、仓库",{"path":630,"title":631,"description":632},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-warehouse","Docker - 仓库管理","仓库是集中存放资源的地方，代码仓库是存放代码的，那么Docker 中的仓库就是存放 Docker 镜像的。",{"path":634,"title":635,"description":636},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-web-containers","Docker - WEB应用实例","在之前的章节中，仅对普通容器进行了演示，但在实际中常常使用到 Docker 容器中的 WEB 应用程序。",{"path":638,"title":639,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-config","Kubernetes - ConfigMap 与 Secret",{"path":641,"title":642,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-helm","Kubernetes - Helm 包管理",{"path":644,"title":645,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-install","Kubernetes - 集群安装",{"path":647,"title":648,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-introduction","Kubernetes - 简介与架构",{"path":650,"title":651,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-kubectl","Kubernetes - kubectl 命令行工具",{"path":653,"title":654,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-monitoring","Kubernetes - 监控与日志",{"path":656,"title":657,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-network-security","Kubernetes - 网络与安全",{"path":659,"title":660,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-service","Kubernetes - Service 与 Ingress",{"path":662,"title":663,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-storage","Kubernetes - 持久化存储",{"path":665,"title":666,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-workload","Kubernetes - 工作负载资源",{"path":668,"title":669,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-bash","Linux - Bash 基础语法",{"path":671,"title":672,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-file-directory","Linux - 文件与目录操作",{"path":674,"title":675,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-network","Linux - 网络配置",{"path":677,"title":678,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-package","Linux - 软件包管理",{"path":680,"title":681,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-process","Linux - 进程管理",{"path":683,"title":684,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-scripts","Linux - 常用脚本示例",{"path":686,"title":687,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-service","Linux - 服务管理",{"path":689,"title":690,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-user-permission","Linux - 用户与权限管理",{"path":692,"title":693,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-https","Nginx - HTTPS 配置",{"path":695,"title":696,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-install","Nginx - 安装与配置",{"path":698,"title":699,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-loadbalance","Nginx - 负载均衡",{"path":701,"title":702,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-optimization","Nginx - 性能优化",{"path":704,"title":705,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-proxy","Nginx - 反向代理",{"path":707,"title":708,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-static","Nginx - 静态资源服务",{"path":710,"title":711,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-vhost","Nginx - 虚拟主机配置",{"path":713,"title":714,"description":715},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-architecture","MySQL 高可用架构","主从复制、读写分离、分库分表。",{"path":717,"title":718,"description":719},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-index","MySQL 索引","索引是帮助 MySQL 高效获取数据的有序数据结构。",{"path":721,"title":722,"description":723},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-lock","MySQL 锁","锁用于解决并发访问时的数据一致性问题。",{"path":725,"title":726,"description":727},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-optimize","MySQL 性能优化","SQL 优化是后端开发必备技能。",{"path":729,"title":730,"description":731},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-transaction","MySQL 事务","事务是一组不可分割的操作，要么全部成功，要么全部失败。",{"path":733,"title":734,"description":735},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-advanced","SQL 进阶","多表查询、子查询、函数、视图、存储过程。",{"path":737,"title":738,"description":739},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-basic","SQL 基础","SQL（Structured Query Language）是操作关系型数据库的标准语言。",{"path":741,"title":742,"description":743},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-advanced","Redis 进阶功能","事务、发布订阅、Lua 脚本、Pipeline。",{"path":745,"title":746,"description":747},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-basic","Redis 基础","Redis 安装配置与基本命令。",{"path":749,"title":750,"description":751},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-cluster","Redis 高可用","主从复制、哨兵、Cluster 集群。",{"path":753,"title":754,"description":755},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-datatype","Redis 数据类型","Redis 5 种基本数据类型 + 4 种特殊类型。",{"path":757,"title":758,"description":759},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-optimize","Redis 性能优化","内存优化、缓存问题、最佳实践。",{"path":761,"title":762,"description":763},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-persistence","Redis 持久化","Redis 提供 RDB 和 AOF 两种持久化方式。",{"path":765,"title":766,"description":767},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-principle","Redis 底层原理","数据结构、线程模型、网络模型。",{"path":769,"title":770,"description":771},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fbehaiver-patterns\u002Fobserver-pattern","观察者模式","观察者模式属于行为型模式，定义了对象之间的一对多的依赖关系，在这种模式中，当一个对象的状态发生变化时，所有依赖于它的对象都会得到通知，并且执行相关操作。观察者模式又被成为“发布—订阅模式”，即发布者发生改变后，会通知所有订阅者。",{"path":773,"title":774,"description":11},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Ffactory-pattern","工厂模式",{"path":776,"title":777,"description":778},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Fsingleton-pattern","单例模式","单例模式是最常用的设计模式之一，他可以保证在整个应用中，某个类只存在一个实例化对象，即全局使用到该类的只有一个对象，这种模式在需要限制某些类的实例数量时非常有用，通常全局只需要一个该对象即可，如一些配置文件映射对象、数据库连接对象等。",{"path":780,"title":781,"description":782},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fstructural-patterns\u002Fadapter-pattern","适配器模式","适配器模式是一种结构型模式，可以将一个类的接口转换成客户端所期望的另一种接口，适配器模式可以帮助开发人员在不修改现有代码的情况下，将不兼容的类组合在一起。",{"path":784,"title":785,"description":786},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-basic-operations","Git 创建版本库","在 Git 上创建版本库有两种方式，一种是直接拷贝远程 Git 仓库到本地，另外一种是我们自己创建本地的版本库。",{"path":788,"title":789,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-branch-manage","Git 分支管理",{"path":791,"title":792,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-content-operations","Git 仓库内容操作",{"path":794,"title":795,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-introduce-install","Git 介绍和安装",{"path":797,"title":798,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-remote-manage","Git 远程管理",{"path":800,"title":801,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-workspace-index-repo","Git 工作原理",{"path":803,"title":804,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fhomebrew","HomeBrew 教程",{"path":806,"title":807,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fidea\u002Fshortcuts","快捷键",{"path":809,"title":810,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fmaven\u002Fintroduce-install-config","Maven - 介绍、安装、配置",{"path":812,"title":813,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fbasic-knowledge","2. 基础知识",{"path":815,"title":816,"description":817},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomponent-communication","9. 组件通信","在前面的章节内，介绍了 Vue 中最核心的内容——组件的介绍和使用，和 Java 等编程语言相反，组件并不近似于这些变成语言中的类，类可以通过类或者其实例化的对象来相互交互，但 Vue 组件之间的作用域是相互独立的，这就意味着不同组件之间的数据无法相互引用。",{"path":819,"title":820,"description":821},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomputed","4. 计算属性","虽然直接在模板中使用表达式方便，但是如果在模板中添加很多逻辑，会让模板变的臃肿且难维护，耦合度较高。有没有一种简单的方式来实现呢？答案是有的。",{"path":823,"title":824,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcreate-vue-project","1. 环境搭建及安装",{"path":826,"title":827,"description":828},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Flife-cycle","6. 生命周期","生命周期是指组件从创建、挂载、更新到销毁的整个过程中所经历的一系列阶段。在 Vue 中，每个组件都有自己的生命周期，可以通过生命周期钩子函数来监听和处理组件在不同阶段的行为和状态。",{"path":830,"title":831,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fother-api","10. 其他 API",{"path":833,"title":834,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fpinia","8. Pinia",{"path":836,"title":837,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Frouter","7. 路由",{"path":839,"title":840,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Ftemplate-grammar","3. 指令及模板语法",{"path":842,"title":843,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fvue3-new-component","11. Vue3 新组件",{"path":845,"title":846,"description":847},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fwatch","5. 监视","Watch 是 Vue 提供的一个用于监视响应式数据变化并执行相应操作的 API，能够对响应式数据的变化做出一些操作的功能。Vue3 中的 Watch 支持多种用法，包括监视响应式对象、ref 对象、数组、函数等。",{"path":849,"title":850,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-introduction","Kafka 简介与安装",{"path":852,"title":853,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-producer-consumer","Kafka 生产者与消费者",{"path":855,"title":856,"description":857},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-springboot","Spring Boot 整合 Kafka","Spring Kafka 提供了对 Apache Kafka 的便捷集成。",{"path":859,"title":860,"description":861},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-exchange","RabbitMQ Exchange 详解","Exchange（交换机）是 RabbitMQ 的核心组件，负责接收生产者发送的消息，并根据规则将消息路由到一个或多个队列。",{"path":863,"title":864,"description":11},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-introduction","RabbitMQ 简介与安装",{"path":866,"title":867,"description":868},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-reliability","RabbitMQ 消息可靠性","消息可靠性是消息队列的核心要求，RabbitMQ 提供了多种机制来保证消息不丢失。",{"path":870,"title":871,"description":872},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-springboot","Spring Boot 整合 RabbitMQ","Spring AMQP 提供了对 RabbitMQ 的便捷集成，大大简化了开发工作。",{"path":874,"title":875,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-client","RocketMQ 客户端使用",{"path":877,"title":878,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-concepts","RocketMQ 核心概念",{"path":880,"title":881,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-installation","RocketMQ 安装部署",{"path":883,"title":884,"description":885},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-message-type","RocketMQ 消息类型","RocketMQ 支持多种消息类型，满足不同业务场景需求。",{"id":887,"title":346,"body":888,"description":347,"extension":3663,"meta":3664,"navigation":1169,"path":345,"seo":3665,"stem":3666,"__hash__":3667},"docs\u002Finterview\u002Fmysql.md",{"type":889,"value":890,"toc":3618},"minimark",[891,894,897,902,907,913,981,986,1041,1047,1049,1053,1058,1074,1079,1095,1101,1208,1210,1214,1219,1290,1295,1357,1359,1363,1456,1458,1462,1467,1490,1519,1521,1525,1529,1601,1603,1607,1673,1678,1680,1684,1690,1695,1698,1702,1709,1795,1799,1806,1870,1874,1880,1900,1906,1908,1912,1917,1920,1925,1933,1938,1946,1948,1952,1956,1961,2000,2005,2054,2056,2060,2065,2165,2171,2173,2177,2182,2229,2234,2251,2253,2257,2261,2321,2326,2358,2360,2364,2369,2408,2413,2462,2467,2484,2486,2490,2500,2505,2649,2651,2655,2659,2663,2669,2674,2723,2725,2729,2734,2748,2753,2770,2772,2776,2781,2792,2797,2845,2850,2861,2863,2867,2871,2926,2931,2978,2980,2984,2990,2995,3021,3027,3029,3033,3038,3043,3051,3056,3067,3069,3073,3145,3147,3151,3224,3226,3230,3319,3321,3325,3365,3367,3371,3478,3480,3484,3487,3530,3533,3572,3575,3614],[892,893,347],"p",{},[895,896],"hr",{},[898,899,901],"h2",{"id":900},"一索引","一、索引",[903,904,906],"h3",{"id":905},"q1-btree-为什么比-b-treehash-更适合-mysql","Q1: B+Tree 为什么比 B-Tree\u002FHash 更适合 MySQL？",[892,908,909],{},[910,911,912],"strong",{},"B+Tree vs B-Tree：",[914,915,916,933],"table",{},[917,918,919],"thead",{},[920,921,922,927,930],"tr",{},[923,924,926],"th",{"align":925},"left","特性",[923,928,929],{"align":925},"B+Tree",[923,931,932],{"align":925},"B-Tree",[934,935,936,948,959,970],"tbody",{},[920,937,938,942,945],{},[939,940,941],"td",{"align":925},"数据存储",[939,943,944],{"align":925},"只在叶子节点存数据",[939,946,947],{"align":925},"所有节点都存数据",[920,949,950,953,956],{},[939,951,952],{"align":925},"叶子节点",[939,954,955],{"align":925},"有链表串联，支持范围查询",[939,957,958],{"align":925},"无链表",[920,960,961,964,967],{},[939,962,963],{"align":925},"每页存储",[939,965,966],{"align":925},"更多 key（因为不存数据）",[939,968,969],{"align":925},"较少 key",[920,971,972,975,978],{},[939,973,974],{"align":925},"IO 次数",[939,976,977],{"align":925},"更少（树更矮）",[939,979,980],{"align":925},"更多",[892,982,983],{},[910,984,985],{},"B+Tree vs Hash：",[914,987,988,999],{},[917,989,990],{},[920,991,992,994,996],{},[923,993,926],{"align":925},[923,995,929],{"align":925},[923,997,998],{"align":925},"Hash",[934,1000,1001,1012,1023,1032],{},[920,1002,1003,1006,1009],{},[939,1004,1005],{"align":925},"等值查询",[939,1007,1008],{"align":925},"O(logN)",[939,1010,1011],{"align":925},"O(1)",[920,1013,1014,1017,1020],{},[939,1015,1016],{"align":925},"范围查询",[939,1018,1019],{"align":925},"✅ 支持",[939,1021,1022],{"align":925},"❌ 不支持",[920,1024,1025,1028,1030],{},[939,1026,1027],{"align":925},"排序",[939,1029,1019],{"align":925},[939,1031,1022],{"align":925},[920,1033,1034,1037,1039],{},[939,1035,1036],{"align":925},"前缀匹配",[939,1038,1019],{"align":925},[939,1040,1022],{"align":925},[892,1042,1043,1046],{},[910,1044,1045],{},"结论："," B+Tree 更适合 OLTP 场景的范围查询和排序需求。",[895,1048],{},[903,1050,1052],{"id":1051},"q2-聚簇索引和二级索引的区别什么是回表","Q2: 聚簇索引和二级索引的区别？什么是回表？",[892,1054,1055],{},[910,1056,1057],{},"聚簇索引（Clustered Index）：",[1059,1060,1061,1068,1071],"ul",{},[1062,1063,1064,1065],"li",{},"叶子节点存储",[910,1066,1067],{},"完整数据行",[1062,1069,1070],{},"InnoDB 主键索引就是聚簇索引",[1062,1072,1073],{},"每表只有一个",[892,1075,1076],{},[910,1077,1078],{},"二级索引（Secondary Index）：",[1059,1080,1081,1086,1089],{},[1062,1082,1064,1083],{},[910,1084,1085],{},"主键值",[1062,1087,1088],{},"非主键索引都是二级索引",[1062,1090,1091,1092],{},"查询完整数据需要",[910,1093,1094],{},"回表",[892,1096,1097,1100],{},[910,1098,1099],{},"回表："," 通过二级索引查到主键后，再根据主键去聚簇索引查完整数据。",[1102,1103,1107],"pre",{"className":1104,"code":1105,"language":1106,"meta":11,"style":11},"language-sql shiki shiki-themes github-light github-light github-dark","-- 回表查询\nSELECT * FROM user WHERE name = 'Tom';\n-- 1. 通过 name 索引找到主键 id\n-- 2. 通过主键 id 回表查完整数据\n\n-- 覆盖索引，无需回表\nSELECT id, name FROM user WHERE name = 'Tom';\n-- name 索引已包含 id 和 name，直接返回\n","sql",[1108,1109,1110,1119,1152,1158,1164,1171,1177,1202],"code",{"__ignoreMap":11},[1111,1112,1115],"span",{"class":1113,"line":1114},"line",1,[1111,1116,1118],{"class":1117},"sCsY4","-- 回表查询\n",[1111,1120,1122,1126,1129,1132,1136,1139,1142,1145,1149],{"class":1113,"line":1121},2,[1111,1123,1125],{"class":1124},"s8jYJ","SELECT",[1111,1127,1128],{"class":1124}," *",[1111,1130,1131],{"class":1124}," FROM",[1111,1133,1135],{"class":1134},"sxrX7"," user ",[1111,1137,1138],{"class":1124},"WHERE",[1111,1140,1141],{"class":1124}," name",[1111,1143,1144],{"class":1124}," =",[1111,1146,1148],{"class":1147},"sIIMD"," 'Tom'",[1111,1150,1151],{"class":1134},";\n",[1111,1153,1155],{"class":1113,"line":1154},3,[1111,1156,1157],{"class":1117},"-- 1. 通过 name 索引找到主键 id\n",[1111,1159,1161],{"class":1113,"line":1160},4,[1111,1162,1163],{"class":1117},"-- 2. 通过主键 id 回表查完整数据\n",[1111,1165,1167],{"class":1113,"line":1166},5,[1111,1168,1170],{"emptyLinePlaceholder":1169},true,"\n",[1111,1172,1174],{"class":1113,"line":1173},6,[1111,1175,1176],{"class":1117},"-- 覆盖索引，无需回表\n",[1111,1178,1180,1182,1185,1188,1190,1192,1194,1196,1198,1200],{"class":1113,"line":1179},7,[1111,1181,1125],{"class":1124},[1111,1183,1184],{"class":1134}," id, ",[1111,1186,1187],{"class":1124},"name",[1111,1189,1131],{"class":1124},[1111,1191,1135],{"class":1134},[1111,1193,1138],{"class":1124},[1111,1195,1141],{"class":1124},[1111,1197,1144],{"class":1124},[1111,1199,1148],{"class":1147},[1111,1201,1151],{"class":1134},[1111,1203,1205],{"class":1113,"line":1204},8,[1111,1206,1207],{"class":1117},"-- name 索引已包含 id 和 name，直接返回\n",[895,1209],{},[903,1211,1213],{"id":1212},"q3-什么是最左前缀法则","Q3: 什么是最左前缀法则？",[892,1215,1216],{},[910,1217,1218],{},"联合索引 (a, b, c) 的最左前缀法则：",[914,1220,1221,1231],{},[917,1222,1223],{},[920,1224,1225,1228],{},[923,1226,1227],{"align":925},"查询条件",[923,1229,1230],{"align":925},"是否使用索引",[934,1232,1233,1243,1252,1261,1271,1280],{},[920,1234,1235,1240],{},[939,1236,1237],{"align":925},[1108,1238,1239],{},"a = 1",[939,1241,1242],{"align":925},"✅",[920,1244,1245,1250],{},[939,1246,1247],{"align":925},[1108,1248,1249],{},"a = 1 AND b = 2",[939,1251,1242],{"align":925},[920,1253,1254,1259],{},[939,1255,1256],{"align":925},[1108,1257,1258],{},"a = 1 AND b = 2 AND c = 3",[939,1260,1242],{"align":925},[920,1262,1263,1268],{},[939,1264,1265],{"align":925},[1108,1266,1267],{},"b = 2",[939,1269,1270],{"align":925},"❌ 无法使用",[920,1272,1273,1278],{},[939,1274,1275],{"align":925},[1108,1276,1277],{},"b = 2 AND c = 3",[939,1279,1270],{"align":925},[920,1281,1282,1287],{},[939,1283,1284],{"align":925},[1108,1285,1286],{},"a = 1 AND c = 3",[939,1288,1289],{"align":925},"✅ 只用 a",[892,1291,1292],{},[910,1293,1294],{},"范围查询右侧失效：",[1102,1296,1298],{"className":1104,"code":1297,"language":1106,"meta":11,"style":11},"-- 索引 (a, b, c)\nSELECT * FROM t WHERE a = 1 AND b > 2 AND c = 3;\n-- 只能用到 a 和 b，c 无法使用（范围查询后的列失效）\n",[1108,1299,1300,1305,1352],{"__ignoreMap":11},[1111,1301,1302],{"class":1113,"line":1114},[1111,1303,1304],{"class":1117},"-- 索引 (a, b, c)\n",[1111,1306,1307,1309,1311,1313,1316,1318,1321,1324,1328,1331,1334,1337,1340,1342,1345,1347,1350],{"class":1113,"line":1121},[1111,1308,1125],{"class":1124},[1111,1310,1128],{"class":1124},[1111,1312,1131],{"class":1124},[1111,1314,1315],{"class":1134}," t ",[1111,1317,1138],{"class":1124},[1111,1319,1320],{"class":1134}," a ",[1111,1322,1323],{"class":1124},"=",[1111,1325,1327],{"class":1326},"sBjJW"," 1",[1111,1329,1330],{"class":1124}," AND",[1111,1332,1333],{"class":1134}," b ",[1111,1335,1336],{"class":1124},">",[1111,1338,1339],{"class":1326}," 2",[1111,1341,1330],{"class":1124},[1111,1343,1344],{"class":1134}," c ",[1111,1346,1323],{"class":1124},[1111,1348,1349],{"class":1326}," 3",[1111,1351,1151],{"class":1134},[1111,1353,1354],{"class":1113,"line":1154},[1111,1355,1356],{"class":1117},"-- 只能用到 a 和 b，c 无法使用（范围查询后的列失效）\n",[895,1358],{},[903,1360,1362],{"id":1361},"q4-索引失效的常见场景","Q4: 索引失效的常见场景",[914,1364,1365,1378],{},[917,1366,1367],{},[920,1368,1369,1372,1375],{},[923,1370,1371],{"align":925},"场景",[923,1373,1374],{"align":925},"示例",[923,1376,1377],{"align":925},"原因",[934,1379,1380,1393,1406,1419,1432,1443],{},[920,1381,1382,1385,1390],{},[939,1383,1384],{"align":925},"函数\u002F表达式",[939,1386,1387],{"align":925},[1108,1388,1389],{},"WHERE YEAR(date) = 2024",[939,1391,1392],{"align":925},"索引列被加工",[920,1394,1395,1398,1403],{},[939,1396,1397],{"align":925},"隐式类型转换",[939,1399,1400],{"align":925},[1108,1401,1402],{},"WHERE varchar_col = 123",[939,1404,1405],{"align":925},"字符串列用数字查",[920,1407,1408,1411,1416],{},[939,1409,1410],{"align":925},"左模糊",[939,1412,1413],{"align":925},[1108,1414,1415],{},"WHERE name LIKE '%Tom'",[939,1417,1418],{"align":925},"无法走索引",[920,1420,1421,1424,1429],{},[939,1422,1423],{"align":925},"OR 部分无索引",[939,1425,1426],{"align":925},[1108,1427,1428],{},"WHERE a = 1 OR b = 2",[939,1430,1431],{"align":925},"b 无索引则全表扫",[920,1433,1434,1437,1440],{},[939,1435,1436],{"align":925},"数据分布差",[939,1438,1439],{"align":925},"回表代价超过全表扫描",[939,1441,1442],{"align":925},"优化器放弃索引",[920,1444,1445,1448,1453],{},[939,1446,1447],{"align":925},"不等于",[939,1449,1450],{"align":925},[1108,1451,1452],{},"WHERE status != 1",[939,1454,1455],{"align":925},"需扫描大部分数据",[895,1457],{},[903,1459,1461],{"id":1460},"q5-如何创建高效的联合索引","Q5: 如何创建高效的联合索引？",[892,1463,1464],{},[910,1465,1466],{},"选择原则：",[1468,1469,1470,1475,1480,1485],"ol",{},[1062,1471,1472],{},[910,1473,1474],{},"区分度高的列在前",[1062,1476,1477],{},[910,1478,1479],{},"常用查询条件优先",[1062,1481,1482],{},[910,1483,1484],{},"考虑排序\u002F分组需求",[1062,1486,1487],{},[910,1488,1489],{},"尽量覆盖高频查询",[1102,1491,1493],{"className":1104,"code":1492,"language":1106,"meta":11,"style":11},"-- 查询：WHERE user_id = ? AND status = ? ORDER BY created_at\n-- 推荐索引：(user_id, status, created_at)\n\n-- 避免冗余索引\n-- (a), (a,b), (a,b,c) 只需要 (a,b,c)\n",[1108,1494,1495,1500,1505,1509,1514],{"__ignoreMap":11},[1111,1496,1497],{"class":1113,"line":1114},[1111,1498,1499],{"class":1117},"-- 查询：WHERE user_id = ? AND status = ? ORDER BY created_at\n",[1111,1501,1502],{"class":1113,"line":1121},[1111,1503,1504],{"class":1117},"-- 推荐索引：(user_id, status, created_at)\n",[1111,1506,1507],{"class":1113,"line":1154},[1111,1508,1170],{"emptyLinePlaceholder":1169},[1111,1510,1511],{"class":1113,"line":1160},[1111,1512,1513],{"class":1117},"-- 避免冗余索引\n",[1111,1515,1516],{"class":1113,"line":1166},[1111,1517,1518],{"class":1117},"-- (a), (a,b), (a,b,c) 只需要 (a,b,c)\n",[895,1520],{},[898,1522,1524],{"id":1523},"二事务与-mvcc","二、事务与 MVCC",[903,1526,1528],{"id":1527},"q6-事务的-acid-特性及实现","Q6: 事务的 ACID 特性及实现",[914,1530,1531,1543],{},[917,1532,1533],{},[920,1534,1535,1537,1540],{},[923,1536,926],{"align":925},[923,1538,1539],{"align":925},"说明",[923,1541,1542],{"align":925},"实现机制",[934,1544,1545,1559,1573,1587],{},[920,1546,1547,1553,1556],{},[939,1548,1549,1552],{"align":925},[910,1550,1551],{},"A"," 原子性",[939,1554,1555],{"align":925},"全成功或全失败",[939,1557,1558],{"align":925},"Undo Log",[920,1560,1561,1567,1570],{},[939,1562,1563,1566],{"align":925},[910,1564,1565],{},"C"," 一致性",[939,1568,1569],{"align":925},"数据状态正确",[939,1571,1572],{"align":925},"依赖其他三个特性",[920,1574,1575,1581,1584],{},[939,1576,1577,1580],{"align":925},[910,1578,1579],{},"I"," 隔离性",[939,1582,1583],{"align":925},"事务互不干扰",[939,1585,1586],{"align":925},"MVCC + 锁",[920,1588,1589,1595,1598],{},[939,1590,1591,1594],{"align":925},[910,1592,1593],{},"D"," 持久性",[939,1596,1597],{"align":925},"提交后永久保存",[939,1599,1600],{"align":925},"Redo Log",[895,1602],{},[903,1604,1606],{"id":1605},"q7-mysql-的四种隔离级别","Q7: MySQL 的四种隔离级别",[914,1608,1609,1625],{},[917,1610,1611],{},[920,1612,1613,1616,1619,1622],{},[923,1614,1615],{"align":925},"隔离级别",[923,1617,1618],{"align":925},"脏读",[923,1620,1621],{"align":925},"不可重复读",[923,1623,1624],{"align":925},"幻读",[934,1626,1627,1638,1650,1662],{},[920,1628,1629,1632,1634,1636],{},[939,1630,1631],{"align":925},"READ UNCOMMITTED",[939,1633,1242],{"align":925},[939,1635,1242],{"align":925},[939,1637,1242],{"align":925},[920,1639,1640,1643,1646,1648],{},[939,1641,1642],{"align":925},"READ COMMITTED (RC)",[939,1644,1645],{"align":925},"❌",[939,1647,1242],{"align":925},[939,1649,1242],{"align":925},[920,1651,1652,1655,1657,1659],{},[939,1653,1654],{"align":925},"REPEATABLE READ (RR)",[939,1656,1645],{"align":925},[939,1658,1645],{"align":925},[939,1660,1661],{"align":925},"✅*",[920,1663,1664,1667,1669,1671],{},[939,1665,1666],{"align":925},"SERIALIZABLE",[939,1668,1645],{"align":925},[939,1670,1645],{"align":925},[939,1672,1645],{"align":925},[892,1674,1675],{},[910,1676,1677],{},"MySQL 默认 RR，通过 MVCC + Next-Key Lock 基本解决幻读。",[895,1679],{},[903,1681,1683],{"id":1682},"q8-谈谈你对-mvcc-的理解它的实现原理是什么","Q8: 谈谈你对 MVCC 的理解？它的实现原理是什么？",[892,1685,1686,1689],{},[910,1687,1688],{},"MVCC (Multi-Version Concurrency Control)"," 多版本并发控制，是 InnoDB 实现隔离级别（尤其是 RC 和 RR）的核心机制。它允许数据库在并发场景下，实现**“非阻塞读”**（快照读），解决了读写冲突问题。",[1691,1692,1694],"h4",{"id":1693},"_1-核心思想","1. 核心思想",[892,1696,1697],{},"通过维护数据的历史版本，让读操作不加锁就能读到一致性的数据，从而提高系统的吞吐量。",[1691,1699,1701],{"id":1700},"_2-三大核心支撑","2. 三大核心支撑",[892,1703,1704,1705,1708],{},"MVCC 的实现依赖于：",[910,1706,1707],{},"隐藏字段、Undo Log 版本链、ReadView","。",[1059,1710,1711,1743,1756],{},[1062,1712,1713,1716,1717],{},[910,1714,1715],{},"隐藏字段","：每行数据除了真实数据外，还有几个隐藏列：\n",[1059,1718,1719,1728,1737],{},[1062,1720,1721,1724,1725,1708],{},[1108,1722,1723],{},"DB_TRX_ID","：最近修改该行数据的",[910,1726,1727],{},"事务 ID",[1062,1729,1730,1733,1734,1736],{},[1108,1731,1732],{},"DB_ROLL_PTR","：回滚指针，指向该行数据上一个版本的 ",[910,1735,1558],{}," 地址。",[1062,1738,1739,1742],{},[1108,1740,1741],{},"DB_ROW_ID","：隐式主键（如果没有显式主键）。",[1062,1744,1745,1748,1749,1752,1753,1708],{},[910,1746,1747],{},"Undo Log 版本链","：\n当事务修改数据时，老版本数据会被写入 Undo Log，并通过隐藏列的 ",[1108,1750,1751],{},"roll_ptr"," 把这些记录串联起来，形成一个",[910,1754,1755],{},"版本链",[1062,1757,1758,1761,1762],{},[910,1759,1760],{},"ReadView (一致性视图)","：\n事务进行“快照读”时产生的一个快照，包含 4 个核心属性：\n",[1059,1763,1764,1774,1783,1789],{},[1062,1765,1766,1769,1770,1773],{},[1108,1767,1768],{},"m_ids","：生成 ReadView 时，当前系统中",[910,1771,1772],{},"活跃且未提交","的事务 ID 列表。",[1062,1775,1776,1779,1780,1782],{},[1108,1777,1778],{},"min_trx_id","：",[1108,1781,1768],{}," 中的最小值。",[1062,1784,1785,1788],{},[1108,1786,1787],{},"max_trx_id","：生成 ReadView 时系统应该分配给下一个事务的 ID（即当前最大事务 ID + 1）。",[1062,1790,1791,1794],{},[1108,1792,1793],{},"creator_trx_id","：生成该 ReadView 的当前事务 ID。",[1691,1796,1798],{"id":1797},"_3-数据可见性算法重点","3. 数据可见性算法（重点）",[892,1800,1801,1802,1805],{},"当事务读取数据时，会拿到版本链中某个版本的 ",[1108,1803,1804],{},"trx_id","，并与 ReadView 进行对比：",[1468,1807,1808,1819,1829,1840],{},[1062,1809,1810,1815,1816,1708],{},[910,1811,1812,1813],{},"等于 ",[1108,1814,1793],{},"：说明是自己改的，",[910,1817,1818],{},"可见",[1062,1820,1821,1826,1827,1708],{},[910,1822,1823,1824],{},"小于 ",[1108,1825,1778],{},"：说明该版本事务在视图生成前已提交，",[910,1828,1818],{},[1062,1830,1831,1836,1837,1708],{},[910,1832,1833,1834],{},"大于等于 ",[1108,1835,1787],{},"：说明该版本事务在视图生成后才开启，",[910,1838,1839],{},"不可见",[1062,1841,1842,1851,1852],{},[910,1843,1844,1845,1847,1848,1850],{},"在 ",[1108,1846,1778],{}," 和 ",[1108,1849,1787],{}," 之间","：\n",[1059,1853,1854,1862],{},[1062,1855,1856,1857,1859,1860,1708],{},"如果在 ",[1108,1858,1768],{}," 中：说明该版本事务还未提交，",[910,1861,1839],{},[1062,1863,1864,1865,1867,1868,1708],{},"如果不在 ",[1108,1866,1768],{}," 中：说明该版本事务已提交，",[910,1869,1818],{},[1691,1871,1873],{"id":1872},"_4-rc-和-rr-的区别","4. RC 和 RR 的区别",[892,1875,1876,1877,1779],{},"MVCC 在不同隔离级别下的表现差异主要体现在 ",[910,1878,1879],{},"ReadView 的生成时机",[1059,1881,1882,1891],{},[1062,1883,1884,1779,1887,1890],{},[910,1885,1886],{},"RC (Read Committed)",[910,1888,1889],{},"每次执行 SELECT"," 都会重新生成一个新的 ReadView。所以能读到别的事务刚提交的数据。",[1062,1892,1893,1779,1896,1899],{},[910,1894,1895],{},"RR (Repeatable Read)",[910,1897,1898],{},"仅在事务第一次执行 SELECT"," 时生成一个 ReadView，后续所有的快照读都复用这一个。所以保证了同一个事务内多次读取结果一致。",[892,1901,1902,1905],{},[910,1903,1904],{},"总结："," MVCC 让事务在不加锁的情况下实现了安全、高效的读取，是 MySQL 处理高并发读写请求的“杀手锏”。",[895,1907],{},[903,1909,1911],{"id":1910},"q9-redo-log-和-binlog-的两阶段提交","Q9: Redo Log 和 Binlog 的两阶段提交",[892,1913,1914],{},[910,1915,1916],{},"为什么需要两阶段提交？",[892,1918,1919],{},"保证 Redo Log 和 Binlog 的一致性。",[892,1921,1922],{},[910,1923,1924],{},"流程：",[1102,1926,1931],{"className":1927,"code":1929,"language":1930},[1928],"language-text","1. 写入 Redo Log（prepare 状态）\n2. 写入 Binlog\n3. 提交事务，Redo Log 改为 commit 状态\n","text",[1108,1932,1929],{"__ignoreMap":11},[892,1934,1935],{},[910,1936,1937],{},"崩溃恢复：",[1059,1939,1940,1943],{},[1062,1941,1942],{},"Redo Log 是 prepare，Binlog 无记录 → 回滚",[1062,1944,1945],{},"Redo Log 是 prepare，Binlog 有记录 → 提交",[895,1947],{},[898,1949,1951],{"id":1950},"三锁","三、锁",[903,1953,1955],{"id":1954},"q10-innodb-的锁类型","Q10: InnoDB 的锁类型",[892,1957,1958],{},[910,1959,1960],{},"按粒度分：",[914,1962,1963,1972],{},[917,1964,1965],{},[920,1966,1967,1970],{},[923,1968,1969],{"align":925},"锁类型",[923,1971,1539],{"align":925},[934,1973,1974,1984,1992],{},[920,1975,1976,1979],{},[939,1977,1978],{"align":925},"全局锁",[939,1980,1981],{"align":925},[1108,1982,1983],{},"FLUSH TABLES WITH READ LOCK",[920,1985,1986,1989],{},[939,1987,1988],{"align":925},"表锁",[939,1990,1991],{"align":925},"MDL 锁、意向锁",[920,1993,1994,1997],{},[939,1995,1996],{"align":925},"行锁",[939,1998,1999],{"align":925},"Record Lock、Gap Lock、Next-Key Lock",[892,2001,2002],{},[910,2003,2004],{},"行锁类型：",[914,2006,2007,2019],{},[917,2008,2009],{},[920,2010,2011,2014,2016],{},[923,2012,2013],{"align":925},"类型",[923,2015,1539],{"align":925},[923,2017,2018],{"align":925},"解决问题",[934,2020,2021,2032,2043],{},[920,2022,2023,2026,2029],{},[939,2024,2025],{"align":925},"Record Lock",[939,2027,2028],{"align":925},"锁定单行",[939,2030,2031],{"align":925},"解决脏读、不可重复读",[920,2033,2034,2037,2040],{},[939,2035,2036],{"align":925},"Gap Lock",[939,2038,2039],{"align":925},"锁定间隙",[939,2041,2042],{"align":925},"解决幻读",[920,2044,2045,2048,2051],{},[939,2046,2047],{"align":925},"Next-Key Lock",[939,2049,2050],{"align":925},"Record + Gap",[939,2052,2053],{"align":925},"InnoDB 默认",[895,2055],{},[903,2057,2059],{"id":2058},"q11-什么情况会产生间隙锁","Q11: 什么情况会产生间隙锁？",[892,2061,2062],{},[910,2063,2064],{},"RR 隔离级别下：",[1102,2066,2068],{"className":1104,"code":2067,"language":1106,"meta":11,"style":11},"-- 假设 id 有 1, 5, 10\n\n-- 等值查询（不存在）\nSELECT * FROM t WHERE id = 3 FOR UPDATE;\n-- 锁住间隙 (1, 5)\n\n-- 范围查询\nSELECT * FROM t WHERE id > 3 AND id \u003C 8 FOR UPDATE;\n-- 锁住间隙 (1, 5] 和 (5, 10)\n",[1108,2069,2070,2075,2079,2084,2111,2116,2120,2125,2159],{"__ignoreMap":11},[1111,2071,2072],{"class":1113,"line":1114},[1111,2073,2074],{"class":1117},"-- 假设 id 有 1, 5, 10\n",[1111,2076,2077],{"class":1113,"line":1121},[1111,2078,1170],{"emptyLinePlaceholder":1169},[1111,2080,2081],{"class":1113,"line":1154},[1111,2082,2083],{"class":1117},"-- 等值查询（不存在）\n",[1111,2085,2086,2088,2090,2092,2094,2096,2099,2101,2103,2106,2109],{"class":1113,"line":1160},[1111,2087,1125],{"class":1124},[1111,2089,1128],{"class":1124},[1111,2091,1131],{"class":1124},[1111,2093,1315],{"class":1134},[1111,2095,1138],{"class":1124},[1111,2097,2098],{"class":1134}," id ",[1111,2100,1323],{"class":1124},[1111,2102,1349],{"class":1326},[1111,2104,2105],{"class":1124}," FOR",[1111,2107,2108],{"class":1124}," UPDATE",[1111,2110,1151],{"class":1134},[1111,2112,2113],{"class":1113,"line":1166},[1111,2114,2115],{"class":1117},"-- 锁住间隙 (1, 5)\n",[1111,2117,2118],{"class":1113,"line":1173},[1111,2119,1170],{"emptyLinePlaceholder":1169},[1111,2121,2122],{"class":1113,"line":1179},[1111,2123,2124],{"class":1117},"-- 范围查询\n",[1111,2126,2127,2129,2131,2133,2135,2137,2139,2141,2143,2145,2147,2150,2153,2155,2157],{"class":1113,"line":1204},[1111,2128,1125],{"class":1124},[1111,2130,1128],{"class":1124},[1111,2132,1131],{"class":1124},[1111,2134,1315],{"class":1134},[1111,2136,1138],{"class":1124},[1111,2138,2098],{"class":1134},[1111,2140,1336],{"class":1124},[1111,2142,1349],{"class":1326},[1111,2144,1330],{"class":1124},[1111,2146,2098],{"class":1134},[1111,2148,2149],{"class":1124},"\u003C",[1111,2151,2152],{"class":1326}," 8",[1111,2154,2105],{"class":1124},[1111,2156,2108],{"class":1124},[1111,2158,1151],{"class":1134},[1111,2160,2162],{"class":1113,"line":2161},9,[1111,2163,2164],{"class":1117},"-- 锁住间隙 (1, 5] 和 (5, 10)\n",[892,2166,2167,2170],{},[910,2168,2169],{},"间隙锁的问题："," 可能导致死锁，降低并发。",[895,2172],{},[903,2174,2176],{"id":2175},"q12-如何排查和解决死锁","Q12: 如何排查和解决死锁",[892,2178,2179],{},[910,2180,2181],{},"排查方法：",[1102,2183,2185],{"className":1104,"code":2184,"language":1106,"meta":11,"style":11},"-- 查看最近死锁\nSHOW ENGINE INNODB STATUS\\G\n\n-- 开启死锁日志\nSET GLOBAL innodb_print_all_deadlocks = 1;\n",[1108,2186,2187,2192,2203,2207,2212],{"__ignoreMap":11},[1111,2188,2189],{"class":1113,"line":1114},[1111,2190,2191],{"class":1117},"-- 查看最近死锁\n",[1111,2193,2194,2197,2200],{"class":1113,"line":1121},[1111,2195,2196],{"class":1134},"SHOW ENGINE INNODB ",[1111,2198,2199],{"class":1124},"STATUS",[1111,2201,2202],{"class":1134},"\\G\n",[1111,2204,2205],{"class":1113,"line":1154},[1111,2206,1170],{"emptyLinePlaceholder":1169},[1111,2208,2209],{"class":1113,"line":1160},[1111,2210,2211],{"class":1117},"-- 开启死锁日志\n",[1111,2213,2214,2217,2220,2223,2225,2227],{"class":1113,"line":1166},[1111,2215,2216],{"class":1124},"SET",[1111,2218,2219],{"class":1124}," GLOBAL",[1111,2221,2222],{"class":1134}," innodb_print_all_deadlocks ",[1111,2224,1323],{"class":1124},[1111,2226,1327],{"class":1326},[1111,2228,1151],{"class":1134},[892,2230,2231],{},[910,2232,2233],{},"解决策略：",[1468,2235,2236,2239,2242,2245],{},[1062,2237,2238],{},"按固定顺序访问表\u002F行",[1062,2240,2241],{},"减小事务粒度",[1062,2243,2244],{},"使用索引避免全表扫描",[1062,2246,2247,2248],{},"设置锁等待超时 ",[1108,2249,2250],{},"innodb_lock_wait_timeout",[895,2252],{},[898,2254,2256],{"id":2255},"四sql-优化","四、SQL 优化",[903,2258,2260],{"id":2259},"q13-explain-关键字段解读","Q13: EXPLAIN 关键字段解读",[914,2262,2263,2275],{},[917,2264,2265],{},[920,2266,2267,2270,2272],{},[923,2268,2269],{"align":925},"字段",[923,2271,1539],{"align":925},[923,2273,2274],{"align":925},"关键值",[934,2276,2277,2288,2299,2310],{},[920,2278,2279,2282,2285],{},[939,2280,2281],{"align":925},"type",[939,2283,2284],{"align":925},"访问类型",[939,2286,2287],{"align":925},"const > eq_ref > ref > range > index > ALL",[920,2289,2290,2293,2296],{},[939,2291,2292],{"align":925},"key",[939,2294,2295],{"align":925},"实际使用的索引",[939,2297,2298],{"align":925},"NULL 表示未使用索引",[920,2300,2301,2304,2307],{},[939,2302,2303],{"align":925},"rows",[939,2305,2306],{"align":925},"预估扫描行数",[939,2308,2309],{"align":925},"越少越好",[920,2311,2312,2315,2318],{},[939,2313,2314],{"align":925},"Extra",[939,2316,2317],{"align":925},"额外信息",[939,2319,2320],{"align":925},"Using index（好）\u002F Using filesort（注意）",[892,2322,2323],{},[910,2324,2325],{},"type 值解释：",[1059,2327,2328,2334,2340,2346,2352],{},[1062,2329,2330,2333],{},[910,2331,2332],{},"const","：主键\u002F唯一索引等值查询",[1062,2335,2336,2339],{},[910,2337,2338],{},"eq_ref","：关联查询，唯一索引匹配",[1062,2341,2342,2345],{},[910,2343,2344],{},"ref","：普通索引等值查询",[1062,2347,2348,2351],{},[910,2349,2350],{},"range","：范围查询",[1062,2353,2354,2357],{},[910,2355,2356],{},"ALL","：全表扫描（需优化）",[895,2359],{},[903,2361,2363],{"id":2362},"q14-慢查询如何排查","Q14: 慢查询如何排查",[892,2365,2366],{},[910,2367,2368],{},"开启慢查询日志：",[1102,2370,2372],{"className":1104,"code":2371,"language":1106,"meta":11,"style":11},"SET GLOBAL slow_query_log = 1;\nSET GLOBAL long_query_time = 2;  -- 超过 2 秒记录\n",[1108,2373,2374,2389],{"__ignoreMap":11},[1111,2375,2376,2378,2380,2383,2385,2387],{"class":1113,"line":1114},[1111,2377,2216],{"class":1124},[1111,2379,2219],{"class":1124},[1111,2381,2382],{"class":1134}," slow_query_log ",[1111,2384,1323],{"class":1124},[1111,2386,1327],{"class":1326},[1111,2388,1151],{"class":1134},[1111,2390,2391,2393,2395,2398,2400,2402,2405],{"class":1113,"line":1121},[1111,2392,2216],{"class":1124},[1111,2394,2219],{"class":1124},[1111,2396,2397],{"class":1134}," long_query_time ",[1111,2399,1323],{"class":1124},[1111,2401,1339],{"class":1326},[1111,2403,2404],{"class":1134},";  ",[1111,2406,2407],{"class":1117},"-- 超过 2 秒记录\n",[892,2409,2410],{},[910,2411,2412],{},"分析工具：",[1102,2414,2418],{"className":2415,"code":2416,"language":2417,"meta":11,"style":11},"language-bash shiki shiki-themes github-light github-light github-dark","# 官方工具\nmysqldumpslow -s t -t 10 slow.log\n\n# Percona 工具（推荐）\npt-query-digest slow.log\n","bash",[1108,2419,2420,2425,2446,2450,2455],{"__ignoreMap":11},[1111,2421,2422],{"class":1113,"line":1114},[1111,2423,2424],{"class":1117},"# 官方工具\n",[1111,2426,2427,2431,2434,2437,2440,2443],{"class":1113,"line":1121},[1111,2428,2430],{"class":2429},"snPdu","mysqldumpslow",[1111,2432,2433],{"class":1326}," -s",[1111,2435,2436],{"class":1147}," t",[1111,2438,2439],{"class":1326}," -t",[1111,2441,2442],{"class":1326}," 10",[1111,2444,2445],{"class":1147}," slow.log\n",[1111,2447,2448],{"class":1113,"line":1154},[1111,2449,1170],{"emptyLinePlaceholder":1169},[1111,2451,2452],{"class":1113,"line":1160},[1111,2453,2454],{"class":1117},"# Percona 工具（推荐）\n",[1111,2456,2457,2460],{"class":1113,"line":1166},[1111,2458,2459],{"class":2429},"pt-query-digest",[1111,2461,2445],{"class":1147},[892,2463,2464],{},[910,2465,2466],{},"优化步骤：",[1468,2468,2469,2472,2475,2478,2481],{},[1062,2470,2471],{},"开启慢查询日志",[1062,2473,2474],{},"找出 Top N 慢 SQL",[1062,2476,2477],{},"EXPLAIN 分析执行计划",[1062,2479,2480],{},"添加\u002F优化索引",[1062,2482,2483],{},"重写 SQL 或调整业务",[895,2485],{},[903,2487,2489],{"id":2488},"q15-分页查询如何优化","Q15: 分页查询如何优化",[892,2491,2492,2495,2496,2499],{},[910,2493,2494],{},"问题："," ",[1108,2497,2498],{},"LIMIT 100000, 10"," 需要扫描 100010 行",[892,2501,2502],{},[910,2503,2504],{},"优化方案：",[1102,2506,2508],{"className":1104,"code":2507,"language":1106,"meta":11,"style":11},"-- 原始 SQL\nSELECT * FROM orders ORDER BY id LIMIT 100000, 10;\n\n-- 优化 1：子查询\nSELECT * FROM orders\nWHERE id >= (SELECT id FROM orders ORDER BY id LIMIT 100000, 1)\nLIMIT 10;\n\n-- 优化 2：游标分页（推荐）\nSELECT * FROM orders WHERE id > 上次最大ID ORDER BY id LIMIT 10;\n",[1108,2509,2510,2515,2545,2549,2554,2565,2602,2610,2614,2619],{"__ignoreMap":11},[1111,2511,2512],{"class":1113,"line":1114},[1111,2513,2514],{"class":1117},"-- 原始 SQL\n",[1111,2516,2517,2519,2521,2523,2526,2529,2531,2534,2537,2540,2543],{"class":1113,"line":1121},[1111,2518,1125],{"class":1124},[1111,2520,1128],{"class":1124},[1111,2522,1131],{"class":1124},[1111,2524,2525],{"class":1134}," orders ",[1111,2527,2528],{"class":1124},"ORDER BY",[1111,2530,2098],{"class":1134},[1111,2532,2533],{"class":1124},"LIMIT",[1111,2535,2536],{"class":1326}," 100000",[1111,2538,2539],{"class":1134},", ",[1111,2541,2542],{"class":1326},"10",[1111,2544,1151],{"class":1134},[1111,2546,2547],{"class":1113,"line":1154},[1111,2548,1170],{"emptyLinePlaceholder":1169},[1111,2550,2551],{"class":1113,"line":1160},[1111,2552,2553],{"class":1117},"-- 优化 1：子查询\n",[1111,2555,2556,2558,2560,2562],{"class":1113,"line":1166},[1111,2557,1125],{"class":1124},[1111,2559,1128],{"class":1124},[1111,2561,1131],{"class":1124},[1111,2563,2564],{"class":1134}," orders\n",[1111,2566,2567,2569,2571,2574,2577,2579,2581,2584,2586,2588,2590,2592,2594,2596,2599],{"class":1113,"line":1173},[1111,2568,1138],{"class":1124},[1111,2570,2098],{"class":1134},[1111,2572,2573],{"class":1124},">=",[1111,2575,2576],{"class":1134}," (",[1111,2578,1125],{"class":1124},[1111,2580,2098],{"class":1134},[1111,2582,2583],{"class":1124},"FROM",[1111,2585,2525],{"class":1134},[1111,2587,2528],{"class":1124},[1111,2589,2098],{"class":1134},[1111,2591,2533],{"class":1124},[1111,2593,2536],{"class":1326},[1111,2595,2539],{"class":1134},[1111,2597,2598],{"class":1326},"1",[1111,2600,2601],{"class":1134},")\n",[1111,2603,2604,2606,2608],{"class":1113,"line":1179},[1111,2605,2533],{"class":1124},[1111,2607,2442],{"class":1326},[1111,2609,1151],{"class":1134},[1111,2611,2612],{"class":1113,"line":1204},[1111,2613,1170],{"emptyLinePlaceholder":1169},[1111,2615,2616],{"class":1113,"line":2161},[1111,2617,2618],{"class":1117},"-- 优化 2：游标分页（推荐）\n",[1111,2620,2622,2624,2626,2628,2630,2632,2634,2636,2639,2641,2643,2645,2647],{"class":1113,"line":2621},10,[1111,2623,1125],{"class":1124},[1111,2625,1128],{"class":1124},[1111,2627,1131],{"class":1124},[1111,2629,2525],{"class":1134},[1111,2631,1138],{"class":1124},[1111,2633,2098],{"class":1134},[1111,2635,1336],{"class":1124},[1111,2637,2638],{"class":1134}," 上次最大ID ",[1111,2640,2528],{"class":1124},[1111,2642,2098],{"class":1134},[1111,2644,2533],{"class":1124},[1111,2646,2442],{"class":1326},[1111,2648,1151],{"class":1134},[895,2650],{},[898,2652,2654],{"id":2653},"五复制与高可用","五、复制与高可用",[903,2656,2658],{"id":2657},"q16-主从复制的原理","Q16: 主从复制的原理",[892,2660,2661],{},[910,2662,1924],{},[1102,2664,2667],{"className":2665,"code":2666,"language":1930},[1928],"1. Master 写入 Binlog\n2. Slave IO 线程拉取 Binlog\n3. Slave 写入 Relay Log\n4. Slave SQL 线程重放 Relay Log\n",[1108,2668,2666],{"__ignoreMap":11},[892,2670,2671],{},[910,2672,2673],{},"复制模式：",[914,2675,2676,2688],{},[917,2677,2678],{},[920,2679,2680,2683,2685],{},[923,2681,2682],{"align":925},"模式",[923,2684,1539],{"align":925},[923,2686,2687],{"align":925},"特点",[934,2689,2690,2701,2712],{},[920,2691,2692,2695,2698],{},[939,2693,2694],{"align":925},"异步",[939,2696,2697],{"align":925},"Master 不等 Slave",[939,2699,2700],{"align":925},"性能好，可能丢数据",[920,2702,2703,2706,2709],{},[939,2704,2705],{"align":925},"半同步",[939,2707,2708],{"align":925},"至少一个 Slave 确认",[939,2710,2711],{"align":925},"折中方案",[920,2713,2714,2717,2720],{},[939,2715,2716],{"align":925},"全同步",[939,2718,2719],{"align":925},"所有 Slave 确认",[939,2721,2722],{"align":925},"强一致，性能差",[895,2724],{},[903,2726,2728],{"id":2727},"q17-主从延迟的原因和解决方案","Q17: 主从延迟的原因和解决方案",[892,2730,2731],{},[910,2732,2733],{},"原因：",[1468,2735,2736,2739,2742,2745],{},[1062,2737,2738],{},"大事务执行慢",[1062,2740,2741],{},"从库机器性能差",[1062,2743,2744],{},"单线程回放（MySQL 5.6 前）",[1062,2746,2747],{},"网络延迟",[892,2749,2750],{},[910,2751,2752],{},"解决方案：",[1468,2754,2755,2758,2764,2767],{},[1062,2756,2757],{},"拆分大事务",[1062,2759,2760,2761],{},"开启并行复制 ",[1108,2762,2763],{},"slave_parallel_workers",[1062,2765,2766],{},"提升从库配置",[1062,2768,2769],{},"关键读操作强制走主库",[895,2771],{},[903,2773,2775],{"id":2774},"q18-分库分表的时机和策略","Q18: 分库分表的时机和策略",[892,2777,2778],{},[910,2779,2780],{},"触发条件：",[1059,2782,2783,2786,2789],{},[1062,2784,2785],{},"单表超过 2000 万行",[1062,2787,2788],{},"表大小超过 2GB",[1062,2790,2791],{},"QPS 超过单实例瓶颈",[892,2793,2794],{},[910,2795,2796],{},"分表策略：",[914,2798,2799,2811],{},[917,2800,2801],{},[920,2802,2803,2806,2808],{},[923,2804,2805],{"align":925},"策略",[923,2807,1539],{"align":925},[923,2809,2810],{"align":925},"适用场景",[934,2812,2813,2823,2834],{},[920,2814,2815,2817,2820],{},[939,2816,998],{"align":925},[939,2818,2819],{"align":925},"按 key 取模",[939,2821,2822],{"align":925},"数据均匀分布",[920,2824,2825,2828,2831],{},[939,2826,2827],{"align":925},"Range",[939,2829,2830],{"align":925},"按范围划分",[939,2832,2833],{"align":925},"时间序列数据",[920,2835,2836,2839,2842],{},[939,2837,2838],{"align":925},"一致性哈希",[939,2840,2841],{"align":925},"减少扩容迁移",[939,2843,2844],{"align":925},"动态扩容场景",[892,2846,2847],{},[910,2848,2849],{},"代价：",[1059,2851,2852,2855,2858],{},[1062,2853,2854],{},"跨分片查询复杂",[1062,2856,2857],{},"分布式事务",[1062,2859,2860],{},"唯一 ID 生成",[895,2862],{},[898,2864,2866],{"id":2865},"六更多八股文","六、更多八股文",[903,2868,2870],{"id":2869},"q19-mysql-的三大日志","Q19: MySQL 的三大日志",[914,2872,2873,2886],{},[917,2874,2875],{},[920,2876,2877,2880,2883],{},[923,2878,2879],{"align":925},"日志",[923,2881,2882],{"align":925},"作用",[923,2884,2885],{"align":925},"层级",[934,2887,2888,2901,2914],{},[920,2889,2890,2895,2898],{},[939,2891,2892],{"align":925},[910,2893,2894],{},"binlog",[939,2896,2897],{"align":925},"归档日志，主从复制",[939,2899,2900],{"align":925},"Server 层",[920,2902,2903,2908,2911],{},[939,2904,2905],{"align":925},[910,2906,2907],{},"redo log",[939,2909,2910],{"align":925},"崩溃恢复，保证持久性",[939,2912,2913],{"align":925},"InnoDB 存储引擎层",[920,2915,2916,2921,2924],{},[939,2917,2918],{"align":925},[910,2919,2920],{},"undo log",[939,2922,2923],{"align":925},"事务回滚，MVCC",[939,2925,2913],{"align":925},[892,2927,2928],{},[910,2929,2930],{},"redo log vs binlog：",[914,2932,2933,2943],{},[917,2934,2935],{},[920,2936,2937,2939,2941],{},[923,2938,926],{"align":925},[923,2940,2907],{"align":925},[923,2942,2894],{"align":925},[934,2944,2945,2956,2967],{},[920,2946,2947,2950,2953],{},[939,2948,2949],{"align":925},"写入方式",[939,2951,2952],{"align":925},"循环写，固定大小",[939,2954,2955],{"align":925},"追加写，归档",[920,2957,2958,2961,2964],{},[939,2959,2960],{"align":925},"内容",[939,2962,2963],{"align":925},"物理日志（页修改）",[939,2965,2966],{"align":925},"逻辑日志（SQL 语句）",[920,2968,2969,2972,2975],{},[939,2970,2971],{"align":925},"用途",[939,2973,2974],{"align":925},"崩溃恢复",[939,2976,2977],{"align":925},"复制、恢复",[895,2979],{},[903,2981,2983],{"id":2982},"q20-buffer-pool-的作用","Q20: Buffer Pool 的作用",[892,2985,2986,2989],{},[910,2987,2988],{},"作用："," 缓存数据页和索引页，减少磁盘 IO",[892,2991,2992],{},[910,2993,2994],{},"组成：",[1059,2996,2997,3003,3009,3015],{},[1062,2998,2999,3002],{},[910,3000,3001],{},"数据页","：缓存表数据",[1062,3004,3005,3008],{},[910,3006,3007],{},"索引页","：缓存索引",[1062,3010,3011,3014],{},[910,3012,3013],{},"Change Buffer","：缓存二级索引修改",[1062,3016,3017,3020],{},[910,3018,3019],{},"自适应哈希索引","：热点数据索引",[892,3022,3023,3026],{},[910,3024,3025],{},"淘汰策略："," 改进的 LRU，分为新生代和老年代",[895,3028],{},[903,3030,3032],{"id":3031},"q21-change-buffer-的作用","Q21: Change Buffer 的作用",[892,3034,3035,3037],{},[910,3036,2988],{}," 缓存二级索引的写操作，减少随机 IO",[892,3039,3040],{},[910,3041,3042],{},"条件：",[1059,3044,3045,3048],{},[1062,3046,3047],{},"只对二级索引生效",[1062,3049,3050],{},"索引不是唯一索引（唯一索引需要判断重复）",[892,3052,3053],{},[910,3054,3055],{},"合并时机：",[1059,3057,3058,3061,3064],{},[1062,3059,3060],{},"访问该数据页时",[1062,3062,3063],{},"后台线程定期合并",[1062,3065,3066],{},"数据库关闭时",[895,3068],{},[903,3070,3072],{"id":3071},"q22-innodb-和-myisam-的区别","Q22: InnoDB 和 MyISAM 的区别",[914,3074,3075,3087],{},[917,3076,3077],{},[920,3078,3079,3081,3084],{},[923,3080,926],{"align":925},[923,3082,3083],{"align":925},"InnoDB",[923,3085,3086],{"align":925},"MyISAM",[934,3088,3089,3098,3107,3116,3124,3134],{},[920,3090,3091,3094,3096],{},[939,3092,3093],{"align":925},"事务",[939,3095,1242],{"align":925},[939,3097,1645],{"align":925},[920,3099,3100,3102,3104],{},[939,3101,1996],{"align":925},[939,3103,1242],{"align":925},[939,3105,3106],{"align":925},"❌（只有表锁）",[920,3108,3109,3112,3114],{},[939,3110,3111],{"align":925},"外键",[939,3113,1242],{"align":925},[939,3115,1645],{"align":925},[920,3117,3118,3120,3122],{},[939,3119,2974],{"align":925},[939,3121,1242],{"align":925},[939,3123,1645],{"align":925},[920,3125,3126,3129,3132],{},[939,3127,3128],{"align":925},"全文索引",[939,3130,3131],{"align":925},"✅（MySQL 5.6+）",[939,3133,1242],{"align":925},[920,3135,3136,3139,3142],{},[939,3137,3138],{"align":925},"存储文件",[939,3140,3141],{"align":925},".ibd",[939,3143,3144],{"align":925},".MYD + .MYI",[895,3146],{},[903,3148,3150],{"id":3149},"q23-大表优化方案","Q23: 大表优化方案",[914,3152,3153,3162],{},[917,3154,3155],{},[920,3156,3157,3160],{},[923,3158,3159],{"align":925},"方案",[923,3161,1539],{"align":925},[934,3163,3164,3174,3184,3194,3204,3214],{},[920,3165,3166,3171],{},[939,3167,3168],{"align":925},[910,3169,3170],{},"分区表",[939,3172,3173],{"align":925},"按时间\u002F范围分区",[920,3175,3176,3181],{},[939,3177,3178],{"align":925},[910,3179,3180],{},"归档冷数据",[939,3182,3183],{"align":925},"历史数据迁移",[920,3185,3186,3191],{},[939,3187,3188],{"align":925},[910,3189,3190],{},"分库分表",[939,3192,3193],{"align":925},"水平\u002F垂直拆分",[920,3195,3196,3201],{},[939,3197,3198],{"align":925},[910,3199,3200],{},"读写分离",[939,3202,3203],{"align":925},"主写从读",[920,3205,3206,3211],{},[939,3207,3208],{"align":925},[910,3209,3210],{},"索引优化",[939,3212,3213],{"align":925},"添加合适索引",[920,3215,3216,3221],{},[939,3217,3218],{"align":925},[910,3219,3220],{},"SQL 优化",[939,3222,3223],{"align":925},"避免全表扫描",[895,3225],{},[903,3227,3229],{"id":3228},"q24-如何优化-count","Q24: 如何优化 COUNT(*)",[1102,3231,3233],{"className":1104,"code":3232,"language":1106,"meta":11,"style":11},"-- 慢：全表扫描\nSELECT COUNT(*) FROM orders;\n\n-- 优化方案：\n-- 1. 使用二级索引（比主键索引小）\nSELECT COUNT(*) FROM orders FORCE INDEX(idx_status);\n\n-- 2. 维护计数表\n-- 3. 估算值（information_schema.TABLES）\n-- 4. Redis 缓存计数\n",[1108,3234,3235,3240,3261,3265,3270,3275,3300,3304,3309,3314],{"__ignoreMap":11},[1111,3236,3237],{"class":1113,"line":1114},[1111,3238,3239],{"class":1117},"-- 慢：全表扫描\n",[1111,3241,3242,3244,3247,3250,3253,3256,3258],{"class":1113,"line":1121},[1111,3243,1125],{"class":1124},[1111,3245,3246],{"class":1326}," COUNT",[1111,3248,3249],{"class":1134},"(",[1111,3251,3252],{"class":1124},"*",[1111,3254,3255],{"class":1134},") ",[1111,3257,2583],{"class":1124},[1111,3259,3260],{"class":1134}," orders;\n",[1111,3262,3263],{"class":1113,"line":1154},[1111,3264,1170],{"emptyLinePlaceholder":1169},[1111,3266,3267],{"class":1113,"line":1160},[1111,3268,3269],{"class":1117},"-- 优化方案：\n",[1111,3271,3272],{"class":1113,"line":1166},[1111,3273,3274],{"class":1117},"-- 1. 使用二级索引（比主键索引小）\n",[1111,3276,3277,3279,3281,3283,3285,3287,3289,3291,3294,3297],{"class":1113,"line":1173},[1111,3278,1125],{"class":1124},[1111,3280,3246],{"class":1326},[1111,3282,3249],{"class":1134},[1111,3284,3252],{"class":1124},[1111,3286,3255],{"class":1134},[1111,3288,2583],{"class":1124},[1111,3290,2525],{"class":1134},[1111,3292,3293],{"class":1124},"FORCE",[1111,3295,3296],{"class":1124}," INDEX",[1111,3298,3299],{"class":1134},"(idx_status);\n",[1111,3301,3302],{"class":1113,"line":1179},[1111,3303,1170],{"emptyLinePlaceholder":1169},[1111,3305,3306],{"class":1113,"line":1204},[1111,3307,3308],{"class":1117},"-- 2. 维护计数表\n",[1111,3310,3311],{"class":1113,"line":2161},[1111,3312,3313],{"class":1117},"-- 3. 估算值（information_schema.TABLES）\n",[1111,3315,3316],{"class":1113,"line":2621},[1111,3317,3318],{"class":1117},"-- 4. Redis 缓存计数\n",[895,3320],{},[903,3322,3324],{"id":3323},"q25-什么是当前读和快照读","Q25: 什么是当前读和快照读",[914,3326,3327,3337],{},[917,3328,3329],{},[920,3330,3331,3333,3335],{},[923,3332,2013],{"align":925},[923,3334,1539],{"align":925},[923,3336,1374],{"align":925},[934,3338,3339,3352],{},[920,3340,3341,3346,3349],{},[939,3342,3343],{"align":925},[910,3344,3345],{},"快照读",[939,3347,3348],{"align":925},"读取历史版本，通过 MVCC",[939,3350,3351],{"align":925},"普通 SELECT",[920,3353,3354,3359,3362],{},[939,3355,3356],{"align":925},[910,3357,3358],{},"当前读",[939,3360,3361],{"align":925},"读取最新数据，加锁",[939,3363,3364],{"align":925},"SELECT ... FOR UPDATE",[895,3366],{},[903,3368,3370],{"id":3369},"q26-mysql-锁等待排查","Q26: MySQL 锁等待排查",[1102,3372,3374],{"className":1104,"code":3373,"language":1106,"meta":11,"style":11},"-- 查看锁等待\nSELECT * FROM information_schema.INNODB_LOCK_WAITS;\n\n-- 查看事务\nSELECT * FROM information_schema.INNODB_TRX;\n\n-- 查看锁\nSELECT * FROM performance_schema.data_locks;\n\n-- 杀死阻塞事务\nKILL \u003Cthread_id>;\n",[1108,3375,3376,3381,3400,3404,3409,3426,3430,3435,3453,3457,3462],{"__ignoreMap":11},[1111,3377,3378],{"class":1113,"line":1114},[1111,3379,3380],{"class":1117},"-- 查看锁等待\n",[1111,3382,3383,3385,3387,3389,3392,3395,3398],{"class":1113,"line":1121},[1111,3384,1125],{"class":1124},[1111,3386,1128],{"class":1124},[1111,3388,1131],{"class":1124},[1111,3390,3391],{"class":1326}," information_schema",[1111,3393,3394],{"class":1134},".",[1111,3396,3397],{"class":1326},"INNODB_LOCK_WAITS",[1111,3399,1151],{"class":1134},[1111,3401,3402],{"class":1113,"line":1154},[1111,3403,1170],{"emptyLinePlaceholder":1169},[1111,3405,3406],{"class":1113,"line":1160},[1111,3407,3408],{"class":1117},"-- 查看事务\n",[1111,3410,3411,3413,3415,3417,3419,3421,3424],{"class":1113,"line":1166},[1111,3412,1125],{"class":1124},[1111,3414,1128],{"class":1124},[1111,3416,1131],{"class":1124},[1111,3418,3391],{"class":1326},[1111,3420,3394],{"class":1134},[1111,3422,3423],{"class":1326},"INNODB_TRX",[1111,3425,1151],{"class":1134},[1111,3427,3428],{"class":1113,"line":1173},[1111,3429,1170],{"emptyLinePlaceholder":1169},[1111,3431,3432],{"class":1113,"line":1179},[1111,3433,3434],{"class":1117},"-- 查看锁\n",[1111,3436,3437,3439,3441,3443,3446,3448,3451],{"class":1113,"line":1204},[1111,3438,1125],{"class":1124},[1111,3440,1128],{"class":1124},[1111,3442,1131],{"class":1124},[1111,3444,3445],{"class":1326}," performance_schema",[1111,3447,3394],{"class":1134},[1111,3449,3450],{"class":1326},"data_locks",[1111,3452,1151],{"class":1134},[1111,3454,3455],{"class":1113,"line":2161},[1111,3456,1170],{"emptyLinePlaceholder":1169},[1111,3458,3459],{"class":1113,"line":2621},[1111,3460,3461],{"class":1117},"-- 杀死阻塞事务\n",[1111,3463,3465,3468,3471,3474,3476],{"class":1113,"line":3464},11,[1111,3466,3467],{"class":1124},"KILL",[1111,3469,3470],{"class":1124}," \u003C",[1111,3472,3473],{"class":1134},"thread_id",[1111,3475,1336],{"class":1124},[1111,3477,1151],{"class":1134},[895,3479],{},[898,3481,3483],{"id":3482},"七高频考点清单","七、高频考点清单",[903,3485,3486],{"id":3486},"必考",[1059,3488,3491,3500,3506,3512,3518,3524],{"className":3489},[3490],"contains-task-list",[1062,3492,3495,3499],{"className":3493},[3494],"task-list-item",[3496,3497],"input",{"disabled":1169,"type":3498},"checkbox"," B+Tree 优势、聚簇索引 vs 二级索引",[1062,3501,3503,3505],{"className":3502},[3494],[3496,3504],{"disabled":1169,"type":3498}," 最左前缀法则、索引失效场景",[1062,3507,3509,3511],{"className":3508},[3494],[3496,3510],{"disabled":1169,"type":3498}," MVCC 实现、Read View 时机",[1062,3513,3515,3517],{"className":3514},[3494],[3496,3516],{"disabled":1169,"type":3498}," Record Lock \u002F Gap Lock \u002F Next-Key Lock",[1062,3519,3521,3523],{"className":3520},[3494],[3496,3522],{"disabled":1169,"type":3498}," Redo Log \u002F Binlog 两阶段提交",[1062,3525,3527,3529],{"className":3526},[3494],[3496,3528],{"disabled":1169,"type":3498}," EXPLAIN 关键字段含义",[903,3531,3532],{"id":3532},"常考",[1059,3534,3536,3542,3548,3554,3560,3566],{"className":3535},[3490],[1062,3537,3539,3541],{"className":3538},[3494],[3496,3540],{"disabled":1169,"type":3498}," 事务 ACID 实现",[1062,3543,3545,3547],{"className":3544},[3494],[3496,3546],{"disabled":1169,"type":3498}," 隔离级别与并发问题",[1062,3549,3551,3553],{"className":3550},[3494],[3496,3552],{"disabled":1169,"type":3498}," 慢查询排查流程",[1062,3555,3557,3559],{"className":3556},[3494],[3496,3558],{"disabled":1169,"type":3498}," 分页优化",[1062,3561,3563,3565],{"className":3562},[3494],[3496,3564],{"disabled":1169,"type":3498}," 死锁排查",[1062,3567,3569,3571],{"className":3568},[3494],[3496,3570],{"disabled":1169,"type":3498}," 三大日志的作用",[903,3573,3574],{"id":3574},"进阶",[1059,3576,3578,3584,3590,3596,3602,3608],{"className":3577},[3490],[1062,3579,3581,3583],{"className":3580},[3494],[3496,3582],{"disabled":1169,"type":3498}," 主从复制原理",[1062,3585,3587,3589],{"className":3586},[3494],[3496,3588],{"disabled":1169,"type":3498}," 半同步复制",[1062,3591,3593,3595],{"className":3592},[3494],[3496,3594],{"disabled":1169,"type":3498}," 分库分表策略",[1062,3597,3599,3601],{"className":3598},[3494],[3496,3600],{"disabled":1169,"type":3498}," 主从延迟解决方案",[1062,3603,3605,3607],{"className":3604},[3494],[3496,3606],{"disabled":1169,"type":3498}," Buffer Pool 原理",[1062,3609,3611,3613],{"className":3610},[3494],[3496,3612],{"disabled":1169,"type":3498}," InnoDB vs MyISAM",[3615,3616,3617],"style",{},"html pre.shiki code .sCsY4, html code.shiki .sCsY4{--shiki-light:#6A737D;--shiki-default:#6A737D;--shiki-dark:#6A737D}html pre.shiki code .snPdu, html code.shiki .snPdu{--shiki-light:#6F42C1;--shiki-default:#6F42C1;--shiki-dark:#B392F0}html pre.shiki code .sBjJW, html code.shiki .sBjJW{--shiki-light:#005CC5;--shiki-default:#005CC5;--shiki-dark:#79B8FF}html pre.shiki code .sIIMD, html code.shiki .sIIMD{--shiki-light:#032F62;--shiki-default:#032F62;--shiki-dark:#9ECBFF}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .s8jYJ, html code.shiki .s8jYJ{--shiki-light:#D73A49;--shiki-default:#D73A49;--shiki-dark:#F97583}html pre.shiki code .sxrX7, html code.shiki .sxrX7{--shiki-light:#24292E;--shiki-default:#24292E;--shiki-dark:#E1E4E8}",{"title":11,"searchDepth":1121,"depth":1121,"links":3619},[3620,3627,3633,3638,3643,3648,3658],{"id":900,"depth":1121,"text":901,"children":3621},[3622,3623,3624,3625,3626],{"id":905,"depth":1154,"text":906},{"id":1051,"depth":1154,"text":1052},{"id":1212,"depth":1154,"text":1213},{"id":1361,"depth":1154,"text":1362},{"id":1460,"depth":1154,"text":1461},{"id":1523,"depth":1121,"text":1524,"children":3628},[3629,3630,3631,3632],{"id":1527,"depth":1154,"text":1528},{"id":1605,"depth":1154,"text":1606},{"id":1682,"depth":1154,"text":1683},{"id":1910,"depth":1154,"text":1911},{"id":1950,"depth":1121,"text":1951,"children":3634},[3635,3636,3637],{"id":1954,"depth":1154,"text":1955},{"id":2058,"depth":1154,"text":2059},{"id":2175,"depth":1154,"text":2176},{"id":2255,"depth":1121,"text":2256,"children":3639},[3640,3641,3642],{"id":2259,"depth":1154,"text":2260},{"id":2362,"depth":1154,"text":2363},{"id":2488,"depth":1154,"text":2489},{"id":2653,"depth":1121,"text":2654,"children":3644},[3645,3646,3647],{"id":2657,"depth":1154,"text":2658},{"id":2727,"depth":1154,"text":2728},{"id":2774,"depth":1154,"text":2775},{"id":2865,"depth":1121,"text":2866,"children":3649},[3650,3651,3652,3653,3654,3655,3656,3657],{"id":2869,"depth":1154,"text":2870},{"id":2982,"depth":1154,"text":2983},{"id":3031,"depth":1154,"text":3032},{"id":3071,"depth":1154,"text":3072},{"id":3149,"depth":1154,"text":3150},{"id":3228,"depth":1154,"text":3229},{"id":3323,"depth":1154,"text":3324},{"id":3369,"depth":1154,"text":3370},{"id":3482,"depth":1121,"text":3483,"children":3659},[3660,3661,3662],{"id":3486,"depth":1154,"text":3486},{"id":3532,"depth":1154,"text":3532},{"id":3574,"depth":1154,"text":3574},"md",{},{"title":346,"description":347},"interview\u002Fmysql","eekQ6FNxrcQGh4cxE2ZsqkIr7YgWXtaneFKD6HfS6tE",1775496433397]