[{"data":1,"prerenderedAt":4300},["ShallowReactive",2],{"search-docs":3,"doc-\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-helm":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":642,"body":888,"description":11,"extension":4295,"meta":4296,"navigation":1083,"path":641,"seo":4297,"stem":4298,"__hash__":4299},"docs\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-helm.md",{"type":889,"value":890,"toc":4246},"minimark",[891,895,899,903,956,960,964,989,993,1013,1017,1028,1031,1044,1047,1050,1172,1176,1242,1246,1417,1421,1527,1531,1645,1649,1705,1709,1748,1751,1754,1801,1804,1811,2059,2062,2081,2085,2125,2128,2178,2182,2186,2355,2359,2566,2570,2956,2959,2963,3207,3210,3278,3281,3373,3376,3541,3544,3605,3609,3613,3679,3683,3711,3714,3751,3754,3757,3763,3838,3841,3902,3905,3908,3970,3973,4020,4024,4049,4053,4146,4149,4237,4242],[892,893,894],"h2",{"id":894},"概述",[896,897,898],"p",{},"Helm 是 Kubernetes 的包管理工具，类似于 apt\u002Fyum\u002Fnpm。它允许开发者打包、配置和部署 Kubernetes 应用，大大简化了复杂应用的部署和管理。",[900,901,902],"h3",{"id":902},"核心概念",[904,905,906,920],"table",{},[907,908,909],"thead",{},[910,911,912,917],"tr",{},[913,914,916],"th",{"align":915},"left","概念",[913,918,919],{"align":915},"说明",[921,922,923,932,940,948],"tbody",{},[910,924,925,929],{},[926,927,928],"td",{"align":915},"Chart",[926,930,931],{"align":915},"Helm 包，包含 Kubernetes 资源的模板",[910,933,934,937],{},[926,935,936],{"align":915},"Repository",[926,938,939],{"align":915},"存放 Chart 的仓库",[910,941,942,945],{},[926,943,944],{"align":915},"Release",[926,946,947],{"align":915},"Chart 的一次部署实例",[910,949,950,953],{},[926,951,952],{"align":915},"Values",[926,954,955],{"align":915},"Chart 的配置参数",[892,957,959],{"id":958},"安装-helm","安装 Helm",[900,961,963],{"id":962},"macos","macOS",[965,966,970],"pre",{"className":967,"code":968,"language":969,"meta":11,"style":11},"language-bash shiki shiki-themes github-light github-light github-dark","brew install helm\n","bash",[971,972,973],"code",{"__ignoreMap":11},[974,975,978,982,986],"span",{"class":976,"line":977},"line",1,[974,979,981],{"class":980},"snPdu","brew",[974,983,985],{"class":984},"sIIMD"," install",[974,987,988],{"class":984}," helm\n",[900,990,992],{"id":991},"linux","Linux",[965,994,996],{"className":967,"code":995,"language":969,"meta":11,"style":11},"curl https:\u002F\u002Fraw.githubusercontent.com\u002Fhelm\u002Fhelm\u002Fmain\u002Fscripts\u002Fget-helm-3 | bash\n",[971,997,998],{"__ignoreMap":11},[974,999,1000,1003,1006,1010],{"class":976,"line":977},[974,1001,1002],{"class":980},"curl",[974,1004,1005],{"class":984}," https:\u002F\u002Fraw.githubusercontent.com\u002Fhelm\u002Fhelm\u002Fmain\u002Fscripts\u002Fget-helm-3",[974,1007,1009],{"class":1008},"s8jYJ"," |",[974,1011,1012],{"class":980}," bash\n",[900,1014,1016],{"id":1015},"windows","Windows",[965,1018,1022],{"className":1019,"code":1020,"language":1021,"meta":11,"style":11},"language-powershell shiki shiki-themes github-light github-light github-dark","choco install kubernetes-helm\n","powershell",[971,1023,1024],{"__ignoreMap":11},[974,1025,1026],{"class":976,"line":977},[974,1027,1020],{},[900,1029,1030],{"id":1030},"验证安装",[965,1032,1034],{"className":967,"code":1033,"language":969,"meta":11,"style":11},"helm version\n",[971,1035,1036],{"__ignoreMap":11},[974,1037,1038,1041],{"class":976,"line":977},[974,1039,1040],{"class":980},"helm",[974,1042,1043],{"class":984}," version\n",[892,1045,1046],{"id":1046},"基本使用",[900,1048,1049],{"id":1049},"添加仓库",[965,1051,1053],{"className":967,"code":1052,"language":969,"meta":11,"style":11},"# 添加官方仓库\nhelm repo add stable https:\u002F\u002Fcharts.helm.sh\u002Fstable\n\n# 添加 Bitnami 仓库\nhelm repo add bitnami https:\u002F\u002Fcharts.bitnami.com\u002Fbitnami\n\n# 更新仓库索引\nhelm repo update\n\n# 查看已添加的仓库\nhelm repo list\n\n# 删除仓库\nhelm repo remove stable\n",[971,1054,1055,1061,1078,1085,1091,1106,1111,1117,1127,1132,1138,1148,1153,1159],{"__ignoreMap":11},[974,1056,1057],{"class":976,"line":977},[974,1058,1060],{"class":1059},"sCsY4","# 添加官方仓库\n",[974,1062,1064,1066,1069,1072,1075],{"class":976,"line":1063},2,[974,1065,1040],{"class":980},[974,1067,1068],{"class":984}," repo",[974,1070,1071],{"class":984}," add",[974,1073,1074],{"class":984}," stable",[974,1076,1077],{"class":984}," https:\u002F\u002Fcharts.helm.sh\u002Fstable\n",[974,1079,1081],{"class":976,"line":1080},3,[974,1082,1084],{"emptyLinePlaceholder":1083},true,"\n",[974,1086,1088],{"class":976,"line":1087},4,[974,1089,1090],{"class":1059},"# 添加 Bitnami 仓库\n",[974,1092,1094,1096,1098,1100,1103],{"class":976,"line":1093},5,[974,1095,1040],{"class":980},[974,1097,1068],{"class":984},[974,1099,1071],{"class":984},[974,1101,1102],{"class":984}," bitnami",[974,1104,1105],{"class":984}," https:\u002F\u002Fcharts.bitnami.com\u002Fbitnami\n",[974,1107,1109],{"class":976,"line":1108},6,[974,1110,1084],{"emptyLinePlaceholder":1083},[974,1112,1114],{"class":976,"line":1113},7,[974,1115,1116],{"class":1059},"# 更新仓库索引\n",[974,1118,1120,1122,1124],{"class":976,"line":1119},8,[974,1121,1040],{"class":980},[974,1123,1068],{"class":984},[974,1125,1126],{"class":984}," update\n",[974,1128,1130],{"class":976,"line":1129},9,[974,1131,1084],{"emptyLinePlaceholder":1083},[974,1133,1135],{"class":976,"line":1134},10,[974,1136,1137],{"class":1059},"# 查看已添加的仓库\n",[974,1139,1141,1143,1145],{"class":976,"line":1140},11,[974,1142,1040],{"class":980},[974,1144,1068],{"class":984},[974,1146,1147],{"class":984}," list\n",[974,1149,1151],{"class":976,"line":1150},12,[974,1152,1084],{"emptyLinePlaceholder":1083},[974,1154,1156],{"class":976,"line":1155},13,[974,1157,1158],{"class":1059},"# 删除仓库\n",[974,1160,1162,1164,1166,1169],{"class":976,"line":1161},14,[974,1163,1040],{"class":980},[974,1165,1068],{"class":984},[974,1167,1168],{"class":984}," remove",[974,1170,1171],{"class":984}," stable\n",[900,1173,1175],{"id":1174},"搜索-chart","搜索 Chart",[965,1177,1179],{"className":967,"code":1178,"language":969,"meta":11,"style":11},"# 在仓库中搜索\nhelm search repo nginx\n\n# 在 Artifact Hub 搜索\nhelm search hub nginx\n\n# 查看所有版本\nhelm search repo nginx --versions\n",[971,1180,1181,1186,1198,1202,1207,1218,1222,1227],{"__ignoreMap":11},[974,1182,1183],{"class":976,"line":977},[974,1184,1185],{"class":1059},"# 在仓库中搜索\n",[974,1187,1188,1190,1193,1195],{"class":976,"line":1063},[974,1189,1040],{"class":980},[974,1191,1192],{"class":984}," search",[974,1194,1068],{"class":984},[974,1196,1197],{"class":984}," nginx\n",[974,1199,1200],{"class":976,"line":1080},[974,1201,1084],{"emptyLinePlaceholder":1083},[974,1203,1204],{"class":976,"line":1087},[974,1205,1206],{"class":1059},"# 在 Artifact Hub 搜索\n",[974,1208,1209,1211,1213,1216],{"class":976,"line":1093},[974,1210,1040],{"class":980},[974,1212,1192],{"class":984},[974,1214,1215],{"class":984}," hub",[974,1217,1197],{"class":984},[974,1219,1220],{"class":976,"line":1108},[974,1221,1084],{"emptyLinePlaceholder":1083},[974,1223,1224],{"class":976,"line":1113},[974,1225,1226],{"class":1059},"# 查看所有版本\n",[974,1228,1229,1231,1233,1235,1238],{"class":976,"line":1119},[974,1230,1040],{"class":980},[974,1232,1192],{"class":984},[974,1234,1068],{"class":984},[974,1236,1237],{"class":984}," nginx",[974,1239,1241],{"class":1240},"sBjJW"," --versions\n",[900,1243,1245],{"id":1244},"安装-chart","安装 Chart",[965,1247,1249],{"className":967,"code":1248,"language":969,"meta":11,"style":11},"# 基本安装\nhelm install my-nginx bitnami\u002Fnginx\n\n# 指定命名空间\nhelm install my-nginx bitnami\u002Fnginx -n production\n\n# 指定版本\nhelm install my-nginx bitnami\u002Fnginx --version 15.0.0\n\n# 自定义配置\nhelm install my-nginx bitnami\u002Fnginx --set service.type=NodePort\n\n# 使用 values 文件\nhelm install my-nginx bitnami\u002Fnginx -f custom-values.yaml\n\n# 生成名称\nhelm install bitnami\u002Fnginx --generate-name\n\n# 模拟安装（不实际执行）\nhelm install my-nginx bitnami\u002Fnginx --dry-run\n",[971,1250,1251,1256,1268,1272,1277,1294,1298,1303,1319,1323,1328,1344,1348,1353,1369,1374,1380,1392,1397,1403],{"__ignoreMap":11},[974,1252,1253],{"class":976,"line":977},[974,1254,1255],{"class":1059},"# 基本安装\n",[974,1257,1258,1260,1262,1265],{"class":976,"line":1063},[974,1259,1040],{"class":980},[974,1261,985],{"class":984},[974,1263,1264],{"class":984}," my-nginx",[974,1266,1267],{"class":984}," bitnami\u002Fnginx\n",[974,1269,1270],{"class":976,"line":1080},[974,1271,1084],{"emptyLinePlaceholder":1083},[974,1273,1274],{"class":976,"line":1087},[974,1275,1276],{"class":1059},"# 指定命名空间\n",[974,1278,1279,1281,1283,1285,1288,1291],{"class":976,"line":1093},[974,1280,1040],{"class":980},[974,1282,985],{"class":984},[974,1284,1264],{"class":984},[974,1286,1287],{"class":984}," bitnami\u002Fnginx",[974,1289,1290],{"class":1240}," -n",[974,1292,1293],{"class":984}," production\n",[974,1295,1296],{"class":976,"line":1108},[974,1297,1084],{"emptyLinePlaceholder":1083},[974,1299,1300],{"class":976,"line":1113},[974,1301,1302],{"class":1059},"# 指定版本\n",[974,1304,1305,1307,1309,1311,1313,1316],{"class":976,"line":1119},[974,1306,1040],{"class":980},[974,1308,985],{"class":984},[974,1310,1264],{"class":984},[974,1312,1287],{"class":984},[974,1314,1315],{"class":1240}," --version",[974,1317,1318],{"class":1240}," 15.0.0\n",[974,1320,1321],{"class":976,"line":1129},[974,1322,1084],{"emptyLinePlaceholder":1083},[974,1324,1325],{"class":976,"line":1134},[974,1326,1327],{"class":1059},"# 自定义配置\n",[974,1329,1330,1332,1334,1336,1338,1341],{"class":976,"line":1140},[974,1331,1040],{"class":980},[974,1333,985],{"class":984},[974,1335,1264],{"class":984},[974,1337,1287],{"class":984},[974,1339,1340],{"class":1240}," --set",[974,1342,1343],{"class":984}," service.type=NodePort\n",[974,1345,1346],{"class":976,"line":1150},[974,1347,1084],{"emptyLinePlaceholder":1083},[974,1349,1350],{"class":976,"line":1155},[974,1351,1352],{"class":1059},"# 使用 values 文件\n",[974,1354,1355,1357,1359,1361,1363,1366],{"class":976,"line":1161},[974,1356,1040],{"class":980},[974,1358,985],{"class":984},[974,1360,1264],{"class":984},[974,1362,1287],{"class":984},[974,1364,1365],{"class":1240}," -f",[974,1367,1368],{"class":984}," custom-values.yaml\n",[974,1370,1372],{"class":976,"line":1371},15,[974,1373,1084],{"emptyLinePlaceholder":1083},[974,1375,1377],{"class":976,"line":1376},16,[974,1378,1379],{"class":1059},"# 生成名称\n",[974,1381,1383,1385,1387,1389],{"class":976,"line":1382},17,[974,1384,1040],{"class":980},[974,1386,985],{"class":984},[974,1388,1287],{"class":984},[974,1390,1391],{"class":1240}," --generate-name\n",[974,1393,1395],{"class":976,"line":1394},18,[974,1396,1084],{"emptyLinePlaceholder":1083},[974,1398,1400],{"class":976,"line":1399},19,[974,1401,1402],{"class":1059},"# 模拟安装（不实际执行）\n",[974,1404,1406,1408,1410,1412,1414],{"class":976,"line":1405},20,[974,1407,1040],{"class":980},[974,1409,985],{"class":984},[974,1411,1264],{"class":984},[974,1413,1287],{"class":984},[974,1415,1416],{"class":1240}," --dry-run\n",[900,1418,1420],{"id":1419},"查看-release","查看 Release",[965,1422,1424],{"className":967,"code":1423,"language":969,"meta":11,"style":11},"# 查看所有 Release\nhelm list\nhelm ls\n\n# 查看所有命名空间\nhelm list -A\n\n# 查看特定状态\nhelm list --pending\nhelm list --failed\n\n# 查看 Release 详情\nhelm status my-nginx\n\n# 查看 Release 历史\nhelm history my-nginx\n",[971,1425,1426,1431,1437,1444,1448,1453,1463,1467,1472,1481,1490,1494,1499,1509,1513,1518],{"__ignoreMap":11},[974,1427,1428],{"class":976,"line":977},[974,1429,1430],{"class":1059},"# 查看所有 Release\n",[974,1432,1433,1435],{"class":976,"line":1063},[974,1434,1040],{"class":980},[974,1436,1147],{"class":984},[974,1438,1439,1441],{"class":976,"line":1080},[974,1440,1040],{"class":980},[974,1442,1443],{"class":984}," ls\n",[974,1445,1446],{"class":976,"line":1087},[974,1447,1084],{"emptyLinePlaceholder":1083},[974,1449,1450],{"class":976,"line":1093},[974,1451,1452],{"class":1059},"# 查看所有命名空间\n",[974,1454,1455,1457,1460],{"class":976,"line":1108},[974,1456,1040],{"class":980},[974,1458,1459],{"class":984}," list",[974,1461,1462],{"class":1240}," -A\n",[974,1464,1465],{"class":976,"line":1113},[974,1466,1084],{"emptyLinePlaceholder":1083},[974,1468,1469],{"class":976,"line":1119},[974,1470,1471],{"class":1059},"# 查看特定状态\n",[974,1473,1474,1476,1478],{"class":976,"line":1129},[974,1475,1040],{"class":980},[974,1477,1459],{"class":984},[974,1479,1480],{"class":1240}," --pending\n",[974,1482,1483,1485,1487],{"class":976,"line":1134},[974,1484,1040],{"class":980},[974,1486,1459],{"class":984},[974,1488,1489],{"class":1240}," --failed\n",[974,1491,1492],{"class":976,"line":1140},[974,1493,1084],{"emptyLinePlaceholder":1083},[974,1495,1496],{"class":976,"line":1150},[974,1497,1498],{"class":1059},"# 查看 Release 详情\n",[974,1500,1501,1503,1506],{"class":976,"line":1155},[974,1502,1040],{"class":980},[974,1504,1505],{"class":984}," status",[974,1507,1508],{"class":984}," my-nginx\n",[974,1510,1511],{"class":976,"line":1161},[974,1512,1084],{"emptyLinePlaceholder":1083},[974,1514,1515],{"class":976,"line":1371},[974,1516,1517],{"class":1059},"# 查看 Release 历史\n",[974,1519,1520,1522,1525],{"class":976,"line":1376},[974,1521,1040],{"class":980},[974,1523,1524],{"class":984}," history",[974,1526,1508],{"class":984},[900,1528,1530],{"id":1529},"升级-release","升级 Release",[965,1532,1534],{"className":967,"code":1533,"language":969,"meta":11,"style":11},"# 升级\nhelm upgrade my-nginx bitnami\u002Fnginx\n\n# 升级并安装（不存在则安装）\nhelm upgrade --install my-nginx bitnami\u002Fnginx\n\n# 升级并修改配置\nhelm upgrade my-nginx bitnami\u002Fnginx --set replicaCount=3\n\n# 重用上次的配置\nhelm upgrade my-nginx bitnami\u002Fnginx --reuse-values\n\n# 重置所有配置\nhelm upgrade my-nginx bitnami\u002Fnginx --reset-values\n",[971,1535,1536,1541,1552,1556,1561,1574,1578,1583,1601,1605,1610,1623,1627,1632],{"__ignoreMap":11},[974,1537,1538],{"class":976,"line":977},[974,1539,1540],{"class":1059},"# 升级\n",[974,1542,1543,1545,1548,1550],{"class":976,"line":1063},[974,1544,1040],{"class":980},[974,1546,1547],{"class":984}," upgrade",[974,1549,1264],{"class":984},[974,1551,1267],{"class":984},[974,1553,1554],{"class":976,"line":1080},[974,1555,1084],{"emptyLinePlaceholder":1083},[974,1557,1558],{"class":976,"line":1087},[974,1559,1560],{"class":1059},"# 升级并安装（不存在则安装）\n",[974,1562,1563,1565,1567,1570,1572],{"class":976,"line":1093},[974,1564,1040],{"class":980},[974,1566,1547],{"class":984},[974,1568,1569],{"class":1240}," --install",[974,1571,1264],{"class":984},[974,1573,1267],{"class":984},[974,1575,1576],{"class":976,"line":1108},[974,1577,1084],{"emptyLinePlaceholder":1083},[974,1579,1580],{"class":976,"line":1113},[974,1581,1582],{"class":1059},"# 升级并修改配置\n",[974,1584,1585,1587,1589,1591,1593,1595,1598],{"class":976,"line":1119},[974,1586,1040],{"class":980},[974,1588,1547],{"class":984},[974,1590,1264],{"class":984},[974,1592,1287],{"class":984},[974,1594,1340],{"class":1240},[974,1596,1597],{"class":984}," replicaCount=",[974,1599,1600],{"class":1240},"3\n",[974,1602,1603],{"class":976,"line":1129},[974,1604,1084],{"emptyLinePlaceholder":1083},[974,1606,1607],{"class":976,"line":1134},[974,1608,1609],{"class":1059},"# 重用上次的配置\n",[974,1611,1612,1614,1616,1618,1620],{"class":976,"line":1140},[974,1613,1040],{"class":980},[974,1615,1547],{"class":984},[974,1617,1264],{"class":984},[974,1619,1287],{"class":984},[974,1621,1622],{"class":1240}," --reuse-values\n",[974,1624,1625],{"class":976,"line":1150},[974,1626,1084],{"emptyLinePlaceholder":1083},[974,1628,1629],{"class":976,"line":1155},[974,1630,1631],{"class":1059},"# 重置所有配置\n",[974,1633,1634,1636,1638,1640,1642],{"class":976,"line":1161},[974,1635,1040],{"class":980},[974,1637,1547],{"class":984},[974,1639,1264],{"class":984},[974,1641,1287],{"class":984},[974,1643,1644],{"class":1240}," --reset-values\n",[900,1646,1648],{"id":1647},"回滚-release","回滚 Release",[965,1650,1652],{"className":967,"code":1651,"language":969,"meta":11,"style":11},"# 查看历史\nhelm history my-nginx\n\n# 回滚到上一版本\nhelm rollback my-nginx\n\n# 回滚到指定版本\nhelm rollback my-nginx 2\n",[971,1653,1654,1659,1667,1671,1676,1685,1689,1694],{"__ignoreMap":11},[974,1655,1656],{"class":976,"line":977},[974,1657,1658],{"class":1059},"# 查看历史\n",[974,1660,1661,1663,1665],{"class":976,"line":1063},[974,1662,1040],{"class":980},[974,1664,1524],{"class":984},[974,1666,1508],{"class":984},[974,1668,1669],{"class":976,"line":1080},[974,1670,1084],{"emptyLinePlaceholder":1083},[974,1672,1673],{"class":976,"line":1087},[974,1674,1675],{"class":1059},"# 回滚到上一版本\n",[974,1677,1678,1680,1683],{"class":976,"line":1093},[974,1679,1040],{"class":980},[974,1681,1682],{"class":984}," rollback",[974,1684,1508],{"class":984},[974,1686,1687],{"class":976,"line":1108},[974,1688,1084],{"emptyLinePlaceholder":1083},[974,1690,1691],{"class":976,"line":1113},[974,1692,1693],{"class":1059},"# 回滚到指定版本\n",[974,1695,1696,1698,1700,1702],{"class":976,"line":1119},[974,1697,1040],{"class":980},[974,1699,1682],{"class":984},[974,1701,1264],{"class":984},[974,1703,1704],{"class":1240}," 2\n",[900,1706,1708],{"id":1707},"卸载-release","卸载 Release",[965,1710,1712],{"className":967,"code":1711,"language":969,"meta":11,"style":11},"# 卸载\nhelm uninstall my-nginx\n\n# 保留历史记录\nhelm uninstall my-nginx --keep-history\n",[971,1713,1714,1719,1728,1732,1737],{"__ignoreMap":11},[974,1715,1716],{"class":976,"line":977},[974,1717,1718],{"class":1059},"# 卸载\n",[974,1720,1721,1723,1726],{"class":976,"line":1063},[974,1722,1040],{"class":980},[974,1724,1725],{"class":984}," uninstall",[974,1727,1508],{"class":984},[974,1729,1730],{"class":976,"line":1080},[974,1731,1084],{"emptyLinePlaceholder":1083},[974,1733,1734],{"class":976,"line":1087},[974,1735,1736],{"class":1059},"# 保留历史记录\n",[974,1738,1739,1741,1743,1745],{"class":976,"line":1093},[974,1740,1040],{"class":980},[974,1742,1725],{"class":984},[974,1744,1264],{"class":984},[974,1746,1747],{"class":1240}," --keep-history\n",[892,1749,1750],{"id":1750},"配置管理",[900,1752,1753],{"id":1753},"查看默认配置",[965,1755,1757],{"className":967,"code":1756,"language":969,"meta":11,"style":11},"# 查看 Chart 的默认 values\nhelm show values bitnami\u002Fnginx\n\n# 保存到文件\nhelm show values bitnami\u002Fnginx > values.yaml\n",[971,1758,1759,1764,1776,1780,1785],{"__ignoreMap":11},[974,1760,1761],{"class":976,"line":977},[974,1762,1763],{"class":1059},"# 查看 Chart 的默认 values\n",[974,1765,1766,1768,1771,1774],{"class":976,"line":1063},[974,1767,1040],{"class":980},[974,1769,1770],{"class":984}," show",[974,1772,1773],{"class":984}," values",[974,1775,1267],{"class":984},[974,1777,1778],{"class":976,"line":1080},[974,1779,1084],{"emptyLinePlaceholder":1083},[974,1781,1782],{"class":976,"line":1087},[974,1783,1784],{"class":1059},"# 保存到文件\n",[974,1786,1787,1789,1791,1793,1795,1798],{"class":976,"line":1093},[974,1788,1040],{"class":980},[974,1790,1770],{"class":984},[974,1792,1773],{"class":984},[974,1794,1287],{"class":984},[974,1796,1797],{"class":1008}," >",[974,1799,1800],{"class":984}," values.yaml\n",[900,1802,1803],{"id":1803},"自定义配置",[896,1805,1806,1807,1810],{},"创建 ",[971,1808,1809],{},"custom-values.yaml","：",[965,1812,1816],{"className":1813,"code":1814,"language":1815,"meta":11,"style":11},"language-yaml shiki shiki-themes github-light github-light github-dark","# 副本数\nreplicaCount: 3\n\n# 镜像配置\nimage:\n  registry: docker.io\n  repository: bitnami\u002Fnginx\n  tag: 1.25.0\n\n# 服务配置\nservice:\n  type: NodePort\n  port: 80\n  nodePort: 30080\n\n# 资源限制\nresources:\n  limits:\n    cpu: 200m\n    memory: 256Mi\n  requests:\n    cpu: 100m\n    memory: 128Mi\n\n# 启用 Ingress\ningress:\n  enabled: true\n  hostname: nginx.example.com\n  annotations:\n    kubernetes.io\u002Fingress.class: nginx\n","yaml",[971,1817,1818,1823,1835,1839,1844,1852,1862,1872,1882,1886,1891,1898,1908,1918,1928,1932,1937,1944,1951,1961,1971,1979,1989,1999,2004,2010,2018,2029,2040,2048],{"__ignoreMap":11},[974,1819,1820],{"class":976,"line":977},[974,1821,1822],{"class":1059},"# 副本数\n",[974,1824,1825,1829,1833],{"class":976,"line":1063},[974,1826,1828],{"class":1827},"sovSZ","replicaCount",[974,1830,1832],{"class":1831},"sxrX7",": ",[974,1834,1600],{"class":1240},[974,1836,1837],{"class":976,"line":1080},[974,1838,1084],{"emptyLinePlaceholder":1083},[974,1840,1841],{"class":976,"line":1087},[974,1842,1843],{"class":1059},"# 镜像配置\n",[974,1845,1846,1849],{"class":976,"line":1093},[974,1847,1848],{"class":1827},"image",[974,1850,1851],{"class":1831},":\n",[974,1853,1854,1857,1859],{"class":976,"line":1108},[974,1855,1856],{"class":1827},"  registry",[974,1858,1832],{"class":1831},[974,1860,1861],{"class":984},"docker.io\n",[974,1863,1864,1867,1869],{"class":976,"line":1113},[974,1865,1866],{"class":1827},"  repository",[974,1868,1832],{"class":1831},[974,1870,1871],{"class":984},"bitnami\u002Fnginx\n",[974,1873,1874,1877,1879],{"class":976,"line":1119},[974,1875,1876],{"class":1827},"  tag",[974,1878,1832],{"class":1831},[974,1880,1881],{"class":1240},"1.25.0\n",[974,1883,1884],{"class":976,"line":1129},[974,1885,1084],{"emptyLinePlaceholder":1083},[974,1887,1888],{"class":976,"line":1134},[974,1889,1890],{"class":1059},"# 服务配置\n",[974,1892,1893,1896],{"class":976,"line":1140},[974,1894,1895],{"class":1827},"service",[974,1897,1851],{"class":1831},[974,1899,1900,1903,1905],{"class":976,"line":1150},[974,1901,1902],{"class":1827},"  type",[974,1904,1832],{"class":1831},[974,1906,1907],{"class":984},"NodePort\n",[974,1909,1910,1913,1915],{"class":976,"line":1155},[974,1911,1912],{"class":1827},"  port",[974,1914,1832],{"class":1831},[974,1916,1917],{"class":1240},"80\n",[974,1919,1920,1923,1925],{"class":976,"line":1161},[974,1921,1922],{"class":1827},"  nodePort",[974,1924,1832],{"class":1831},[974,1926,1927],{"class":1240},"30080\n",[974,1929,1930],{"class":976,"line":1371},[974,1931,1084],{"emptyLinePlaceholder":1083},[974,1933,1934],{"class":976,"line":1376},[974,1935,1936],{"class":1059},"# 资源限制\n",[974,1938,1939,1942],{"class":976,"line":1382},[974,1940,1941],{"class":1827},"resources",[974,1943,1851],{"class":1831},[974,1945,1946,1949],{"class":976,"line":1394},[974,1947,1948],{"class":1827},"  limits",[974,1950,1851],{"class":1831},[974,1952,1953,1956,1958],{"class":976,"line":1399},[974,1954,1955],{"class":1827},"    cpu",[974,1957,1832],{"class":1831},[974,1959,1960],{"class":984},"200m\n",[974,1962,1963,1966,1968],{"class":976,"line":1405},[974,1964,1965],{"class":1827},"    memory",[974,1967,1832],{"class":1831},[974,1969,1970],{"class":984},"256Mi\n",[974,1972,1974,1977],{"class":976,"line":1973},21,[974,1975,1976],{"class":1827},"  requests",[974,1978,1851],{"class":1831},[974,1980,1982,1984,1986],{"class":976,"line":1981},22,[974,1983,1955],{"class":1827},[974,1985,1832],{"class":1831},[974,1987,1988],{"class":984},"100m\n",[974,1990,1992,1994,1996],{"class":976,"line":1991},23,[974,1993,1965],{"class":1827},[974,1995,1832],{"class":1831},[974,1997,1998],{"class":984},"128Mi\n",[974,2000,2002],{"class":976,"line":2001},24,[974,2003,1084],{"emptyLinePlaceholder":1083},[974,2005,2007],{"class":976,"line":2006},25,[974,2008,2009],{"class":1059},"# 启用 Ingress\n",[974,2011,2013,2016],{"class":976,"line":2012},26,[974,2014,2015],{"class":1827},"ingress",[974,2017,1851],{"class":1831},[974,2019,2021,2024,2026],{"class":976,"line":2020},27,[974,2022,2023],{"class":1827},"  enabled",[974,2025,1832],{"class":1831},[974,2027,2028],{"class":1240},"true\n",[974,2030,2032,2035,2037],{"class":976,"line":2031},28,[974,2033,2034],{"class":1827},"  hostname",[974,2036,1832],{"class":1831},[974,2038,2039],{"class":984},"nginx.example.com\n",[974,2041,2043,2046],{"class":976,"line":2042},29,[974,2044,2045],{"class":1827},"  annotations",[974,2047,1851],{"class":1831},[974,2049,2051,2054,2056],{"class":976,"line":2050},30,[974,2052,2053],{"class":1827},"    kubernetes.io\u002Fingress.class",[974,2055,1832],{"class":1831},[974,2057,2058],{"class":984},"nginx\n",[896,2060,2061],{},"安装时使用：",[965,2063,2065],{"className":967,"code":2064,"language":969,"meta":11,"style":11},"helm install my-nginx bitnami\u002Fnginx -f custom-values.yaml\n",[971,2066,2067],{"__ignoreMap":11},[974,2068,2069,2071,2073,2075,2077,2079],{"class":976,"line":977},[974,2070,1040],{"class":980},[974,2072,985],{"class":984},[974,2074,1264],{"class":984},[974,2076,1287],{"class":984},[974,2078,1365],{"class":1240},[974,2080,1368],{"class":984},[900,2082,2084],{"id":2083},"多个-values-文件","多个 Values 文件",[965,2086,2088],{"className":967,"code":2087,"language":969,"meta":11,"style":11},"# 后面的文件优先级更高\nhelm install my-nginx bitnami\u002Fnginx \\\n  -f base-values.yaml \\\n  -f production-values.yaml\n",[971,2089,2090,2095,2108,2118],{"__ignoreMap":11},[974,2091,2092],{"class":976,"line":977},[974,2093,2094],{"class":1059},"# 后面的文件优先级更高\n",[974,2096,2097,2099,2101,2103,2105],{"class":976,"line":1063},[974,2098,1040],{"class":980},[974,2100,985],{"class":984},[974,2102,1264],{"class":984},[974,2104,1287],{"class":984},[974,2106,2107],{"class":1240}," \\\n",[974,2109,2110,2113,2116],{"class":976,"line":1080},[974,2111,2112],{"class":1240},"  -f",[974,2114,2115],{"class":984}," base-values.yaml",[974,2117,2107],{"class":1240},[974,2119,2120,2122],{"class":976,"line":1087},[974,2121,2112],{"class":1240},[974,2123,2124],{"class":984}," production-values.yaml\n",[900,2126,2127],{"id":2127},"命令行覆盖",[965,2129,2131],{"className":967,"code":2130,"language":969,"meta":11,"style":11},"# --set 优先级最高\nhelm install my-nginx bitnami\u002Fnginx \\\n  -f values.yaml \\\n  --set replicaCount=5 \\\n  --set service.type=LoadBalancer\n",[971,2132,2133,2138,2150,2159,2171],{"__ignoreMap":11},[974,2134,2135],{"class":976,"line":977},[974,2136,2137],{"class":1059},"# --set 优先级最高\n",[974,2139,2140,2142,2144,2146,2148],{"class":976,"line":1063},[974,2141,1040],{"class":980},[974,2143,985],{"class":984},[974,2145,1264],{"class":984},[974,2147,1287],{"class":984},[974,2149,2107],{"class":1240},[974,2151,2152,2154,2157],{"class":976,"line":1080},[974,2153,2112],{"class":1240},[974,2155,2156],{"class":984}," values.yaml",[974,2158,2107],{"class":1240},[974,2160,2161,2164,2166,2169],{"class":976,"line":1087},[974,2162,2163],{"class":1240},"  --set",[974,2165,1597],{"class":984},[974,2167,2168],{"class":1240},"5",[974,2170,2107],{"class":1240},[974,2172,2173,2175],{"class":976,"line":1093},[974,2174,2163],{"class":1240},[974,2176,2177],{"class":984}," service.type=LoadBalancer\n",[892,2179,2181],{"id":2180},"创建-chart","创建 Chart",[900,2183,2185],{"id":2184},"初始化-chart","初始化 Chart",[965,2187,2189],{"className":967,"code":2188,"language":969,"meta":11,"style":11},"# 创建新 Chart\nhelm create mychart\n\n# 目录结构\nmychart\u002F\n├── Chart.yaml          # Chart 元信息\n├── values.yaml         # 默认配置\n├── charts\u002F             # 依赖的 Chart\n├── templates\u002F          # Kubernetes 资源模板\n│   ├── deployment.yaml\n│   ├── service.yaml\n│   ├── ingress.yaml\n│   ├── hpa.yaml\n│   ├── serviceaccount.yaml\n│   ├── _helpers.tpl    # 模板辅助函数\n│   ├── NOTES.txt       # 安装后的提示信息\n│   └── tests\u002F          # 测试\n└── .helmignore         # 忽略文件\n",[971,2190,2191,2196,2206,2210,2215,2220,2231,2240,2250,2260,2271,2280,2289,2298,2307,2319,2331,2344],{"__ignoreMap":11},[974,2192,2193],{"class":976,"line":977},[974,2194,2195],{"class":1059},"# 创建新 Chart\n",[974,2197,2198,2200,2203],{"class":976,"line":1063},[974,2199,1040],{"class":980},[974,2201,2202],{"class":984}," create",[974,2204,2205],{"class":984}," mychart\n",[974,2207,2208],{"class":976,"line":1080},[974,2209,1084],{"emptyLinePlaceholder":1083},[974,2211,2212],{"class":976,"line":1087},[974,2213,2214],{"class":1059},"# 目录结构\n",[974,2216,2217],{"class":976,"line":1093},[974,2218,2219],{"class":980},"mychart\u002F\n",[974,2221,2222,2225,2228],{"class":976,"line":1108},[974,2223,2224],{"class":980},"├──",[974,2226,2227],{"class":984}," Chart.yaml",[974,2229,2230],{"class":1059},"          # Chart 元信息\n",[974,2232,2233,2235,2237],{"class":976,"line":1113},[974,2234,2224],{"class":980},[974,2236,2156],{"class":984},[974,2238,2239],{"class":1059},"         # 默认配置\n",[974,2241,2242,2244,2247],{"class":976,"line":1119},[974,2243,2224],{"class":980},[974,2245,2246],{"class":984}," charts\u002F",[974,2248,2249],{"class":1059},"             # 依赖的 Chart\n",[974,2251,2252,2254,2257],{"class":976,"line":1129},[974,2253,2224],{"class":980},[974,2255,2256],{"class":984}," templates\u002F",[974,2258,2259],{"class":1059},"          # Kubernetes 资源模板\n",[974,2261,2262,2265,2268],{"class":976,"line":1134},[974,2263,2264],{"class":980},"│",[974,2266,2267],{"class":984},"   ├──",[974,2269,2270],{"class":984}," deployment.yaml\n",[974,2272,2273,2275,2277],{"class":976,"line":1140},[974,2274,2264],{"class":980},[974,2276,2267],{"class":984},[974,2278,2279],{"class":984}," service.yaml\n",[974,2281,2282,2284,2286],{"class":976,"line":1150},[974,2283,2264],{"class":980},[974,2285,2267],{"class":984},[974,2287,2288],{"class":984}," ingress.yaml\n",[974,2290,2291,2293,2295],{"class":976,"line":1155},[974,2292,2264],{"class":980},[974,2294,2267],{"class":984},[974,2296,2297],{"class":984}," hpa.yaml\n",[974,2299,2300,2302,2304],{"class":976,"line":1161},[974,2301,2264],{"class":980},[974,2303,2267],{"class":984},[974,2305,2306],{"class":984}," serviceaccount.yaml\n",[974,2308,2309,2311,2313,2316],{"class":976,"line":1371},[974,2310,2264],{"class":980},[974,2312,2267],{"class":984},[974,2314,2315],{"class":984}," _helpers.tpl",[974,2317,2318],{"class":1059},"    # 模板辅助函数\n",[974,2320,2321,2323,2325,2328],{"class":976,"line":1376},[974,2322,2264],{"class":980},[974,2324,2267],{"class":984},[974,2326,2327],{"class":984}," NOTES.txt",[974,2329,2330],{"class":1059},"       # 安装后的提示信息\n",[974,2332,2333,2335,2338,2341],{"class":976,"line":1382},[974,2334,2264],{"class":980},[974,2336,2337],{"class":984},"   └──",[974,2339,2340],{"class":984}," tests\u002F",[974,2342,2343],{"class":1059},"          # 测试\n",[974,2345,2346,2349,2352],{"class":976,"line":1394},[974,2347,2348],{"class":980},"└──",[974,2350,2351],{"class":984}," .helmignore",[974,2353,2354],{"class":1059},"         # 忽略文件\n",[900,2356,2358],{"id":2357},"chartyaml","Chart.yaml",[965,2360,2362],{"className":1813,"code":2361,"language":1815,"meta":11,"style":11},"apiVersion: v2\nname: mychart\ndescription: A Helm chart for my application\ntype: application\nversion: 0.1.0        # Chart 版本\nappVersion: \"1.0.0\"   # 应用版本\n\nkeywords:\n  - web\n  - nginx\n\nhome: https:\u002F\u002Fgithub.com\u002Fexample\u002Fmychart\nsources:\n  - https:\u002F\u002Fgithub.com\u002Fexample\u002Fmychart\n\nmaintainers:\n  - name: John Doe\n    email: john@example.com\n\ndependencies:\n  - name: mysql\n    version: \"9.0.0\"\n    repository: https:\u002F\u002Fcharts.bitnami.com\u002Fbitnami\n    condition: mysql.enabled\n",[971,2363,2364,2374,2384,2394,2404,2417,2430,2434,2441,2449,2455,2459,2469,2476,2482,2486,2493,2504,2514,2518,2525,2536,2546,2556],{"__ignoreMap":11},[974,2365,2366,2369,2371],{"class":976,"line":977},[974,2367,2368],{"class":1827},"apiVersion",[974,2370,1832],{"class":1831},[974,2372,2373],{"class":984},"v2\n",[974,2375,2376,2379,2381],{"class":976,"line":1063},[974,2377,2378],{"class":1827},"name",[974,2380,1832],{"class":1831},[974,2382,2383],{"class":984},"mychart\n",[974,2385,2386,2389,2391],{"class":976,"line":1080},[974,2387,2388],{"class":1827},"description",[974,2390,1832],{"class":1831},[974,2392,2393],{"class":984},"A Helm chart for my application\n",[974,2395,2396,2399,2401],{"class":976,"line":1087},[974,2397,2398],{"class":1827},"type",[974,2400,1832],{"class":1831},[974,2402,2403],{"class":984},"application\n",[974,2405,2406,2409,2411,2414],{"class":976,"line":1093},[974,2407,2408],{"class":1827},"version",[974,2410,1832],{"class":1831},[974,2412,2413],{"class":1240},"0.1.0",[974,2415,2416],{"class":1059},"        # Chart 版本\n",[974,2418,2419,2422,2424,2427],{"class":976,"line":1108},[974,2420,2421],{"class":1827},"appVersion",[974,2423,1832],{"class":1831},[974,2425,2426],{"class":984},"\"1.0.0\"",[974,2428,2429],{"class":1059},"   # 应用版本\n",[974,2431,2432],{"class":976,"line":1113},[974,2433,1084],{"emptyLinePlaceholder":1083},[974,2435,2436,2439],{"class":976,"line":1119},[974,2437,2438],{"class":1827},"keywords",[974,2440,1851],{"class":1831},[974,2442,2443,2446],{"class":976,"line":1129},[974,2444,2445],{"class":1831},"  - ",[974,2447,2448],{"class":984},"web\n",[974,2450,2451,2453],{"class":976,"line":1134},[974,2452,2445],{"class":1831},[974,2454,2058],{"class":984},[974,2456,2457],{"class":976,"line":1140},[974,2458,1084],{"emptyLinePlaceholder":1083},[974,2460,2461,2464,2466],{"class":976,"line":1150},[974,2462,2463],{"class":1827},"home",[974,2465,1832],{"class":1831},[974,2467,2468],{"class":984},"https:\u002F\u002Fgithub.com\u002Fexample\u002Fmychart\n",[974,2470,2471,2474],{"class":976,"line":1155},[974,2472,2473],{"class":1827},"sources",[974,2475,1851],{"class":1831},[974,2477,2478,2480],{"class":976,"line":1161},[974,2479,2445],{"class":1831},[974,2481,2468],{"class":984},[974,2483,2484],{"class":976,"line":1371},[974,2485,1084],{"emptyLinePlaceholder":1083},[974,2487,2488,2491],{"class":976,"line":1376},[974,2489,2490],{"class":1827},"maintainers",[974,2492,1851],{"class":1831},[974,2494,2495,2497,2499,2501],{"class":976,"line":1382},[974,2496,2445],{"class":1831},[974,2498,2378],{"class":1827},[974,2500,1832],{"class":1831},[974,2502,2503],{"class":984},"John Doe\n",[974,2505,2506,2509,2511],{"class":976,"line":1394},[974,2507,2508],{"class":1827},"    email",[974,2510,1832],{"class":1831},[974,2512,2513],{"class":984},"john@example.com\n",[974,2515,2516],{"class":976,"line":1399},[974,2517,1084],{"emptyLinePlaceholder":1083},[974,2519,2520,2523],{"class":976,"line":1405},[974,2521,2522],{"class":1827},"dependencies",[974,2524,1851],{"class":1831},[974,2526,2527,2529,2531,2533],{"class":976,"line":1973},[974,2528,2445],{"class":1831},[974,2530,2378],{"class":1827},[974,2532,1832],{"class":1831},[974,2534,2535],{"class":984},"mysql\n",[974,2537,2538,2541,2543],{"class":976,"line":1981},[974,2539,2540],{"class":1827},"    version",[974,2542,1832],{"class":1831},[974,2544,2545],{"class":984},"\"9.0.0\"\n",[974,2547,2548,2551,2553],{"class":976,"line":1991},[974,2549,2550],{"class":1827},"    repository",[974,2552,1832],{"class":1831},[974,2554,2555],{"class":984},"https:\u002F\u002Fcharts.bitnami.com\u002Fbitnami\n",[974,2557,2558,2561,2563],{"class":976,"line":2001},[974,2559,2560],{"class":1827},"    condition",[974,2562,1832],{"class":1831},[974,2564,2565],{"class":984},"mysql.enabled\n",[900,2567,2569],{"id":2568},"valuesyaml","values.yaml",[965,2571,2573],{"className":1813,"code":2572,"language":1815,"meta":11,"style":11},"# 应用名称\nnameOverride: \"\"\nfullnameOverride: \"\"\n\n# 副本数\nreplicaCount: 1\n\n# 镜像配置\nimage:\n  repository: nginx\n  tag: \"1.21\"\n  pullPolicy: IfNotPresent\n\n# 服务配置\nservice:\n  type: ClusterIP\n  port: 80\n\n# Ingress 配置\ningress:\n  enabled: false\n  className: nginx\n  hosts:\n    - host: chart-example.local\n      paths:\n        - path: \u002F\n          pathType: Prefix\n\n# 资源配置\nresources:\n  limits:\n    cpu: 100m\n    memory: 128Mi\n  requests:\n    cpu: 50m\n    memory: 64Mi\n\n# 自动扩缩\nautoscaling:\n  enabled: false\n  minReplicas: 1\n  maxReplicas: 10\n  targetCPUUtilizationPercentage: 80\n\n# 节点选择\nnodeSelector: {}\n\n# 容忍\ntolerations: []\n\n# 亲和性\naffinity: {}\n",[971,2574,2575,2580,2590,2599,2603,2607,2616,2620,2624,2630,2638,2647,2657,2661,2665,2671,2680,2688,2692,2697,2703,2712,2721,2728,2741,2748,2761,2771,2775,2780,2786,2793,2802,2811,2818,2828,2838,2843,2849,2857,2866,2876,2887,2897,2902,2908,2917,2922,2928,2937,2942,2948],{"__ignoreMap":11},[974,2576,2577],{"class":976,"line":977},[974,2578,2579],{"class":1059},"# 应用名称\n",[974,2581,2582,2585,2587],{"class":976,"line":1063},[974,2583,2584],{"class":1827},"nameOverride",[974,2586,1832],{"class":1831},[974,2588,2589],{"class":984},"\"\"\n",[974,2591,2592,2595,2597],{"class":976,"line":1080},[974,2593,2594],{"class":1827},"fullnameOverride",[974,2596,1832],{"class":1831},[974,2598,2589],{"class":984},[974,2600,2601],{"class":976,"line":1087},[974,2602,1084],{"emptyLinePlaceholder":1083},[974,2604,2605],{"class":976,"line":1093},[974,2606,1822],{"class":1059},[974,2608,2609,2611,2613],{"class":976,"line":1108},[974,2610,1828],{"class":1827},[974,2612,1832],{"class":1831},[974,2614,2615],{"class":1240},"1\n",[974,2617,2618],{"class":976,"line":1113},[974,2619,1084],{"emptyLinePlaceholder":1083},[974,2621,2622],{"class":976,"line":1119},[974,2623,1843],{"class":1059},[974,2625,2626,2628],{"class":976,"line":1129},[974,2627,1848],{"class":1827},[974,2629,1851],{"class":1831},[974,2631,2632,2634,2636],{"class":976,"line":1134},[974,2633,1866],{"class":1827},[974,2635,1832],{"class":1831},[974,2637,2058],{"class":984},[974,2639,2640,2642,2644],{"class":976,"line":1140},[974,2641,1876],{"class":1827},[974,2643,1832],{"class":1831},[974,2645,2646],{"class":984},"\"1.21\"\n",[974,2648,2649,2652,2654],{"class":976,"line":1150},[974,2650,2651],{"class":1827},"  pullPolicy",[974,2653,1832],{"class":1831},[974,2655,2656],{"class":984},"IfNotPresent\n",[974,2658,2659],{"class":976,"line":1155},[974,2660,1084],{"emptyLinePlaceholder":1083},[974,2662,2663],{"class":976,"line":1161},[974,2664,1890],{"class":1059},[974,2666,2667,2669],{"class":976,"line":1371},[974,2668,1895],{"class":1827},[974,2670,1851],{"class":1831},[974,2672,2673,2675,2677],{"class":976,"line":1376},[974,2674,1902],{"class":1827},[974,2676,1832],{"class":1831},[974,2678,2679],{"class":984},"ClusterIP\n",[974,2681,2682,2684,2686],{"class":976,"line":1382},[974,2683,1912],{"class":1827},[974,2685,1832],{"class":1831},[974,2687,1917],{"class":1240},[974,2689,2690],{"class":976,"line":1394},[974,2691,1084],{"emptyLinePlaceholder":1083},[974,2693,2694],{"class":976,"line":1399},[974,2695,2696],{"class":1059},"# Ingress 配置\n",[974,2698,2699,2701],{"class":976,"line":1405},[974,2700,2015],{"class":1827},[974,2702,1851],{"class":1831},[974,2704,2705,2707,2709],{"class":976,"line":1973},[974,2706,2023],{"class":1827},[974,2708,1832],{"class":1831},[974,2710,2711],{"class":1240},"false\n",[974,2713,2714,2717,2719],{"class":976,"line":1981},[974,2715,2716],{"class":1827},"  className",[974,2718,1832],{"class":1831},[974,2720,2058],{"class":984},[974,2722,2723,2726],{"class":976,"line":1991},[974,2724,2725],{"class":1827},"  hosts",[974,2727,1851],{"class":1831},[974,2729,2730,2733,2736,2738],{"class":976,"line":2001},[974,2731,2732],{"class":1831},"    - ",[974,2734,2735],{"class":1827},"host",[974,2737,1832],{"class":1831},[974,2739,2740],{"class":984},"chart-example.local\n",[974,2742,2743,2746],{"class":976,"line":2006},[974,2744,2745],{"class":1827},"      paths",[974,2747,1851],{"class":1831},[974,2749,2750,2753,2756,2758],{"class":976,"line":2012},[974,2751,2752],{"class":1831},"        - ",[974,2754,2755],{"class":1827},"path",[974,2757,1832],{"class":1831},[974,2759,2760],{"class":984},"\u002F\n",[974,2762,2763,2766,2768],{"class":976,"line":2020},[974,2764,2765],{"class":1827},"          pathType",[974,2767,1832],{"class":1831},[974,2769,2770],{"class":984},"Prefix\n",[974,2772,2773],{"class":976,"line":2031},[974,2774,1084],{"emptyLinePlaceholder":1083},[974,2776,2777],{"class":976,"line":2042},[974,2778,2779],{"class":1059},"# 资源配置\n",[974,2781,2782,2784],{"class":976,"line":2050},[974,2783,1941],{"class":1827},[974,2785,1851],{"class":1831},[974,2787,2789,2791],{"class":976,"line":2788},31,[974,2790,1948],{"class":1827},[974,2792,1851],{"class":1831},[974,2794,2796,2798,2800],{"class":976,"line":2795},32,[974,2797,1955],{"class":1827},[974,2799,1832],{"class":1831},[974,2801,1988],{"class":984},[974,2803,2805,2807,2809],{"class":976,"line":2804},33,[974,2806,1965],{"class":1827},[974,2808,1832],{"class":1831},[974,2810,1998],{"class":984},[974,2812,2814,2816],{"class":976,"line":2813},34,[974,2815,1976],{"class":1827},[974,2817,1851],{"class":1831},[974,2819,2821,2823,2825],{"class":976,"line":2820},35,[974,2822,1955],{"class":1827},[974,2824,1832],{"class":1831},[974,2826,2827],{"class":984},"50m\n",[974,2829,2831,2833,2835],{"class":976,"line":2830},36,[974,2832,1965],{"class":1827},[974,2834,1832],{"class":1831},[974,2836,2837],{"class":984},"64Mi\n",[974,2839,2841],{"class":976,"line":2840},37,[974,2842,1084],{"emptyLinePlaceholder":1083},[974,2844,2846],{"class":976,"line":2845},38,[974,2847,2848],{"class":1059},"# 自动扩缩\n",[974,2850,2852,2855],{"class":976,"line":2851},39,[974,2853,2854],{"class":1827},"autoscaling",[974,2856,1851],{"class":1831},[974,2858,2860,2862,2864],{"class":976,"line":2859},40,[974,2861,2023],{"class":1827},[974,2863,1832],{"class":1831},[974,2865,2711],{"class":1240},[974,2867,2869,2872,2874],{"class":976,"line":2868},41,[974,2870,2871],{"class":1827},"  minReplicas",[974,2873,1832],{"class":1831},[974,2875,2615],{"class":1240},[974,2877,2879,2882,2884],{"class":976,"line":2878},42,[974,2880,2881],{"class":1827},"  maxReplicas",[974,2883,1832],{"class":1831},[974,2885,2886],{"class":1240},"10\n",[974,2888,2890,2893,2895],{"class":976,"line":2889},43,[974,2891,2892],{"class":1827},"  targetCPUUtilizationPercentage",[974,2894,1832],{"class":1831},[974,2896,1917],{"class":1240},[974,2898,2900],{"class":976,"line":2899},44,[974,2901,1084],{"emptyLinePlaceholder":1083},[974,2903,2905],{"class":976,"line":2904},45,[974,2906,2907],{"class":1059},"# 节点选择\n",[974,2909,2911,2914],{"class":976,"line":2910},46,[974,2912,2913],{"class":1827},"nodeSelector",[974,2915,2916],{"class":1831},": {}\n",[974,2918,2920],{"class":976,"line":2919},47,[974,2921,1084],{"emptyLinePlaceholder":1083},[974,2923,2925],{"class":976,"line":2924},48,[974,2926,2927],{"class":1059},"# 容忍\n",[974,2929,2931,2934],{"class":976,"line":2930},49,[974,2932,2933],{"class":1827},"tolerations",[974,2935,2936],{"class":1831},": []\n",[974,2938,2940],{"class":976,"line":2939},50,[974,2941,1084],{"emptyLinePlaceholder":1083},[974,2943,2945],{"class":976,"line":2944},51,[974,2946,2947],{"class":1059},"# 亲和性\n",[974,2949,2951,2954],{"class":976,"line":2950},52,[974,2952,2953],{"class":1827},"affinity",[974,2955,2916],{"class":1831},[900,2957,2958],{"id":2958},"模板语法",[2960,2961,2962],"h4",{"id":2962},"基本语法",[965,2964,2966],{"className":1813,"code":2965,"language":1815,"meta":11,"style":11},"# templates\u002Fdeployment.yaml\napiVersion: apps\u002Fv1\nkind: Deployment\nmetadata:\n  name: {{ include \"mychart.fullname\" . }}\n  labels:\n    {{- include \"mychart.labels\" . | nindent 4 }}\nspec:\n  replicas: {{ .Values.replicaCount }}\n  selector:\n    matchLabels:\n      {{- include \"mychart.selectorLabels\" . | nindent 6 }}\n  template:\n    metadata:\n      labels:\n        {{- include \"mychart.selectorLabels\" . | nindent 8 }}\n    spec:\n      containers:\n      - name: {{ .Chart.Name }}\n        image: \"{{ .Values.image.repository }}:{{ .Values.image.tag }}\"\n        imagePullPolicy: {{ .Values.image.pullPolicy }}\n        ports:\n        - containerPort: 80\n        {{- if .Values.resources }}\n        resources:\n          {{- toYaml .Values.resources | nindent 10 }}\n        {{- end }}\n",[971,2967,2968,2973,2982,2992,2999,3013,3020,3030,3037,3049,3056,3063,3073,3080,3087,3094,3104,3111,3118,3132,3142,3154,3161,3172,3181,3188,3198],{"__ignoreMap":11},[974,2969,2970],{"class":976,"line":977},[974,2971,2972],{"class":1059},"# templates\u002Fdeployment.yaml\n",[974,2974,2975,2977,2979],{"class":976,"line":1063},[974,2976,2368],{"class":1827},[974,2978,1832],{"class":1831},[974,2980,2981],{"class":984},"apps\u002Fv1\n",[974,2983,2984,2987,2989],{"class":976,"line":1080},[974,2985,2986],{"class":1827},"kind",[974,2988,1832],{"class":1831},[974,2990,2991],{"class":984},"Deployment\n",[974,2993,2994,2997],{"class":976,"line":1087},[974,2995,2996],{"class":1827},"metadata",[974,2998,1851],{"class":1831},[974,3000,3001,3004,3007,3010],{"class":976,"line":1093},[974,3002,3003],{"class":1827},"  name",[974,3005,3006],{"class":1831},": {{ ",[974,3008,3009],{"class":984},"include \"mychart.fullname\" .",[974,3011,3012],{"class":1831}," }}\n",[974,3014,3015,3018],{"class":976,"line":1108},[974,3016,3017],{"class":1827},"  labels",[974,3019,1851],{"class":1831},[974,3021,3022,3025,3028],{"class":976,"line":1113},[974,3023,3024],{"class":1831},"    {{- ",[974,3026,3027],{"class":984},"include \"mychart.labels\" . | nindent 4",[974,3029,3012],{"class":1831},[974,3031,3032,3035],{"class":976,"line":1119},[974,3033,3034],{"class":1827},"spec",[974,3036,1851],{"class":1831},[974,3038,3039,3042,3044,3047],{"class":976,"line":1129},[974,3040,3041],{"class":1827},"  replicas",[974,3043,3006],{"class":1831},[974,3045,3046],{"class":984},".Values.replicaCount",[974,3048,3012],{"class":1831},[974,3050,3051,3054],{"class":976,"line":1134},[974,3052,3053],{"class":1827},"  selector",[974,3055,1851],{"class":1831},[974,3057,3058,3061],{"class":976,"line":1140},[974,3059,3060],{"class":1827},"    matchLabels",[974,3062,1851],{"class":1831},[974,3064,3065,3068,3071],{"class":976,"line":1150},[974,3066,3067],{"class":1831},"      {{- ",[974,3069,3070],{"class":984},"include \"mychart.selectorLabels\" . | nindent 6",[974,3072,3012],{"class":1831},[974,3074,3075,3078],{"class":976,"line":1155},[974,3076,3077],{"class":1827},"  template",[974,3079,1851],{"class":1831},[974,3081,3082,3085],{"class":976,"line":1161},[974,3083,3084],{"class":1827},"    metadata",[974,3086,1851],{"class":1831},[974,3088,3089,3092],{"class":976,"line":1371},[974,3090,3091],{"class":1827},"      labels",[974,3093,1851],{"class":1831},[974,3095,3096,3099,3102],{"class":976,"line":1376},[974,3097,3098],{"class":1831},"        {{- ",[974,3100,3101],{"class":984},"include \"mychart.selectorLabels\" . | nindent 8",[974,3103,3012],{"class":1831},[974,3105,3106,3109],{"class":976,"line":1382},[974,3107,3108],{"class":1827},"    spec",[974,3110,1851],{"class":1831},[974,3112,3113,3116],{"class":976,"line":1394},[974,3114,3115],{"class":1827},"      containers",[974,3117,1851],{"class":1831},[974,3119,3120,3123,3125,3127,3130],{"class":976,"line":1399},[974,3121,3122],{"class":1831},"      - ",[974,3124,2378],{"class":1827},[974,3126,3006],{"class":1831},[974,3128,3129],{"class":984},".Chart.Name",[974,3131,3012],{"class":1831},[974,3133,3134,3137,3139],{"class":976,"line":1405},[974,3135,3136],{"class":1827},"        image",[974,3138,1832],{"class":1831},[974,3140,3141],{"class":984},"\"{{ .Values.image.repository }}:{{ .Values.image.tag }}\"\n",[974,3143,3144,3147,3149,3152],{"class":976,"line":1973},[974,3145,3146],{"class":1827},"        imagePullPolicy",[974,3148,3006],{"class":1831},[974,3150,3151],{"class":984},".Values.image.pullPolicy",[974,3153,3012],{"class":1831},[974,3155,3156,3159],{"class":976,"line":1981},[974,3157,3158],{"class":1827},"        ports",[974,3160,1851],{"class":1831},[974,3162,3163,3165,3168,3170],{"class":976,"line":1991},[974,3164,2752],{"class":1831},[974,3166,3167],{"class":1827},"containerPort",[974,3169,1832],{"class":1831},[974,3171,1917],{"class":1240},[974,3173,3174,3176,3179],{"class":976,"line":2001},[974,3175,3098],{"class":1831},[974,3177,3178],{"class":984},"if .Values.resources",[974,3180,3012],{"class":1831},[974,3182,3183,3186],{"class":976,"line":2006},[974,3184,3185],{"class":1827},"        resources",[974,3187,1851],{"class":1831},[974,3189,3190,3193,3196],{"class":976,"line":2012},[974,3191,3192],{"class":1831},"          {{- ",[974,3194,3195],{"class":984},"toYaml .Values.resources | nindent 10",[974,3197,3012],{"class":1831},[974,3199,3200,3202,3205],{"class":976,"line":2020},[974,3201,3098],{"class":1831},[974,3203,3204],{"class":984},"end",[974,3206,3012],{"class":1831},[2960,3208,3209],{"id":3209},"条件判断",[965,3211,3213],{"className":1813,"code":3212,"language":1815,"meta":11,"style":11},"{{- if .Values.ingress.enabled }}\napiVersion: networking.k8s.io\u002Fv1\nkind: Ingress\nmetadata:\n  name: {{ include \"mychart.fullname\" . }}\nspec:\n  # ...\n{{- end }}\n",[971,3214,3215,3225,3234,3243,3249,3259,3265,3270],{"__ignoreMap":11},[974,3216,3217,3220,3223],{"class":976,"line":977},[974,3218,3219],{"class":1831},"{{- ",[974,3221,3222],{"class":984},"if .Values.ingress.enabled",[974,3224,3012],{"class":1831},[974,3226,3227,3229,3231],{"class":976,"line":1063},[974,3228,2368],{"class":1827},[974,3230,1832],{"class":1831},[974,3232,3233],{"class":984},"networking.k8s.io\u002Fv1\n",[974,3235,3236,3238,3240],{"class":976,"line":1080},[974,3237,2986],{"class":1827},[974,3239,1832],{"class":1831},[974,3241,3242],{"class":984},"Ingress\n",[974,3244,3245,3247],{"class":976,"line":1087},[974,3246,2996],{"class":1827},[974,3248,1851],{"class":1831},[974,3250,3251,3253,3255,3257],{"class":976,"line":1093},[974,3252,3003],{"class":1827},[974,3254,3006],{"class":1831},[974,3256,3009],{"class":984},[974,3258,3012],{"class":1831},[974,3260,3261,3263],{"class":976,"line":1108},[974,3262,3034],{"class":1827},[974,3264,1851],{"class":1831},[974,3266,3267],{"class":976,"line":1113},[974,3268,3269],{"class":1059},"  # ...\n",[974,3271,3272,3274,3276],{"class":976,"line":1119},[974,3273,3219],{"class":1831},[974,3275,3204],{"class":984},[974,3277,3012],{"class":1831},[2960,3279,3280],{"id":3280},"循环",[965,3282,3284],{"className":1813,"code":3283,"language":1815,"meta":11,"style":11},"{{- range .Values.ingress.hosts }}\n- host: {{ .host }}\n  http:\n    paths:\n    {{- range .paths }}\n    - path: {{ .path }}\n      pathType: {{ .pathType }}\n    {{- end }}\n{{- end }}\n",[971,3285,3286,3295,3309,3316,3323,3332,3345,3357,3365],{"__ignoreMap":11},[974,3287,3288,3290,3293],{"class":976,"line":977},[974,3289,3219],{"class":1831},[974,3291,3292],{"class":984},"range .Values.ingress.hosts",[974,3294,3012],{"class":1831},[974,3296,3297,3300,3302,3304,3307],{"class":976,"line":1063},[974,3298,3299],{"class":1831},"- ",[974,3301,2735],{"class":1827},[974,3303,3006],{"class":1831},[974,3305,3306],{"class":984},".host",[974,3308,3012],{"class":1831},[974,3310,3311,3314],{"class":976,"line":1080},[974,3312,3313],{"class":1827},"  http",[974,3315,1851],{"class":1831},[974,3317,3318,3321],{"class":976,"line":1087},[974,3319,3320],{"class":1827},"    paths",[974,3322,1851],{"class":1831},[974,3324,3325,3327,3330],{"class":976,"line":1093},[974,3326,3024],{"class":1831},[974,3328,3329],{"class":984},"range .paths",[974,3331,3012],{"class":1831},[974,3333,3334,3336,3338,3340,3343],{"class":976,"line":1108},[974,3335,2732],{"class":1831},[974,3337,2755],{"class":1827},[974,3339,3006],{"class":1831},[974,3341,3342],{"class":984},".path",[974,3344,3012],{"class":1831},[974,3346,3347,3350,3352,3355],{"class":976,"line":1113},[974,3348,3349],{"class":1827},"      pathType",[974,3351,3006],{"class":1831},[974,3353,3354],{"class":984},".pathType",[974,3356,3012],{"class":1831},[974,3358,3359,3361,3363],{"class":976,"line":1119},[974,3360,3024],{"class":1831},[974,3362,3204],{"class":984},[974,3364,3012],{"class":1831},[974,3366,3367,3369,3371],{"class":976,"line":1129},[974,3368,3219],{"class":1831},[974,3370,3204],{"class":984},[974,3372,3012],{"class":1831},[2960,3374,3375],{"id":3375},"辅助模板",[965,3377,3379],{"className":1813,"code":3378,"language":1815,"meta":11,"style":11},"# templates\u002F_helpers.tpl\n{{- define \"mychart.fullname\" -}}\n{{- if .Values.fullnameOverride }}\n{{- .Values.fullnameOverride | trunc 63 | trimSuffix \"-\" }}\n{{- else }}\n{{- $name := default .Chart.Name .Values.nameOverride }}\n{{- printf \"%s-%s\" .Release.Name $name | trunc 63 | trimSuffix \"-\" }}\n{{- end }}\n{{- end }}\n\n{{- define \"mychart.labels\" -}}\nhelm.sh\u002Fchart: {{ .Chart.Name }}-{{ .Chart.Version }}\napp.kubernetes.io\u002Fname: {{ include \"mychart.name\" . }}\napp.kubernetes.io\u002Finstance: {{ .Release.Name }}\napp.kubernetes.io\u002Fversion: {{ .Chart.AppVersion | quote }}\napp.kubernetes.io\u002Fmanaged-by: {{ .Release.Service }}\n{{- end }}\n",[971,3380,3381,3386,3396,3405,3414,3423,3432,3441,3449,3457,3461,3470,3485,3497,3509,3521,3533],{"__ignoreMap":11},[974,3382,3383],{"class":976,"line":977},[974,3384,3385],{"class":1059},"# templates\u002F_helpers.tpl\n",[974,3387,3388,3390,3393],{"class":976,"line":1063},[974,3389,3219],{"class":1831},[974,3391,3392],{"class":984},"define \"mychart.fullname\" -",[974,3394,3395],{"class":1831},"}}\n",[974,3397,3398,3400,3403],{"class":976,"line":1080},[974,3399,3219],{"class":1831},[974,3401,3402],{"class":984},"if .Values.fullnameOverride",[974,3404,3012],{"class":1831},[974,3406,3407,3409,3412],{"class":976,"line":1087},[974,3408,3219],{"class":1831},[974,3410,3411],{"class":984},".Values.fullnameOverride | trunc 63 | trimSuffix \"-\"",[974,3413,3012],{"class":1831},[974,3415,3416,3418,3421],{"class":976,"line":1093},[974,3417,3219],{"class":1831},[974,3419,3420],{"class":984},"else",[974,3422,3012],{"class":1831},[974,3424,3425,3427,3430],{"class":976,"line":1108},[974,3426,3219],{"class":1831},[974,3428,3429],{"class":984},"$name := default .Chart.Name .Values.nameOverride",[974,3431,3012],{"class":1831},[974,3433,3434,3436,3439],{"class":976,"line":1113},[974,3435,3219],{"class":1831},[974,3437,3438],{"class":984},"printf \"%s-%s\" .Release.Name $name | trunc 63 | trimSuffix \"-\"",[974,3440,3012],{"class":1831},[974,3442,3443,3445,3447],{"class":976,"line":1119},[974,3444,3219],{"class":1831},[974,3446,3204],{"class":984},[974,3448,3012],{"class":1831},[974,3450,3451,3453,3455],{"class":976,"line":1129},[974,3452,3219],{"class":1831},[974,3454,3204],{"class":984},[974,3456,3012],{"class":1831},[974,3458,3459],{"class":976,"line":1134},[974,3460,1084],{"emptyLinePlaceholder":1083},[974,3462,3463,3465,3468],{"class":976,"line":1140},[974,3464,3219],{"class":1831},[974,3466,3467],{"class":984},"define \"mychart.labels\" -",[974,3469,3395],{"class":1831},[974,3471,3472,3475,3477,3479,3482],{"class":976,"line":1150},[974,3473,3474],{"class":1827},"helm.sh\u002Fchart",[974,3476,3006],{"class":1831},[974,3478,3129],{"class":984},[974,3480,3481],{"class":1831}," }}",[974,3483,3484],{"class":984},"-{{ .Chart.Version }}\n",[974,3486,3487,3490,3492,3495],{"class":976,"line":1155},[974,3488,3489],{"class":1827},"app.kubernetes.io\u002Fname",[974,3491,3006],{"class":1831},[974,3493,3494],{"class":984},"include \"mychart.name\" .",[974,3496,3012],{"class":1831},[974,3498,3499,3502,3504,3507],{"class":976,"line":1161},[974,3500,3501],{"class":1827},"app.kubernetes.io\u002Finstance",[974,3503,3006],{"class":1831},[974,3505,3506],{"class":984},".Release.Name",[974,3508,3012],{"class":1831},[974,3510,3511,3514,3516,3519],{"class":976,"line":1371},[974,3512,3513],{"class":1827},"app.kubernetes.io\u002Fversion",[974,3515,3006],{"class":1831},[974,3517,3518],{"class":984},".Chart.AppVersion | quote",[974,3520,3012],{"class":1831},[974,3522,3523,3526,3528,3531],{"class":976,"line":1376},[974,3524,3525],{"class":1827},"app.kubernetes.io\u002Fmanaged-by",[974,3527,3006],{"class":1831},[974,3529,3530],{"class":984},".Release.Service",[974,3532,3012],{"class":1831},[974,3534,3535,3537,3539],{"class":976,"line":1382},[974,3536,3219],{"class":1831},[974,3538,3204],{"class":984},[974,3540,3012],{"class":1831},[900,3542,3543],{"id":3543},"内置对象",[904,3545,3546,3555],{},[907,3547,3548],{},[910,3549,3550,3553],{},[913,3551,3552],{"align":915},"对象",[913,3554,919],{"align":915},[921,3556,3557,3565,3573,3581,3589,3597],{},[910,3558,3559,3562],{},[926,3560,3561],{"align":915},".Values",[926,3563,3564],{"align":915},"values.yaml 中的配置",[910,3566,3567,3570],{},[926,3568,3569],{"align":915},".Release",[926,3571,3572],{"align":915},"Release 信息（Name、Namespace 等）",[910,3574,3575,3578],{},[926,3576,3577],{"align":915},".Chart",[926,3579,3580],{"align":915},"Chart.yaml 中的信息",[910,3582,3583,3586],{},[926,3584,3585],{"align":915},".Files",[926,3587,3588],{"align":915},"访问 Chart 中的文件",[910,3590,3591,3594],{},[926,3592,3593],{"align":915},".Capabilities",[926,3595,3596],{"align":915},"集群能力信息",[910,3598,3599,3602],{},[926,3600,3601],{"align":915},".Template",[926,3603,3604],{"align":915},"当前模板信息",[892,3606,3608],{"id":3607},"chart-打包和发布","Chart 打包和发布",[900,3610,3612],{"id":3611},"验证-chart","验证 Chart",[965,3614,3616],{"className":967,"code":3615,"language":969,"meta":11,"style":11},"# 语法检查\nhelm lint mychart\n\n# 模板渲染预览\nhelm template my-release mychart\n\n# 模拟安装\nhelm install my-release mychart --dry-run --debug\n",[971,3617,3618,3623,3632,3636,3641,3653,3657,3662],{"__ignoreMap":11},[974,3619,3620],{"class":976,"line":977},[974,3621,3622],{"class":1059},"# 语法检查\n",[974,3624,3625,3627,3630],{"class":976,"line":1063},[974,3626,1040],{"class":980},[974,3628,3629],{"class":984}," lint",[974,3631,2205],{"class":984},[974,3633,3634],{"class":976,"line":1080},[974,3635,1084],{"emptyLinePlaceholder":1083},[974,3637,3638],{"class":976,"line":1087},[974,3639,3640],{"class":1059},"# 模板渲染预览\n",[974,3642,3643,3645,3648,3651],{"class":976,"line":1093},[974,3644,1040],{"class":980},[974,3646,3647],{"class":984}," template",[974,3649,3650],{"class":984}," my-release",[974,3652,2205],{"class":984},[974,3654,3655],{"class":976,"line":1108},[974,3656,1084],{"emptyLinePlaceholder":1083},[974,3658,3659],{"class":976,"line":1113},[974,3660,3661],{"class":1059},"# 模拟安装\n",[974,3663,3664,3666,3668,3670,3673,3676],{"class":976,"line":1119},[974,3665,1040],{"class":980},[974,3667,985],{"class":984},[974,3669,3650],{"class":984},[974,3671,3672],{"class":984}," mychart",[974,3674,3675],{"class":1240}," --dry-run",[974,3677,3678],{"class":1240}," --debug\n",[900,3680,3682],{"id":3681},"打包-chart","打包 Chart",[965,3684,3686],{"className":967,"code":3685,"language":969,"meta":11,"style":11},"# 打包\nhelm package mychart\n\n# 输出：mychart-0.1.0.tgz\n",[971,3687,3688,3693,3702,3706],{"__ignoreMap":11},[974,3689,3690],{"class":976,"line":977},[974,3691,3692],{"class":1059},"# 打包\n",[974,3694,3695,3697,3700],{"class":976,"line":1063},[974,3696,1040],{"class":980},[974,3698,3699],{"class":984}," package",[974,3701,2205],{"class":984},[974,3703,3704],{"class":976,"line":1080},[974,3705,1084],{"emptyLinePlaceholder":1083},[974,3707,3708],{"class":976,"line":1087},[974,3709,3710],{"class":1059},"# 输出：mychart-0.1.0.tgz\n",[900,3712,3713],{"id":3713},"发布到仓库",[965,3715,3717],{"className":967,"code":3716,"language":969,"meta":11,"style":11},"# 创建本地仓库\nhelm repo index . --url https:\u002F\u002Fcharts.example.com\n\n# 上传到 GitHub Pages、S3 等\n",[971,3718,3719,3724,3742,3746],{"__ignoreMap":11},[974,3720,3721],{"class":976,"line":977},[974,3722,3723],{"class":1059},"# 创建本地仓库\n",[974,3725,3726,3728,3730,3733,3736,3739],{"class":976,"line":1063},[974,3727,1040],{"class":980},[974,3729,1068],{"class":984},[974,3731,3732],{"class":984}," index",[974,3734,3735],{"class":984}," .",[974,3737,3738],{"class":1240}," --url",[974,3740,3741],{"class":984}," https:\u002F\u002Fcharts.example.com\n",[974,3743,3744],{"class":976,"line":1080},[974,3745,1084],{"emptyLinePlaceholder":1083},[974,3747,3748],{"class":976,"line":1087},[974,3749,3750],{"class":1059},"# 上传到 GitHub Pages、S3 等\n",[892,3752,3753],{"id":3753},"依赖管理",[900,3755,3756],{"id":3756},"定义依赖",[896,3758,3759,3760,3762],{},"在 ",[971,3761,2358],{}," 中：",[965,3764,3766],{"className":1813,"code":3765,"language":1815,"meta":11,"style":11},"dependencies:\n  - name: mysql\n    version: \"9.x.x\"\n    repository: https:\u002F\u002Fcharts.bitnami.com\u002Fbitnami\n  - name: redis\n    version: \"17.x.x\"\n    repository: https:\u002F\u002Fcharts.bitnami.com\u002Fbitnami\n    condition: redis.enabled\n",[971,3767,3768,3774,3784,3793,3801,3812,3821,3829],{"__ignoreMap":11},[974,3769,3770,3772],{"class":976,"line":977},[974,3771,2522],{"class":1827},[974,3773,1851],{"class":1831},[974,3775,3776,3778,3780,3782],{"class":976,"line":1063},[974,3777,2445],{"class":1831},[974,3779,2378],{"class":1827},[974,3781,1832],{"class":1831},[974,3783,2535],{"class":984},[974,3785,3786,3788,3790],{"class":976,"line":1080},[974,3787,2540],{"class":1827},[974,3789,1832],{"class":1831},[974,3791,3792],{"class":984},"\"9.x.x\"\n",[974,3794,3795,3797,3799],{"class":976,"line":1087},[974,3796,2550],{"class":1827},[974,3798,1832],{"class":1831},[974,3800,2555],{"class":984},[974,3802,3803,3805,3807,3809],{"class":976,"line":1093},[974,3804,2445],{"class":1831},[974,3806,2378],{"class":1827},[974,3808,1832],{"class":1831},[974,3810,3811],{"class":984},"redis\n",[974,3813,3814,3816,3818],{"class":976,"line":1108},[974,3815,2540],{"class":1827},[974,3817,1832],{"class":1831},[974,3819,3820],{"class":984},"\"17.x.x\"\n",[974,3822,3823,3825,3827],{"class":976,"line":1113},[974,3824,2550],{"class":1827},[974,3826,1832],{"class":1831},[974,3828,2555],{"class":984},[974,3830,3831,3833,3835],{"class":976,"line":1119},[974,3832,2560],{"class":1827},[974,3834,1832],{"class":1831},[974,3836,3837],{"class":984},"redis.enabled\n",[900,3839,3840],{"id":3840},"管理依赖",[965,3842,3844],{"className":967,"code":3843,"language":969,"meta":11,"style":11},"# 下载依赖\nhelm dependency update mychart\n\n# 查看依赖\nhelm dependency list mychart\n\n# 重新构建依赖\nhelm dependency build mychart\n",[971,3845,3846,3851,3863,3867,3872,3882,3886,3891],{"__ignoreMap":11},[974,3847,3848],{"class":976,"line":977},[974,3849,3850],{"class":1059},"# 下载依赖\n",[974,3852,3853,3855,3858,3861],{"class":976,"line":1063},[974,3854,1040],{"class":980},[974,3856,3857],{"class":984}," dependency",[974,3859,3860],{"class":984}," update",[974,3862,2205],{"class":984},[974,3864,3865],{"class":976,"line":1080},[974,3866,1084],{"emptyLinePlaceholder":1083},[974,3868,3869],{"class":976,"line":1087},[974,3870,3871],{"class":1059},"# 查看依赖\n",[974,3873,3874,3876,3878,3880],{"class":976,"line":1093},[974,3875,1040],{"class":980},[974,3877,3857],{"class":984},[974,3879,1459],{"class":984},[974,3881,2205],{"class":984},[974,3883,3884],{"class":976,"line":1108},[974,3885,1084],{"emptyLinePlaceholder":1083},[974,3887,3888],{"class":976,"line":1113},[974,3889,3890],{"class":1059},"# 重新构建依赖\n",[974,3892,3893,3895,3897,3900],{"class":976,"line":1119},[974,3894,1040],{"class":980},[974,3896,3857],{"class":984},[974,3898,3899],{"class":984}," build",[974,3901,2205],{"class":984},[892,3903,3904],{"id":3904},"实用技巧",[900,3906,3907],{"id":3907},"查看实际渲染的资源",[965,3909,3911],{"className":967,"code":3910,"language":969,"meta":11,"style":11},"# 查看将要部署的资源\nhelm get manifest my-release\n\n# 查看安装时的 values\nhelm get values my-release\n\n# 查看所有信息\nhelm get all my-release\n",[971,3912,3913,3918,3931,3935,3940,3950,3954,3959],{"__ignoreMap":11},[974,3914,3915],{"class":976,"line":977},[974,3916,3917],{"class":1059},"# 查看将要部署的资源\n",[974,3919,3920,3922,3925,3928],{"class":976,"line":1063},[974,3921,1040],{"class":980},[974,3923,3924],{"class":984}," get",[974,3926,3927],{"class":984}," manifest",[974,3929,3930],{"class":984}," my-release\n",[974,3932,3933],{"class":976,"line":1080},[974,3934,1084],{"emptyLinePlaceholder":1083},[974,3936,3937],{"class":976,"line":1087},[974,3938,3939],{"class":1059},"# 查看安装时的 values\n",[974,3941,3942,3944,3946,3948],{"class":976,"line":1093},[974,3943,1040],{"class":980},[974,3945,3924],{"class":984},[974,3947,1773],{"class":984},[974,3949,3930],{"class":984},[974,3951,3952],{"class":976,"line":1108},[974,3953,1084],{"emptyLinePlaceholder":1083},[974,3955,3956],{"class":976,"line":1113},[974,3957,3958],{"class":1059},"# 查看所有信息\n",[974,3960,3961,3963,3965,3968],{"class":976,"line":1119},[974,3962,1040],{"class":980},[974,3964,3924],{"class":984},[974,3966,3967],{"class":984}," all",[974,3969,3930],{"class":984},[900,3971,3972],{"id":3972},"调试模板",[965,3974,3976],{"className":967,"code":3975,"language":969,"meta":11,"style":11},"# 详细输出\nhelm install my-release mychart --debug\n\n# 只渲染特定模板\nhelm template my-release mychart -s templates\u002Fdeployment.yaml\n",[971,3977,3978,3983,3995,3999,4004],{"__ignoreMap":11},[974,3979,3980],{"class":976,"line":977},[974,3981,3982],{"class":1059},"# 详细输出\n",[974,3984,3985,3987,3989,3991,3993],{"class":976,"line":1063},[974,3986,1040],{"class":980},[974,3988,985],{"class":984},[974,3990,3650],{"class":984},[974,3992,3672],{"class":984},[974,3994,3678],{"class":1240},[974,3996,3997],{"class":976,"line":1080},[974,3998,1084],{"emptyLinePlaceholder":1083},[974,4000,4001],{"class":976,"line":1087},[974,4002,4003],{"class":1059},"# 只渲染特定模板\n",[974,4005,4006,4008,4010,4012,4014,4017],{"class":976,"line":1093},[974,4007,1040],{"class":980},[974,4009,3647],{"class":984},[974,4011,3650],{"class":984},[974,4013,3672],{"class":984},[974,4015,4016],{"class":1240}," -s",[974,4018,4019],{"class":984}," templates\u002Fdeployment.yaml\n",[900,4021,4023],{"id":4022},"从-release-导出","从 Release 导出",[965,4025,4027],{"className":967,"code":4026,"language":969,"meta":11,"style":11},"# 导出当前配置\nhelm get values my-release > current-values.yaml\n",[971,4028,4029,4034],{"__ignoreMap":11},[974,4030,4031],{"class":976,"line":977},[974,4032,4033],{"class":1059},"# 导出当前配置\n",[974,4035,4036,4038,4040,4042,4044,4046],{"class":976,"line":1063},[974,4037,1040],{"class":980},[974,4039,3924],{"class":984},[974,4041,1773],{"class":984},[974,4043,3650],{"class":984},[974,4045,1797],{"class":1008},[974,4047,4048],{"class":984}," current-values.yaml\n",[892,4050,4052],{"id":4051},"常用-chart-推荐","常用 Chart 推荐",[904,4054,4055,4067],{},[907,4056,4057],{},[910,4058,4059,4061,4064],{},[913,4060,928],{"align":915},[913,4062,4063],{"align":915},"仓库",[913,4065,4066],{"align":915},"用途",[921,4068,4069,4080,4091,4102,4113,4124,4135],{},[910,4070,4071,4074,4077],{},[926,4072,4073],{"align":915},"nginx",[926,4075,4076],{"align":915},"bitnami\u002Fnginx",[926,4078,4079],{"align":915},"Web 服务器",[910,4081,4082,4085,4088],{},[926,4083,4084],{"align":915},"mysql",[926,4086,4087],{"align":915},"bitnami\u002Fmysql",[926,4089,4090],{"align":915},"数据库",[910,4092,4093,4096,4099],{},[926,4094,4095],{"align":915},"redis",[926,4097,4098],{"align":915},"bitnami\u002Fredis",[926,4100,4101],{"align":915},"缓存",[910,4103,4104,4107,4110],{},[926,4105,4106],{"align":915},"prometheus",[926,4108,4109],{"align":915},"prometheus-community\u002Fprometheus",[926,4111,4112],{"align":915},"监控",[910,4114,4115,4118,4121],{},[926,4116,4117],{"align":915},"grafana",[926,4119,4120],{"align":915},"grafana\u002Fgrafana",[926,4122,4123],{"align":915},"可视化",[910,4125,4126,4129,4132],{},[926,4127,4128],{"align":915},"cert-manager",[926,4130,4131],{"align":915},"jetstack\u002Fcert-manager",[926,4133,4134],{"align":915},"证书管理",[910,4136,4137,4140,4143],{},[926,4138,4139],{"align":915},"ingress-nginx",[926,4141,4142],{"align":915},"ingress-nginx\u002Fingress-nginx",[926,4144,4145],{"align":915},"Ingress 控制器",[892,4147,4148],{"id":4148},"总结",[904,4150,4151,4162],{},[907,4152,4153],{},[910,4154,4155,4159],{},[913,4156,4158],{"align":4157},"center","命令",[913,4160,4161],{"align":915},"作用",[921,4163,4164,4171,4178,4186,4193,4200,4207,4215,4222,4229],{},[910,4165,4166,4169],{},[926,4167,4168],{"align":4157},"helm repo add",[926,4170,1049],{"align":915},[910,4172,4173,4176],{},[926,4174,4175],{"align":4157},"helm search repo",[926,4177,1175],{"align":915},[910,4179,4180,4183],{},[926,4181,4182],{"align":4157},"helm install",[926,4184,4185],{"align":915},"安装 Release",[910,4187,4188,4191],{},[926,4189,4190],{"align":4157},"helm upgrade",[926,4192,1530],{"align":915},[910,4194,4195,4198],{},[926,4196,4197],{"align":4157},"helm rollback",[926,4199,1648],{"align":915},[910,4201,4202,4205],{},[926,4203,4204],{"align":4157},"helm uninstall",[926,4206,1708],{"align":915},[910,4208,4209,4212],{},[926,4210,4211],{"align":4157},"helm list",[926,4213,4214],{"align":915},"查看 Release 列表",[910,4216,4217,4220],{},[926,4218,4219],{"align":4157},"helm create",[926,4221,2181],{"align":915},[910,4223,4224,4227],{},[926,4225,4226],{"align":4157},"helm package",[926,4228,3682],{"align":915},[910,4230,4231,4234],{},[926,4232,4233],{"align":4157},"helm lint",[926,4235,4236],{"align":915},"检查 Chart",[4238,4239,4241],"note",{"title":4240},"最佳实践","\n1. 始终使用版本锁定 `--version`\n2. 使用 values 文件而非 `--set`\n3. 为不同环境创建不同的 values 文件\n4. 定期更新仓库索引 `helm repo update`\n5. 生产环境升级前先 `--dry-run`\n",[4243,4244,4245],"style",{},"html pre.shiki code .snPdu, html code.shiki .snPdu{--shiki-light:#6F42C1;--shiki-default:#6F42C1;--shiki-dark:#B392F0}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 .sCsY4, html code.shiki .sCsY4{--shiki-light:#6A737D;--shiki-default:#6A737D;--shiki-dark:#6A737D}html pre.shiki code .sBjJW, html code.shiki .sBjJW{--shiki-light:#005CC5;--shiki-default:#005CC5;--shiki-dark:#79B8FF}html pre.shiki code .sovSZ, html code.shiki .sovSZ{--shiki-light:#22863A;--shiki-default:#22863A;--shiki-dark:#85E89D}html pre.shiki code .sxrX7, html code.shiki .sxrX7{--shiki-light:#24292E;--shiki-default:#24292E;--shiki-dark:#E1E4E8}",{"title":11,"searchDepth":1063,"depth":1063,"links":4247},[4248,4251,4257,4266,4272,4279,4284,4288,4293,4294],{"id":894,"depth":1063,"text":894,"children":4249},[4250],{"id":902,"depth":1080,"text":902},{"id":958,"depth":1063,"text":959,"children":4252},[4253,4254,4255,4256],{"id":962,"depth":1080,"text":963},{"id":991,"depth":1080,"text":992},{"id":1015,"depth":1080,"text":1016},{"id":1030,"depth":1080,"text":1030},{"id":1046,"depth":1063,"text":1046,"children":4258},[4259,4260,4261,4262,4263,4264,4265],{"id":1049,"depth":1080,"text":1049},{"id":1174,"depth":1080,"text":1175},{"id":1244,"depth":1080,"text":1245},{"id":1419,"depth":1080,"text":1420},{"id":1529,"depth":1080,"text":1530},{"id":1647,"depth":1080,"text":1648},{"id":1707,"depth":1080,"text":1708},{"id":1750,"depth":1063,"text":1750,"children":4267},[4268,4269,4270,4271],{"id":1753,"depth":1080,"text":1753},{"id":1803,"depth":1080,"text":1803},{"id":2083,"depth":1080,"text":2084},{"id":2127,"depth":1080,"text":2127},{"id":2180,"depth":1063,"text":2181,"children":4273},[4274,4275,4276,4277,4278],{"id":2184,"depth":1080,"text":2185},{"id":2357,"depth":1080,"text":2358},{"id":2568,"depth":1080,"text":2569},{"id":2958,"depth":1080,"text":2958},{"id":3543,"depth":1080,"text":3543},{"id":3607,"depth":1063,"text":3608,"children":4280},[4281,4282,4283],{"id":3611,"depth":1080,"text":3612},{"id":3681,"depth":1080,"text":3682},{"id":3713,"depth":1080,"text":3713},{"id":3753,"depth":1063,"text":3753,"children":4285},[4286,4287],{"id":3756,"depth":1080,"text":3756},{"id":3840,"depth":1080,"text":3840},{"id":3904,"depth":1063,"text":3904,"children":4289},[4290,4291,4292],{"id":3907,"depth":1080,"text":3907},{"id":3972,"depth":1080,"text":3972},{"id":4022,"depth":1080,"text":4023},{"id":4051,"depth":1063,"text":4052},{"id":4148,"depth":1063,"text":4148},"md",{},{"title":642,"description":11},"tutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-helm","mTYlWfH_LJKfgdsJAB2kZXC61Hb8q54nsmSogCMBWvg",1775496416069]