[{"data":1,"prerenderedAt":4662},["ShallowReactive",2],{"search-docs":3,"doc-\u002Fgolang\u002Fengineering\u002Fkubernetes":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":208,"body":888,"description":209,"extension":4657,"meta":4658,"navigation":2558,"path":207,"seo":4659,"stem":4660,"__hash__":4661},"docs\u002Fgolang\u002Fengineering\u002Fkubernetes.md",{"type":889,"value":890,"toc":4630},"minimark",[891,894,898,903,1433,1437,1539,1543,1744,1748,1852,1856,1936,1939,1943,2154,2158,2236,2240,2464,2468,2472,2480,2484,2536,2540,2791,2794,3000,3004,3140,3143,3734,3737,3741,4253,4257,4380,4383,4626],[892,893,209],"p",{},[895,896,897],"h2",{"id":897},"基础资源",[899,900,902],"h3",{"id":901},"deployment","Deployment",[904,905,909],"pre",{"className":906,"code":907,"language":908,"meta":11,"style":11},"language-yaml shiki shiki-themes github-light github-light github-dark","# deployment.yaml\napiVersion: apps\u002Fv1\nkind: Deployment\nmetadata:\n  name: myapp\n  labels:\n    app: myapp\nspec:\n  replicas: 3\n  selector:\n    matchLabels:\n      app: myapp\n  template:\n    metadata:\n      labels:\n        app: myapp\n    spec:\n      containers:\n      - name: myapp\n        image: myrepo\u002Fmyapp:latest\n        ports:\n        - containerPort: 8080\n        env:\n        - name: APP_ENV\n          value: production\n        - name: DB_HOST\n          valueFrom:\n            configMapKeyRef:\n              name: myapp-config\n              key: db_host\n        - name: DB_PASSWORD\n          valueFrom:\n            secretKeyRef:\n              name: myapp-secret\n              key: db_password\n        resources:\n          requests:\n            memory: \"128Mi\"\n            cpu: \"100m\"\n          limits:\n            memory: \"256Mi\"\n            cpu: \"500m\"\n        livenessProbe:\n          httpGet:\n            path: \u002Fhealth\n            port: 8080\n          initialDelaySeconds: 15\n          periodSeconds: 10\n        readinessProbe:\n          httpGet:\n            path: \u002Fready\n            port: 8080\n          initialDelaySeconds: 5\n          periodSeconds: 5\n","yaml",[910,911,912,921,936,947,956,967,975,985,993,1005,1013,1021,1031,1039,1047,1055,1065,1073,1081,1094,1105,1113,1127,1135,1147,1158,1170,1178,1186,1197,1208,1220,1227,1235,1245,1255,1263,1271,1282,1293,1301,1311,1321,1329,1337,1348,1358,1369,1380,1388,1395,1405,1414,1424],"code",{"__ignoreMap":11},[913,914,917],"span",{"class":915,"line":916},"line",1,[913,918,920],{"class":919},"sCsY4","# deployment.yaml\n",[913,922,924,928,932],{"class":915,"line":923},2,[913,925,927],{"class":926},"sovSZ","apiVersion",[913,929,931],{"class":930},"sxrX7",": ",[913,933,935],{"class":934},"sIIMD","apps\u002Fv1\n",[913,937,939,942,944],{"class":915,"line":938},3,[913,940,941],{"class":926},"kind",[913,943,931],{"class":930},[913,945,946],{"class":934},"Deployment\n",[913,948,950,953],{"class":915,"line":949},4,[913,951,952],{"class":926},"metadata",[913,954,955],{"class":930},":\n",[913,957,959,962,964],{"class":915,"line":958},5,[913,960,961],{"class":926},"  name",[913,963,931],{"class":930},[913,965,966],{"class":934},"myapp\n",[913,968,970,973],{"class":915,"line":969},6,[913,971,972],{"class":926},"  labels",[913,974,955],{"class":930},[913,976,978,981,983],{"class":915,"line":977},7,[913,979,980],{"class":926},"    app",[913,982,931],{"class":930},[913,984,966],{"class":934},[913,986,988,991],{"class":915,"line":987},8,[913,989,990],{"class":926},"spec",[913,992,955],{"class":930},[913,994,996,999,1001],{"class":915,"line":995},9,[913,997,998],{"class":926},"  replicas",[913,1000,931],{"class":930},[913,1002,1004],{"class":1003},"sBjJW","3\n",[913,1006,1008,1011],{"class":915,"line":1007},10,[913,1009,1010],{"class":926},"  selector",[913,1012,955],{"class":930},[913,1014,1016,1019],{"class":915,"line":1015},11,[913,1017,1018],{"class":926},"    matchLabels",[913,1020,955],{"class":930},[913,1022,1024,1027,1029],{"class":915,"line":1023},12,[913,1025,1026],{"class":926},"      app",[913,1028,931],{"class":930},[913,1030,966],{"class":934},[913,1032,1034,1037],{"class":915,"line":1033},13,[913,1035,1036],{"class":926},"  template",[913,1038,955],{"class":930},[913,1040,1042,1045],{"class":915,"line":1041},14,[913,1043,1044],{"class":926},"    metadata",[913,1046,955],{"class":930},[913,1048,1050,1053],{"class":915,"line":1049},15,[913,1051,1052],{"class":926},"      labels",[913,1054,955],{"class":930},[913,1056,1058,1061,1063],{"class":915,"line":1057},16,[913,1059,1060],{"class":926},"        app",[913,1062,931],{"class":930},[913,1064,966],{"class":934},[913,1066,1068,1071],{"class":915,"line":1067},17,[913,1069,1070],{"class":926},"    spec",[913,1072,955],{"class":930},[913,1074,1076,1079],{"class":915,"line":1075},18,[913,1077,1078],{"class":926},"      containers",[913,1080,955],{"class":930},[913,1082,1084,1087,1090,1092],{"class":915,"line":1083},19,[913,1085,1086],{"class":930},"      - ",[913,1088,1089],{"class":926},"name",[913,1091,931],{"class":930},[913,1093,966],{"class":934},[913,1095,1097,1100,1102],{"class":915,"line":1096},20,[913,1098,1099],{"class":926},"        image",[913,1101,931],{"class":930},[913,1103,1104],{"class":934},"myrepo\u002Fmyapp:latest\n",[913,1106,1108,1111],{"class":915,"line":1107},21,[913,1109,1110],{"class":926},"        ports",[913,1112,955],{"class":930},[913,1114,1116,1119,1122,1124],{"class":915,"line":1115},22,[913,1117,1118],{"class":930},"        - ",[913,1120,1121],{"class":926},"containerPort",[913,1123,931],{"class":930},[913,1125,1126],{"class":1003},"8080\n",[913,1128,1130,1133],{"class":915,"line":1129},23,[913,1131,1132],{"class":926},"        env",[913,1134,955],{"class":930},[913,1136,1138,1140,1142,1144],{"class":915,"line":1137},24,[913,1139,1118],{"class":930},[913,1141,1089],{"class":926},[913,1143,931],{"class":930},[913,1145,1146],{"class":934},"APP_ENV\n",[913,1148,1150,1153,1155],{"class":915,"line":1149},25,[913,1151,1152],{"class":926},"          value",[913,1154,931],{"class":930},[913,1156,1157],{"class":934},"production\n",[913,1159,1161,1163,1165,1167],{"class":915,"line":1160},26,[913,1162,1118],{"class":930},[913,1164,1089],{"class":926},[913,1166,931],{"class":930},[913,1168,1169],{"class":934},"DB_HOST\n",[913,1171,1173,1176],{"class":915,"line":1172},27,[913,1174,1175],{"class":926},"          valueFrom",[913,1177,955],{"class":930},[913,1179,1181,1184],{"class":915,"line":1180},28,[913,1182,1183],{"class":926},"            configMapKeyRef",[913,1185,955],{"class":930},[913,1187,1189,1192,1194],{"class":915,"line":1188},29,[913,1190,1191],{"class":926},"              name",[913,1193,931],{"class":930},[913,1195,1196],{"class":934},"myapp-config\n",[913,1198,1200,1203,1205],{"class":915,"line":1199},30,[913,1201,1202],{"class":926},"              key",[913,1204,931],{"class":930},[913,1206,1207],{"class":934},"db_host\n",[913,1209,1211,1213,1215,1217],{"class":915,"line":1210},31,[913,1212,1118],{"class":930},[913,1214,1089],{"class":926},[913,1216,931],{"class":930},[913,1218,1219],{"class":934},"DB_PASSWORD\n",[913,1221,1223,1225],{"class":915,"line":1222},32,[913,1224,1175],{"class":926},[913,1226,955],{"class":930},[913,1228,1230,1233],{"class":915,"line":1229},33,[913,1231,1232],{"class":926},"            secretKeyRef",[913,1234,955],{"class":930},[913,1236,1238,1240,1242],{"class":915,"line":1237},34,[913,1239,1191],{"class":926},[913,1241,931],{"class":930},[913,1243,1244],{"class":934},"myapp-secret\n",[913,1246,1248,1250,1252],{"class":915,"line":1247},35,[913,1249,1202],{"class":926},[913,1251,931],{"class":930},[913,1253,1254],{"class":934},"db_password\n",[913,1256,1258,1261],{"class":915,"line":1257},36,[913,1259,1260],{"class":926},"        resources",[913,1262,955],{"class":930},[913,1264,1266,1269],{"class":915,"line":1265},37,[913,1267,1268],{"class":926},"          requests",[913,1270,955],{"class":930},[913,1272,1274,1277,1279],{"class":915,"line":1273},38,[913,1275,1276],{"class":926},"            memory",[913,1278,931],{"class":930},[913,1280,1281],{"class":934},"\"128Mi\"\n",[913,1283,1285,1288,1290],{"class":915,"line":1284},39,[913,1286,1287],{"class":926},"            cpu",[913,1289,931],{"class":930},[913,1291,1292],{"class":934},"\"100m\"\n",[913,1294,1296,1299],{"class":915,"line":1295},40,[913,1297,1298],{"class":926},"          limits",[913,1300,955],{"class":930},[913,1302,1304,1306,1308],{"class":915,"line":1303},41,[913,1305,1276],{"class":926},[913,1307,931],{"class":930},[913,1309,1310],{"class":934},"\"256Mi\"\n",[913,1312,1314,1316,1318],{"class":915,"line":1313},42,[913,1315,1287],{"class":926},[913,1317,931],{"class":930},[913,1319,1320],{"class":934},"\"500m\"\n",[913,1322,1324,1327],{"class":915,"line":1323},43,[913,1325,1326],{"class":926},"        livenessProbe",[913,1328,955],{"class":930},[913,1330,1332,1335],{"class":915,"line":1331},44,[913,1333,1334],{"class":926},"          httpGet",[913,1336,955],{"class":930},[913,1338,1340,1343,1345],{"class":915,"line":1339},45,[913,1341,1342],{"class":926},"            path",[913,1344,931],{"class":930},[913,1346,1347],{"class":934},"\u002Fhealth\n",[913,1349,1351,1354,1356],{"class":915,"line":1350},46,[913,1352,1353],{"class":926},"            port",[913,1355,931],{"class":930},[913,1357,1126],{"class":1003},[913,1359,1361,1364,1366],{"class":915,"line":1360},47,[913,1362,1363],{"class":926},"          initialDelaySeconds",[913,1365,931],{"class":930},[913,1367,1368],{"class":1003},"15\n",[913,1370,1372,1375,1377],{"class":915,"line":1371},48,[913,1373,1374],{"class":926},"          periodSeconds",[913,1376,931],{"class":930},[913,1378,1379],{"class":1003},"10\n",[913,1381,1383,1386],{"class":915,"line":1382},49,[913,1384,1385],{"class":926},"        readinessProbe",[913,1387,955],{"class":930},[913,1389,1391,1393],{"class":915,"line":1390},50,[913,1392,1334],{"class":926},[913,1394,955],{"class":930},[913,1396,1398,1400,1402],{"class":915,"line":1397},51,[913,1399,1342],{"class":926},[913,1401,931],{"class":930},[913,1403,1404],{"class":934},"\u002Fready\n",[913,1406,1408,1410,1412],{"class":915,"line":1407},52,[913,1409,1353],{"class":926},[913,1411,931],{"class":930},[913,1413,1126],{"class":1003},[913,1415,1417,1419,1421],{"class":915,"line":1416},53,[913,1418,1363],{"class":926},[913,1420,931],{"class":930},[913,1422,1423],{"class":1003},"5\n",[913,1425,1427,1429,1431],{"class":915,"line":1426},54,[913,1428,1374],{"class":926},[913,1430,931],{"class":930},[913,1432,1423],{"class":1003},[899,1434,1436],{"id":1435},"service","Service",[904,1438,1440],{"className":906,"code":1439,"language":908,"meta":11,"style":11},"# service.yaml\napiVersion: v1\nkind: Service\nmetadata:\n  name: myapp-service\nspec:\n  selector:\n    app: myapp\n  ports:\n  - port: 80\n    targetPort: 8080\n  type: ClusterIP\n",[910,1441,1442,1447,1456,1465,1471,1480,1486,1492,1500,1507,1520,1529],{"__ignoreMap":11},[913,1443,1444],{"class":915,"line":916},[913,1445,1446],{"class":919},"# service.yaml\n",[913,1448,1449,1451,1453],{"class":915,"line":923},[913,1450,927],{"class":926},[913,1452,931],{"class":930},[913,1454,1455],{"class":934},"v1\n",[913,1457,1458,1460,1462],{"class":915,"line":938},[913,1459,941],{"class":926},[913,1461,931],{"class":930},[913,1463,1464],{"class":934},"Service\n",[913,1466,1467,1469],{"class":915,"line":949},[913,1468,952],{"class":926},[913,1470,955],{"class":930},[913,1472,1473,1475,1477],{"class":915,"line":958},[913,1474,961],{"class":926},[913,1476,931],{"class":930},[913,1478,1479],{"class":934},"myapp-service\n",[913,1481,1482,1484],{"class":915,"line":969},[913,1483,990],{"class":926},[913,1485,955],{"class":930},[913,1487,1488,1490],{"class":915,"line":977},[913,1489,1010],{"class":926},[913,1491,955],{"class":930},[913,1493,1494,1496,1498],{"class":915,"line":987},[913,1495,980],{"class":926},[913,1497,931],{"class":930},[913,1499,966],{"class":934},[913,1501,1502,1505],{"class":915,"line":995},[913,1503,1504],{"class":926},"  ports",[913,1506,955],{"class":930},[913,1508,1509,1512,1515,1517],{"class":915,"line":1007},[913,1510,1511],{"class":930},"  - ",[913,1513,1514],{"class":926},"port",[913,1516,931],{"class":930},[913,1518,1519],{"class":1003},"80\n",[913,1521,1522,1525,1527],{"class":915,"line":1015},[913,1523,1524],{"class":926},"    targetPort",[913,1526,931],{"class":930},[913,1528,1126],{"class":1003},[913,1530,1531,1534,1536],{"class":915,"line":1023},[913,1532,1533],{"class":926},"  type",[913,1535,931],{"class":930},[913,1537,1538],{"class":934},"ClusterIP\n",[899,1540,1542],{"id":1541},"ingress","Ingress",[904,1544,1546],{"className":906,"code":1545,"language":908,"meta":11,"style":11},"# ingress.yaml\napiVersion: networking.k8s.io\u002Fv1\nkind: Ingress\nmetadata:\n  name: myapp-ingress\n  annotations:\n    nginx.ingress.kubernetes.io\u002Frewrite-target: \u002F\nspec:\n  ingressClassName: nginx\n  rules:\n  - host: myapp.example.com\n    http:\n      paths:\n      - path: \u002F\n        pathType: Prefix\n        backend:\n          service:\n            name: myapp-service\n            port:\n              number: 80\n  tls:\n  - hosts:\n    - myapp.example.com\n    secretName: myapp-tls\n",[910,1547,1548,1553,1562,1571,1577,1586,1593,1603,1609,1619,1626,1638,1645,1652,1663,1673,1680,1687,1696,1702,1711,1718,1727,1734],{"__ignoreMap":11},[913,1549,1550],{"class":915,"line":916},[913,1551,1552],{"class":919},"# ingress.yaml\n",[913,1554,1555,1557,1559],{"class":915,"line":923},[913,1556,927],{"class":926},[913,1558,931],{"class":930},[913,1560,1561],{"class":934},"networking.k8s.io\u002Fv1\n",[913,1563,1564,1566,1568],{"class":915,"line":938},[913,1565,941],{"class":926},[913,1567,931],{"class":930},[913,1569,1570],{"class":934},"Ingress\n",[913,1572,1573,1575],{"class":915,"line":949},[913,1574,952],{"class":926},[913,1576,955],{"class":930},[913,1578,1579,1581,1583],{"class":915,"line":958},[913,1580,961],{"class":926},[913,1582,931],{"class":930},[913,1584,1585],{"class":934},"myapp-ingress\n",[913,1587,1588,1591],{"class":915,"line":969},[913,1589,1590],{"class":926},"  annotations",[913,1592,955],{"class":930},[913,1594,1595,1598,1600],{"class":915,"line":977},[913,1596,1597],{"class":926},"    nginx.ingress.kubernetes.io\u002Frewrite-target",[913,1599,931],{"class":930},[913,1601,1602],{"class":934},"\u002F\n",[913,1604,1605,1607],{"class":915,"line":987},[913,1606,990],{"class":926},[913,1608,955],{"class":930},[913,1610,1611,1614,1616],{"class":915,"line":995},[913,1612,1613],{"class":926},"  ingressClassName",[913,1615,931],{"class":930},[913,1617,1618],{"class":934},"nginx\n",[913,1620,1621,1624],{"class":915,"line":1007},[913,1622,1623],{"class":926},"  rules",[913,1625,955],{"class":930},[913,1627,1628,1630,1633,1635],{"class":915,"line":1015},[913,1629,1511],{"class":930},[913,1631,1632],{"class":926},"host",[913,1634,931],{"class":930},[913,1636,1637],{"class":934},"myapp.example.com\n",[913,1639,1640,1643],{"class":915,"line":1023},[913,1641,1642],{"class":926},"    http",[913,1644,955],{"class":930},[913,1646,1647,1650],{"class":915,"line":1033},[913,1648,1649],{"class":926},"      paths",[913,1651,955],{"class":930},[913,1653,1654,1656,1659,1661],{"class":915,"line":1041},[913,1655,1086],{"class":930},[913,1657,1658],{"class":926},"path",[913,1660,931],{"class":930},[913,1662,1602],{"class":934},[913,1664,1665,1668,1670],{"class":915,"line":1049},[913,1666,1667],{"class":926},"        pathType",[913,1669,931],{"class":930},[913,1671,1672],{"class":934},"Prefix\n",[913,1674,1675,1678],{"class":915,"line":1057},[913,1676,1677],{"class":926},"        backend",[913,1679,955],{"class":930},[913,1681,1682,1685],{"class":915,"line":1067},[913,1683,1684],{"class":926},"          service",[913,1686,955],{"class":930},[913,1688,1689,1692,1694],{"class":915,"line":1075},[913,1690,1691],{"class":926},"            name",[913,1693,931],{"class":930},[913,1695,1479],{"class":934},[913,1697,1698,1700],{"class":915,"line":1083},[913,1699,1353],{"class":926},[913,1701,955],{"class":930},[913,1703,1704,1707,1709],{"class":915,"line":1096},[913,1705,1706],{"class":926},"              number",[913,1708,931],{"class":930},[913,1710,1519],{"class":1003},[913,1712,1713,1716],{"class":915,"line":1107},[913,1714,1715],{"class":926},"  tls",[913,1717,955],{"class":930},[913,1719,1720,1722,1725],{"class":915,"line":1115},[913,1721,1511],{"class":930},[913,1723,1724],{"class":926},"hosts",[913,1726,955],{"class":930},[913,1728,1729,1732],{"class":915,"line":1129},[913,1730,1731],{"class":930},"    - ",[913,1733,1637],{"class":934},[913,1735,1736,1739,1741],{"class":915,"line":1137},[913,1737,1738],{"class":926},"    secretName",[913,1740,931],{"class":930},[913,1742,1743],{"class":934},"myapp-tls\n",[899,1745,1747],{"id":1746},"configmap","ConfigMap",[904,1749,1751],{"className":906,"code":1750,"language":908,"meta":11,"style":11},"# configmap.yaml\napiVersion: v1\nkind: ConfigMap\nmetadata:\n  name: myapp-config\ndata:\n  db_host: \"mysql-service\"\n  redis_host: \"redis-service\"\n  config.yaml: |\n    server:\n      port: 8080\n    database:\n      host: mysql-service\n      port: 3306\n",[910,1752,1753,1758,1766,1775,1781,1789,1796,1806,1816,1827,1832,1837,1842,1847],{"__ignoreMap":11},[913,1754,1755],{"class":915,"line":916},[913,1756,1757],{"class":919},"# configmap.yaml\n",[913,1759,1760,1762,1764],{"class":915,"line":923},[913,1761,927],{"class":926},[913,1763,931],{"class":930},[913,1765,1455],{"class":934},[913,1767,1768,1770,1772],{"class":915,"line":938},[913,1769,941],{"class":926},[913,1771,931],{"class":930},[913,1773,1774],{"class":934},"ConfigMap\n",[913,1776,1777,1779],{"class":915,"line":949},[913,1778,952],{"class":926},[913,1780,955],{"class":930},[913,1782,1783,1785,1787],{"class":915,"line":958},[913,1784,961],{"class":926},[913,1786,931],{"class":930},[913,1788,1196],{"class":934},[913,1790,1791,1794],{"class":915,"line":969},[913,1792,1793],{"class":926},"data",[913,1795,955],{"class":930},[913,1797,1798,1801,1803],{"class":915,"line":977},[913,1799,1800],{"class":926},"  db_host",[913,1802,931],{"class":930},[913,1804,1805],{"class":934},"\"mysql-service\"\n",[913,1807,1808,1811,1813],{"class":915,"line":987},[913,1809,1810],{"class":926},"  redis_host",[913,1812,931],{"class":930},[913,1814,1815],{"class":934},"\"redis-service\"\n",[913,1817,1818,1821,1823],{"class":915,"line":995},[913,1819,1820],{"class":926},"  config.yaml",[913,1822,931],{"class":930},[913,1824,1826],{"class":1825},"s8jYJ","|\n",[913,1828,1829],{"class":915,"line":1007},[913,1830,1831],{"class":934},"    server:\n",[913,1833,1834],{"class":915,"line":1015},[913,1835,1836],{"class":934},"      port: 8080\n",[913,1838,1839],{"class":915,"line":1023},[913,1840,1841],{"class":934},"    database:\n",[913,1843,1844],{"class":915,"line":1033},[913,1845,1846],{"class":934},"      host: mysql-service\n",[913,1848,1849],{"class":915,"line":1041},[913,1850,1851],{"class":934},"      port: 3306\n",[899,1853,1855],{"id":1854},"secret","Secret",[904,1857,1859],{"className":906,"code":1858,"language":908,"meta":11,"style":11},"# secret.yaml\napiVersion: v1\nkind: Secret\nmetadata:\n  name: myapp-secret\ntype: Opaque\ndata:\n  db_password: cGFzc3dvcmQ=  # base64 encoded\n  jwt_secret: bXktc2VjcmV0LWtleQ==\n",[910,1860,1861,1866,1874,1883,1889,1897,1907,1913,1926],{"__ignoreMap":11},[913,1862,1863],{"class":915,"line":916},[913,1864,1865],{"class":919},"# secret.yaml\n",[913,1867,1868,1870,1872],{"class":915,"line":923},[913,1869,927],{"class":926},[913,1871,931],{"class":930},[913,1873,1455],{"class":934},[913,1875,1876,1878,1880],{"class":915,"line":938},[913,1877,941],{"class":926},[913,1879,931],{"class":930},[913,1881,1882],{"class":934},"Secret\n",[913,1884,1885,1887],{"class":915,"line":949},[913,1886,952],{"class":926},[913,1888,955],{"class":930},[913,1890,1891,1893,1895],{"class":915,"line":958},[913,1892,961],{"class":926},[913,1894,931],{"class":930},[913,1896,1244],{"class":934},[913,1898,1899,1902,1904],{"class":915,"line":969},[913,1900,1901],{"class":926},"type",[913,1903,931],{"class":930},[913,1905,1906],{"class":934},"Opaque\n",[913,1908,1909,1911],{"class":915,"line":977},[913,1910,1793],{"class":926},[913,1912,955],{"class":930},[913,1914,1915,1918,1920,1923],{"class":915,"line":987},[913,1916,1917],{"class":926},"  db_password",[913,1919,931],{"class":930},[913,1921,1922],{"class":934},"cGFzc3dvcmQ=",[913,1924,1925],{"class":919},"  # base64 encoded\n",[913,1927,1928,1931,1933],{"class":915,"line":995},[913,1929,1930],{"class":926},"  jwt_secret",[913,1932,931],{"class":930},[913,1934,1935],{"class":934},"bXktc2VjcmV0LWtleQ==\n",[895,1937,1938],{"id":1938},"高级配置",[899,1940,1942],{"id":1941},"hpa自动扩缩容","HPA（自动扩缩容）",[904,1944,1946],{"className":906,"code":1945,"language":908,"meta":11,"style":11},"# hpa.yaml\napiVersion: autoscaling\u002Fv2\nkind: HorizontalPodAutoscaler\nmetadata:\n  name: myapp-hpa\nspec:\n  scaleTargetRef:\n    apiVersion: apps\u002Fv1\n    kind: Deployment\n    name: myapp\n  minReplicas: 2\n  maxReplicas: 10\n  metrics:\n  - type: Resource\n    resource:\n      name: cpu\n      target:\n        type: Utilization\n        averageUtilization: 70\n  - type: Resource\n    resource:\n      name: memory\n      target:\n        type: Utilization\n        averageUtilization: 80\n",[910,1947,1948,1953,1962,1971,1977,1986,1992,1999,2008,2017,2026,2036,2045,2052,2063,2070,2080,2087,2097,2107,2117,2123,2132,2138,2146],{"__ignoreMap":11},[913,1949,1950],{"class":915,"line":916},[913,1951,1952],{"class":919},"# hpa.yaml\n",[913,1954,1955,1957,1959],{"class":915,"line":923},[913,1956,927],{"class":926},[913,1958,931],{"class":930},[913,1960,1961],{"class":934},"autoscaling\u002Fv2\n",[913,1963,1964,1966,1968],{"class":915,"line":938},[913,1965,941],{"class":926},[913,1967,931],{"class":930},[913,1969,1970],{"class":934},"HorizontalPodAutoscaler\n",[913,1972,1973,1975],{"class":915,"line":949},[913,1974,952],{"class":926},[913,1976,955],{"class":930},[913,1978,1979,1981,1983],{"class":915,"line":958},[913,1980,961],{"class":926},[913,1982,931],{"class":930},[913,1984,1985],{"class":934},"myapp-hpa\n",[913,1987,1988,1990],{"class":915,"line":969},[913,1989,990],{"class":926},[913,1991,955],{"class":930},[913,1993,1994,1997],{"class":915,"line":977},[913,1995,1996],{"class":926},"  scaleTargetRef",[913,1998,955],{"class":930},[913,2000,2001,2004,2006],{"class":915,"line":987},[913,2002,2003],{"class":926},"    apiVersion",[913,2005,931],{"class":930},[913,2007,935],{"class":934},[913,2009,2010,2013,2015],{"class":915,"line":995},[913,2011,2012],{"class":926},"    kind",[913,2014,931],{"class":930},[913,2016,946],{"class":934},[913,2018,2019,2022,2024],{"class":915,"line":1007},[913,2020,2021],{"class":926},"    name",[913,2023,931],{"class":930},[913,2025,966],{"class":934},[913,2027,2028,2031,2033],{"class":915,"line":1015},[913,2029,2030],{"class":926},"  minReplicas",[913,2032,931],{"class":930},[913,2034,2035],{"class":1003},"2\n",[913,2037,2038,2041,2043],{"class":915,"line":1023},[913,2039,2040],{"class":926},"  maxReplicas",[913,2042,931],{"class":930},[913,2044,1379],{"class":1003},[913,2046,2047,2050],{"class":915,"line":1033},[913,2048,2049],{"class":926},"  metrics",[913,2051,955],{"class":930},[913,2053,2054,2056,2058,2060],{"class":915,"line":1041},[913,2055,1511],{"class":930},[913,2057,1901],{"class":926},[913,2059,931],{"class":930},[913,2061,2062],{"class":934},"Resource\n",[913,2064,2065,2068],{"class":915,"line":1049},[913,2066,2067],{"class":926},"    resource",[913,2069,955],{"class":930},[913,2071,2072,2075,2077],{"class":915,"line":1057},[913,2073,2074],{"class":926},"      name",[913,2076,931],{"class":930},[913,2078,2079],{"class":934},"cpu\n",[913,2081,2082,2085],{"class":915,"line":1067},[913,2083,2084],{"class":926},"      target",[913,2086,955],{"class":930},[913,2088,2089,2092,2094],{"class":915,"line":1075},[913,2090,2091],{"class":926},"        type",[913,2093,931],{"class":930},[913,2095,2096],{"class":934},"Utilization\n",[913,2098,2099,2102,2104],{"class":915,"line":1083},[913,2100,2101],{"class":926},"        averageUtilization",[913,2103,931],{"class":930},[913,2105,2106],{"class":1003},"70\n",[913,2108,2109,2111,2113,2115],{"class":915,"line":1096},[913,2110,1511],{"class":930},[913,2112,1901],{"class":926},[913,2114,931],{"class":930},[913,2116,2062],{"class":934},[913,2118,2119,2121],{"class":915,"line":1107},[913,2120,2067],{"class":926},[913,2122,955],{"class":930},[913,2124,2125,2127,2129],{"class":915,"line":1115},[913,2126,2074],{"class":926},[913,2128,931],{"class":930},[913,2130,2131],{"class":934},"memory\n",[913,2133,2134,2136],{"class":915,"line":1129},[913,2135,2084],{"class":926},[913,2137,955],{"class":930},[913,2139,2140,2142,2144],{"class":915,"line":1137},[913,2141,2091],{"class":926},[913,2143,931],{"class":930},[913,2145,2096],{"class":934},[913,2147,2148,2150,2152],{"class":915,"line":1149},[913,2149,2101],{"class":926},[913,2151,931],{"class":930},[913,2153,1519],{"class":1003},[899,2155,2157],{"id":2156},"pdbpod-中断预算","PDB（Pod 中断预算）",[904,2159,2161],{"className":906,"code":2160,"language":908,"meta":11,"style":11},"# pdb.yaml\napiVersion: policy\u002Fv1\nkind: PodDisruptionBudget\nmetadata:\n  name: myapp-pdb\nspec:\n  minAvailable: 2\n  selector:\n    matchLabels:\n      app: myapp\n",[910,2162,2163,2168,2177,2186,2192,2201,2207,2216,2222,2228],{"__ignoreMap":11},[913,2164,2165],{"class":915,"line":916},[913,2166,2167],{"class":919},"# pdb.yaml\n",[913,2169,2170,2172,2174],{"class":915,"line":923},[913,2171,927],{"class":926},[913,2173,931],{"class":930},[913,2175,2176],{"class":934},"policy\u002Fv1\n",[913,2178,2179,2181,2183],{"class":915,"line":938},[913,2180,941],{"class":926},[913,2182,931],{"class":930},[913,2184,2185],{"class":934},"PodDisruptionBudget\n",[913,2187,2188,2190],{"class":915,"line":949},[913,2189,952],{"class":926},[913,2191,955],{"class":930},[913,2193,2194,2196,2198],{"class":915,"line":958},[913,2195,961],{"class":926},[913,2197,931],{"class":930},[913,2199,2200],{"class":934},"myapp-pdb\n",[913,2202,2203,2205],{"class":915,"line":969},[913,2204,990],{"class":926},[913,2206,955],{"class":930},[913,2208,2209,2212,2214],{"class":915,"line":977},[913,2210,2211],{"class":926},"  minAvailable",[913,2213,931],{"class":930},[913,2215,2035],{"class":1003},[913,2217,2218,2220],{"class":915,"line":987},[913,2219,1010],{"class":926},[913,2221,955],{"class":930},[913,2223,2224,2226],{"class":915,"line":995},[913,2225,1018],{"class":926},[913,2227,955],{"class":930},[913,2229,2230,2232,2234],{"class":915,"line":1007},[913,2231,1026],{"class":926},[913,2233,931],{"class":930},[913,2235,966],{"class":934},[899,2237,2239],{"id":2238},"networkpolicy","NetworkPolicy",[904,2241,2243],{"className":906,"code":2242,"language":908,"meta":11,"style":11},"# network-policy.yaml\napiVersion: networking.k8s.io\u002Fv1\nkind: NetworkPolicy\nmetadata:\n  name: myapp-network-policy\nspec:\n  podSelector:\n    matchLabels:\n      app: myapp\n  policyTypes:\n  - Ingress\n  - Egress\n  ingress:\n  - from:\n    - podSelector:\n        matchLabels:\n          role: frontend\n    ports:\n    - protocol: TCP\n      port: 8080\n  egress:\n  - to:\n    - podSelector:\n        matchLabels:\n          app: mysql\n    ports:\n    - protocol: TCP\n      port: 3306\n",[910,2244,2245,2250,2258,2267,2273,2282,2288,2295,2301,2309,2316,2322,2329,2336,2345,2354,2361,2371,2378,2390,2399,2406,2415,2423,2429,2439,2445,2455],{"__ignoreMap":11},[913,2246,2247],{"class":915,"line":916},[913,2248,2249],{"class":919},"# network-policy.yaml\n",[913,2251,2252,2254,2256],{"class":915,"line":923},[913,2253,927],{"class":926},[913,2255,931],{"class":930},[913,2257,1561],{"class":934},[913,2259,2260,2262,2264],{"class":915,"line":938},[913,2261,941],{"class":926},[913,2263,931],{"class":930},[913,2265,2266],{"class":934},"NetworkPolicy\n",[913,2268,2269,2271],{"class":915,"line":949},[913,2270,952],{"class":926},[913,2272,955],{"class":930},[913,2274,2275,2277,2279],{"class":915,"line":958},[913,2276,961],{"class":926},[913,2278,931],{"class":930},[913,2280,2281],{"class":934},"myapp-network-policy\n",[913,2283,2284,2286],{"class":915,"line":969},[913,2285,990],{"class":926},[913,2287,955],{"class":930},[913,2289,2290,2293],{"class":915,"line":977},[913,2291,2292],{"class":926},"  podSelector",[913,2294,955],{"class":930},[913,2296,2297,2299],{"class":915,"line":987},[913,2298,1018],{"class":926},[913,2300,955],{"class":930},[913,2302,2303,2305,2307],{"class":915,"line":995},[913,2304,1026],{"class":926},[913,2306,931],{"class":930},[913,2308,966],{"class":934},[913,2310,2311,2314],{"class":915,"line":1007},[913,2312,2313],{"class":926},"  policyTypes",[913,2315,955],{"class":930},[913,2317,2318,2320],{"class":915,"line":1015},[913,2319,1511],{"class":930},[913,2321,1570],{"class":934},[913,2323,2324,2326],{"class":915,"line":1023},[913,2325,1511],{"class":930},[913,2327,2328],{"class":934},"Egress\n",[913,2330,2331,2334],{"class":915,"line":1033},[913,2332,2333],{"class":926},"  ingress",[913,2335,955],{"class":930},[913,2337,2338,2340,2343],{"class":915,"line":1041},[913,2339,1511],{"class":930},[913,2341,2342],{"class":926},"from",[913,2344,955],{"class":930},[913,2346,2347,2349,2352],{"class":915,"line":1049},[913,2348,1731],{"class":930},[913,2350,2351],{"class":926},"podSelector",[913,2353,955],{"class":930},[913,2355,2356,2359],{"class":915,"line":1057},[913,2357,2358],{"class":926},"        matchLabels",[913,2360,955],{"class":930},[913,2362,2363,2366,2368],{"class":915,"line":1067},[913,2364,2365],{"class":926},"          role",[913,2367,931],{"class":930},[913,2369,2370],{"class":934},"frontend\n",[913,2372,2373,2376],{"class":915,"line":1075},[913,2374,2375],{"class":926},"    ports",[913,2377,955],{"class":930},[913,2379,2380,2382,2385,2387],{"class":915,"line":1083},[913,2381,1731],{"class":930},[913,2383,2384],{"class":926},"protocol",[913,2386,931],{"class":930},[913,2388,2389],{"class":934},"TCP\n",[913,2391,2392,2395,2397],{"class":915,"line":1096},[913,2393,2394],{"class":926},"      port",[913,2396,931],{"class":930},[913,2398,1126],{"class":1003},[913,2400,2401,2404],{"class":915,"line":1107},[913,2402,2403],{"class":926},"  egress",[913,2405,955],{"class":930},[913,2407,2408,2410,2413],{"class":915,"line":1115},[913,2409,1511],{"class":930},[913,2411,2412],{"class":926},"to",[913,2414,955],{"class":930},[913,2416,2417,2419,2421],{"class":915,"line":1129},[913,2418,1731],{"class":930},[913,2420,2351],{"class":926},[913,2422,955],{"class":930},[913,2424,2425,2427],{"class":915,"line":1137},[913,2426,2358],{"class":926},[913,2428,955],{"class":930},[913,2430,2431,2434,2436],{"class":915,"line":1149},[913,2432,2433],{"class":926},"          app",[913,2435,931],{"class":930},[913,2437,2438],{"class":934},"mysql\n",[913,2440,2441,2443],{"class":915,"line":1160},[913,2442,2375],{"class":926},[913,2444,955],{"class":930},[913,2446,2447,2449,2451,2453],{"class":915,"line":1172},[913,2448,1731],{"class":930},[913,2450,2384],{"class":926},[913,2452,931],{"class":930},[913,2454,2389],{"class":934},[913,2456,2457,2459,2461],{"class":915,"line":1180},[913,2458,2394],{"class":926},[913,2460,931],{"class":930},[913,2462,2463],{"class":1003},"3306\n",[895,2465,2467],{"id":2466},"helm","Helm",[899,2469,2471],{"id":2470},"chart-结构","Chart 结构",[904,2473,2478],{"className":2474,"code":2476,"language":2477},[2475],"language-text","myapp\u002F\n├── Chart.yaml\n├── values.yaml\n├── templates\u002F\n│   ├── deployment.yaml\n│   ├── service.yaml\n│   ├── ingress.yaml\n│   ├── configmap.yaml\n│   ├── secret.yaml\n│   ├── hpa.yaml\n│   └── _helpers.tpl\n","text",[910,2479,2476],{"__ignoreMap":11},[899,2481,2483],{"id":2482},"chartyaml","Chart.yaml",[904,2485,2487],{"className":906,"code":2486,"language":908,"meta":11,"style":11},"apiVersion: v2\nname: myapp\ndescription: My Go Application\nversion: 0.1.0\nappVersion: \"1.0.0\"\n",[910,2488,2489,2498,2506,2516,2526],{"__ignoreMap":11},[913,2490,2491,2493,2495],{"class":915,"line":916},[913,2492,927],{"class":926},[913,2494,931],{"class":930},[913,2496,2497],{"class":934},"v2\n",[913,2499,2500,2502,2504],{"class":915,"line":923},[913,2501,1089],{"class":926},[913,2503,931],{"class":930},[913,2505,966],{"class":934},[913,2507,2508,2511,2513],{"class":915,"line":938},[913,2509,2510],{"class":926},"description",[913,2512,931],{"class":930},[913,2514,2515],{"class":934},"My Go Application\n",[913,2517,2518,2521,2523],{"class":915,"line":949},[913,2519,2520],{"class":926},"version",[913,2522,931],{"class":930},[913,2524,2525],{"class":1003},"0.1.0\n",[913,2527,2528,2531,2533],{"class":915,"line":958},[913,2529,2530],{"class":926},"appVersion",[913,2532,931],{"class":930},[913,2534,2535],{"class":934},"\"1.0.0\"\n",[899,2537,2539],{"id":2538},"valuesyaml","values.yaml",[904,2541,2543],{"className":906,"code":2542,"language":908,"meta":11,"style":11},"replicaCount: 3\n\nimage:\n  repository: myrepo\u002Fmyapp\n  tag: latest\n  pullPolicy: IfNotPresent\n\nservice:\n  type: ClusterIP\n  port: 80\n\ningress:\n  enabled: true\n  host: myapp.example.com\n\nresources:\n  requests:\n    memory: 128Mi\n    cpu: 100m\n  limits:\n    memory: 256Mi\n    cpu: 500m\n\nautoscaling:\n  enabled: true\n  minReplicas: 2\n  maxReplicas: 10\n  targetCPUUtilization: 70\n\nconfig:\n  dbHost: mysql-service\n  redisHost: redis-service\n",[910,2544,2545,2554,2560,2567,2577,2587,2597,2601,2607,2615,2624,2628,2634,2644,2653,2657,2664,2671,2681,2691,2698,2707,2716,2720,2727,2735,2743,2751,2760,2764,2771,2781],{"__ignoreMap":11},[913,2546,2547,2550,2552],{"class":915,"line":916},[913,2548,2549],{"class":926},"replicaCount",[913,2551,931],{"class":930},[913,2553,1004],{"class":1003},[913,2555,2556],{"class":915,"line":923},[913,2557,2559],{"emptyLinePlaceholder":2558},true,"\n",[913,2561,2562,2565],{"class":915,"line":938},[913,2563,2564],{"class":926},"image",[913,2566,955],{"class":930},[913,2568,2569,2572,2574],{"class":915,"line":949},[913,2570,2571],{"class":926},"  repository",[913,2573,931],{"class":930},[913,2575,2576],{"class":934},"myrepo\u002Fmyapp\n",[913,2578,2579,2582,2584],{"class":915,"line":958},[913,2580,2581],{"class":926},"  tag",[913,2583,931],{"class":930},[913,2585,2586],{"class":934},"latest\n",[913,2588,2589,2592,2594],{"class":915,"line":969},[913,2590,2591],{"class":926},"  pullPolicy",[913,2593,931],{"class":930},[913,2595,2596],{"class":934},"IfNotPresent\n",[913,2598,2599],{"class":915,"line":977},[913,2600,2559],{"emptyLinePlaceholder":2558},[913,2602,2603,2605],{"class":915,"line":987},[913,2604,1435],{"class":926},[913,2606,955],{"class":930},[913,2608,2609,2611,2613],{"class":915,"line":995},[913,2610,1533],{"class":926},[913,2612,931],{"class":930},[913,2614,1538],{"class":934},[913,2616,2617,2620,2622],{"class":915,"line":1007},[913,2618,2619],{"class":926},"  port",[913,2621,931],{"class":930},[913,2623,1519],{"class":1003},[913,2625,2626],{"class":915,"line":1015},[913,2627,2559],{"emptyLinePlaceholder":2558},[913,2629,2630,2632],{"class":915,"line":1023},[913,2631,1541],{"class":926},[913,2633,955],{"class":930},[913,2635,2636,2639,2641],{"class":915,"line":1033},[913,2637,2638],{"class":926},"  enabled",[913,2640,931],{"class":930},[913,2642,2643],{"class":1003},"true\n",[913,2645,2646,2649,2651],{"class":915,"line":1041},[913,2647,2648],{"class":926},"  host",[913,2650,931],{"class":930},[913,2652,1637],{"class":934},[913,2654,2655],{"class":915,"line":1049},[913,2656,2559],{"emptyLinePlaceholder":2558},[913,2658,2659,2662],{"class":915,"line":1057},[913,2660,2661],{"class":926},"resources",[913,2663,955],{"class":930},[913,2665,2666,2669],{"class":915,"line":1067},[913,2667,2668],{"class":926},"  requests",[913,2670,955],{"class":930},[913,2672,2673,2676,2678],{"class":915,"line":1075},[913,2674,2675],{"class":926},"    memory",[913,2677,931],{"class":930},[913,2679,2680],{"class":934},"128Mi\n",[913,2682,2683,2686,2688],{"class":915,"line":1083},[913,2684,2685],{"class":926},"    cpu",[913,2687,931],{"class":930},[913,2689,2690],{"class":934},"100m\n",[913,2692,2693,2696],{"class":915,"line":1096},[913,2694,2695],{"class":926},"  limits",[913,2697,955],{"class":930},[913,2699,2700,2702,2704],{"class":915,"line":1107},[913,2701,2675],{"class":926},[913,2703,931],{"class":930},[913,2705,2706],{"class":934},"256Mi\n",[913,2708,2709,2711,2713],{"class":915,"line":1115},[913,2710,2685],{"class":926},[913,2712,931],{"class":930},[913,2714,2715],{"class":934},"500m\n",[913,2717,2718],{"class":915,"line":1129},[913,2719,2559],{"emptyLinePlaceholder":2558},[913,2721,2722,2725],{"class":915,"line":1137},[913,2723,2724],{"class":926},"autoscaling",[913,2726,955],{"class":930},[913,2728,2729,2731,2733],{"class":915,"line":1149},[913,2730,2638],{"class":926},[913,2732,931],{"class":930},[913,2734,2643],{"class":1003},[913,2736,2737,2739,2741],{"class":915,"line":1160},[913,2738,2030],{"class":926},[913,2740,931],{"class":930},[913,2742,2035],{"class":1003},[913,2744,2745,2747,2749],{"class":915,"line":1172},[913,2746,2040],{"class":926},[913,2748,931],{"class":930},[913,2750,1379],{"class":1003},[913,2752,2753,2756,2758],{"class":915,"line":1180},[913,2754,2755],{"class":926},"  targetCPUUtilization",[913,2757,931],{"class":930},[913,2759,2106],{"class":1003},[913,2761,2762],{"class":915,"line":1188},[913,2763,2559],{"emptyLinePlaceholder":2558},[913,2765,2766,2769],{"class":915,"line":1199},[913,2767,2768],{"class":926},"config",[913,2770,955],{"class":930},[913,2772,2773,2776,2778],{"class":915,"line":1210},[913,2774,2775],{"class":926},"  dbHost",[913,2777,931],{"class":930},[913,2779,2780],{"class":934},"mysql-service\n",[913,2782,2783,2786,2788],{"class":915,"line":1222},[913,2784,2785],{"class":926},"  redisHost",[913,2787,931],{"class":930},[913,2789,2790],{"class":934},"redis-service\n",[899,2792,2793],{"id":2793},"模板示例",[904,2795,2797],{"className":906,"code":2796,"language":908,"meta":11,"style":11},"# templates\u002Fdeployment.yaml\napiVersion: apps\u002Fv1\nkind: Deployment\nmetadata:\n  name: {{ include \"myapp.fullname\" . }}\n  labels:\n    {{- include \"myapp.labels\" . | nindent 4 }}\nspec:\n  replicas: {{ .Values.replicaCount }}\n  selector:\n    matchLabels:\n      {{- include \"myapp.selectorLabels\" . | nindent 6 }}\n  template:\n    metadata:\n      labels:\n        {{- include \"myapp.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: 8080\n        resources:\n          {{- toYaml .Values.resources | nindent 12 }}\n",[910,2798,2799,2804,2812,2820,2826,2839,2845,2855,2861,2872,2878,2884,2894,2900,2906,2912,2922,2928,2934,2947,2956,2968,2974,2984,2990],{"__ignoreMap":11},[913,2800,2801],{"class":915,"line":916},[913,2802,2803],{"class":919},"# templates\u002Fdeployment.yaml\n",[913,2805,2806,2808,2810],{"class":915,"line":923},[913,2807,927],{"class":926},[913,2809,931],{"class":930},[913,2811,935],{"class":934},[913,2813,2814,2816,2818],{"class":915,"line":938},[913,2815,941],{"class":926},[913,2817,931],{"class":930},[913,2819,946],{"class":934},[913,2821,2822,2824],{"class":915,"line":949},[913,2823,952],{"class":926},[913,2825,955],{"class":930},[913,2827,2828,2830,2833,2836],{"class":915,"line":958},[913,2829,961],{"class":926},[913,2831,2832],{"class":930},": {{ ",[913,2834,2835],{"class":934},"include \"myapp.fullname\" .",[913,2837,2838],{"class":930}," }}\n",[913,2840,2841,2843],{"class":915,"line":969},[913,2842,972],{"class":926},[913,2844,955],{"class":930},[913,2846,2847,2850,2853],{"class":915,"line":977},[913,2848,2849],{"class":930},"    {{- ",[913,2851,2852],{"class":934},"include \"myapp.labels\" . | nindent 4",[913,2854,2838],{"class":930},[913,2856,2857,2859],{"class":915,"line":987},[913,2858,990],{"class":926},[913,2860,955],{"class":930},[913,2862,2863,2865,2867,2870],{"class":915,"line":995},[913,2864,998],{"class":926},[913,2866,2832],{"class":930},[913,2868,2869],{"class":934},".Values.replicaCount",[913,2871,2838],{"class":930},[913,2873,2874,2876],{"class":915,"line":1007},[913,2875,1010],{"class":926},[913,2877,955],{"class":930},[913,2879,2880,2882],{"class":915,"line":1015},[913,2881,1018],{"class":926},[913,2883,955],{"class":930},[913,2885,2886,2889,2892],{"class":915,"line":1023},[913,2887,2888],{"class":930},"      {{- ",[913,2890,2891],{"class":934},"include \"myapp.selectorLabels\" . | nindent 6",[913,2893,2838],{"class":930},[913,2895,2896,2898],{"class":915,"line":1033},[913,2897,1036],{"class":926},[913,2899,955],{"class":930},[913,2901,2902,2904],{"class":915,"line":1041},[913,2903,1044],{"class":926},[913,2905,955],{"class":930},[913,2907,2908,2910],{"class":915,"line":1049},[913,2909,1052],{"class":926},[913,2911,955],{"class":930},[913,2913,2914,2917,2920],{"class":915,"line":1057},[913,2915,2916],{"class":930},"        {{- ",[913,2918,2919],{"class":934},"include \"myapp.selectorLabels\" . | nindent 8",[913,2921,2838],{"class":930},[913,2923,2924,2926],{"class":915,"line":1067},[913,2925,1070],{"class":926},[913,2927,955],{"class":930},[913,2929,2930,2932],{"class":915,"line":1075},[913,2931,1078],{"class":926},[913,2933,955],{"class":930},[913,2935,2936,2938,2940,2942,2945],{"class":915,"line":1083},[913,2937,1086],{"class":930},[913,2939,1089],{"class":926},[913,2941,2832],{"class":930},[913,2943,2944],{"class":934},".Chart.Name",[913,2946,2838],{"class":930},[913,2948,2949,2951,2953],{"class":915,"line":1096},[913,2950,1099],{"class":926},[913,2952,931],{"class":930},[913,2954,2955],{"class":934},"\"{{ .Values.image.repository }}:{{ .Values.image.tag }}\"\n",[913,2957,2958,2961,2963,2966],{"class":915,"line":1107},[913,2959,2960],{"class":926},"        imagePullPolicy",[913,2962,2832],{"class":930},[913,2964,2965],{"class":934},".Values.image.pullPolicy",[913,2967,2838],{"class":930},[913,2969,2970,2972],{"class":915,"line":1115},[913,2971,1110],{"class":926},[913,2973,955],{"class":930},[913,2975,2976,2978,2980,2982],{"class":915,"line":1129},[913,2977,1118],{"class":930},[913,2979,1121],{"class":926},[913,2981,931],{"class":930},[913,2983,1126],{"class":1003},[913,2985,2986,2988],{"class":915,"line":1137},[913,2987,1260],{"class":926},[913,2989,955],{"class":930},[913,2991,2992,2995,2998],{"class":915,"line":1149},[913,2993,2994],{"class":930},"          {{- ",[913,2996,2997],{"class":934},"toYaml .Values.resources | nindent 12",[913,2999,2838],{"class":930},[899,3001,3003],{"id":3002},"helm-命令","Helm 命令",[904,3005,3009],{"className":3006,"code":3007,"language":3008,"meta":11,"style":11},"language-bash shiki shiki-themes github-light github-light github-dark","# 安装\nhelm install myapp .\u002Fmyapp\n\n# 升级\nhelm upgrade myapp .\u002Fmyapp\n\n# 使用自定义 values\nhelm install myapp .\u002Fmyapp -f values-prod.yaml\n\n# 设置值\nhelm install myapp .\u002Fmyapp --set image.tag=v1.0.0\n\n# 卸载\nhelm uninstall myapp\n\n# 查看渲染结果\nhelm template myapp .\u002Fmyapp\n","bash",[910,3010,3011,3016,3030,3034,3039,3050,3054,3059,3076,3080,3085,3101,3105,3110,3120,3124,3129],{"__ignoreMap":11},[913,3012,3013],{"class":915,"line":916},[913,3014,3015],{"class":919},"# 安装\n",[913,3017,3018,3021,3024,3027],{"class":915,"line":923},[913,3019,2466],{"class":3020},"snPdu",[913,3022,3023],{"class":934}," install",[913,3025,3026],{"class":934}," myapp",[913,3028,3029],{"class":934}," .\u002Fmyapp\n",[913,3031,3032],{"class":915,"line":938},[913,3033,2559],{"emptyLinePlaceholder":2558},[913,3035,3036],{"class":915,"line":949},[913,3037,3038],{"class":919},"# 升级\n",[913,3040,3041,3043,3046,3048],{"class":915,"line":958},[913,3042,2466],{"class":3020},[913,3044,3045],{"class":934}," upgrade",[913,3047,3026],{"class":934},[913,3049,3029],{"class":934},[913,3051,3052],{"class":915,"line":969},[913,3053,2559],{"emptyLinePlaceholder":2558},[913,3055,3056],{"class":915,"line":977},[913,3057,3058],{"class":919},"# 使用自定义 values\n",[913,3060,3061,3063,3065,3067,3070,3073],{"class":915,"line":987},[913,3062,2466],{"class":3020},[913,3064,3023],{"class":934},[913,3066,3026],{"class":934},[913,3068,3069],{"class":934}," .\u002Fmyapp",[913,3071,3072],{"class":1003}," -f",[913,3074,3075],{"class":934}," values-prod.yaml\n",[913,3077,3078],{"class":915,"line":995},[913,3079,2559],{"emptyLinePlaceholder":2558},[913,3081,3082],{"class":915,"line":1007},[913,3083,3084],{"class":919},"# 设置值\n",[913,3086,3087,3089,3091,3093,3095,3098],{"class":915,"line":1015},[913,3088,2466],{"class":3020},[913,3090,3023],{"class":934},[913,3092,3026],{"class":934},[913,3094,3069],{"class":934},[913,3096,3097],{"class":1003}," --set",[913,3099,3100],{"class":934}," image.tag=v1.0.0\n",[913,3102,3103],{"class":915,"line":1023},[913,3104,2559],{"emptyLinePlaceholder":2558},[913,3106,3107],{"class":915,"line":1033},[913,3108,3109],{"class":919},"# 卸载\n",[913,3111,3112,3114,3117],{"class":915,"line":1041},[913,3113,2466],{"class":3020},[913,3115,3116],{"class":934}," uninstall",[913,3118,3119],{"class":934}," myapp\n",[913,3121,3122],{"class":915,"line":1049},[913,3123,2559],{"emptyLinePlaceholder":2558},[913,3125,3126],{"class":915,"line":1057},[913,3127,3128],{"class":919},"# 查看渲染结果\n",[913,3130,3131,3133,3136,3138],{"class":915,"line":1067},[913,3132,2466],{"class":3020},[913,3134,3135],{"class":934}," template",[913,3137,3026],{"class":934},[913,3139,3029],{"class":934},[895,3141,3142],{"id":3142},"健康检查接口",[904,3144,3148],{"className":3145,"code":3146,"language":3147,"meta":11,"style":11},"language-go shiki shiki-themes github-light github-light github-dark","package main\n\nimport (\n    \"net\u002Fhttp\"\n    \"sync\u002Fatomic\"\n    \"github.com\u002Fgin-gonic\u002Fgin\"\n)\n\nvar (\n    healthy int32 = 1\n    ready   int32 = 0\n)\n\nfunc main() {\n    r := gin.Default()\n    \n    \u002F\u002F 存活检查\n    r.GET(\"\u002Fhealth\", func(c *gin.Context) {\n        if atomic.LoadInt32(&healthy) == 1 {\n            c.JSON(http.StatusOK, gin.H{\"status\": \"healthy\"})\n        } else {\n            c.JSON(http.StatusServiceUnavailable, gin.H{\"status\": \"unhealthy\"})\n        }\n    })\n    \n    \u002F\u002F 就绪检查\n    r.GET(\"\u002Fready\", func(c *gin.Context) {\n        if atomic.LoadInt32(&ready) == 1 {\n            c.JSON(http.StatusOK, gin.H{\"status\": \"ready\"})\n        } else {\n            c.JSON(http.StatusServiceUnavailable, gin.H{\"status\": \"not ready\"})\n        }\n    })\n    \n    \u002F\u002F 初始化完成后设置就绪\n    go func() {\n        \u002F\u002F 初始化数据库、缓存等...\n        initDB()\n        initCache()\n        atomic.StoreInt32(&ready, 1)\n    }()\n    \n    r.Run(\":8080\")\n}\n\n\u002F\u002F 优雅关闭\nfunc gracefulShutdown() {\n    \u002F\u002F 设置为不健康，停止接收新请求\n    atomic.StoreInt32(&healthy, 0)\n    \n    \u002F\u002F 等待现有请求完成\n    time.Sleep(5 * time.Second)\n    \n    \u002F\u002F 清理资源\n    cleanup()\n}\n","go",[910,3149,3150,3158,3162,3170,3180,3189,3198,3203,3207,3214,3228,3240,3244,3248,3259,3276,3281,3286,3326,3354,3386,3396,3422,3427,3432,3436,3441,3470,3491,3516,3524,3549,3553,3557,3561,3566,3576,3581,3588,3595,3615,3620,3624,3638,3643,3647,3652,3661,3666,3685,3689,3694,3712,3716,3721,3729],{"__ignoreMap":11},[913,3151,3152,3155],{"class":915,"line":916},[913,3153,3154],{"class":1825},"package",[913,3156,3157],{"class":3020}," main\n",[913,3159,3160],{"class":915,"line":923},[913,3161,2559],{"emptyLinePlaceholder":2558},[913,3163,3164,3167],{"class":915,"line":938},[913,3165,3166],{"class":1825},"import",[913,3168,3169],{"class":930}," (\n",[913,3171,3172,3175,3177],{"class":915,"line":949},[913,3173,3174],{"class":934},"    \"",[913,3176,252],{"class":3020},[913,3178,3179],{"class":934},"\"\n",[913,3181,3182,3184,3187],{"class":915,"line":958},[913,3183,3174],{"class":934},[913,3185,3186],{"class":3020},"sync\u002Fatomic",[913,3188,3179],{"class":934},[913,3190,3191,3193,3196],{"class":915,"line":969},[913,3192,3174],{"class":934},[913,3194,3195],{"class":3020},"github.com\u002Fgin-gonic\u002Fgin",[913,3197,3179],{"class":934},[913,3199,3200],{"class":915,"line":977},[913,3201,3202],{"class":930},")\n",[913,3204,3205],{"class":915,"line":987},[913,3206,2559],{"emptyLinePlaceholder":2558},[913,3208,3209,3212],{"class":915,"line":995},[913,3210,3211],{"class":1825},"var",[913,3213,3169],{"class":930},[913,3215,3216,3219,3222,3225],{"class":915,"line":1007},[913,3217,3218],{"class":930},"    healthy ",[913,3220,3221],{"class":1825},"int32",[913,3223,3224],{"class":1825}," =",[913,3226,3227],{"class":1003}," 1\n",[913,3229,3230,3233,3235,3237],{"class":915,"line":1015},[913,3231,3232],{"class":930},"    ready   ",[913,3234,3221],{"class":1825},[913,3236,3224],{"class":1825},[913,3238,3239],{"class":1003}," 0\n",[913,3241,3242],{"class":915,"line":1023},[913,3243,3202],{"class":930},[913,3245,3246],{"class":915,"line":1033},[913,3247,2559],{"emptyLinePlaceholder":2558},[913,3249,3250,3253,3256],{"class":915,"line":1041},[913,3251,3252],{"class":1825},"func",[913,3254,3255],{"class":3020}," main",[913,3257,3258],{"class":930},"() {\n",[913,3260,3261,3264,3267,3270,3273],{"class":915,"line":1049},[913,3262,3263],{"class":930},"    r ",[913,3265,3266],{"class":1825},":=",[913,3268,3269],{"class":930}," gin.",[913,3271,3272],{"class":3020},"Default",[913,3274,3275],{"class":930},"()\n",[913,3277,3278],{"class":915,"line":1057},[913,3279,3280],{"class":930},"    \n",[913,3282,3283],{"class":915,"line":1067},[913,3284,3285],{"class":919},"    \u002F\u002F 存活检查\n",[913,3287,3288,3291,3294,3297,3300,3303,3305,3307,3311,3314,3317,3320,3323],{"class":915,"line":1075},[913,3289,3290],{"class":930},"    r.",[913,3292,3293],{"class":3020},"GET",[913,3295,3296],{"class":930},"(",[913,3298,3299],{"class":934},"\"\u002Fhealth\"",[913,3301,3302],{"class":930},", ",[913,3304,3252],{"class":1825},[913,3306,3296],{"class":930},[913,3308,3310],{"class":3309},"sP4rz","c",[913,3312,3313],{"class":1825}," *",[913,3315,3316],{"class":3020},"gin",[913,3318,3319],{"class":930},".",[913,3321,3322],{"class":3020},"Context",[913,3324,3325],{"class":930},") {\n",[913,3327,3328,3331,3334,3337,3339,3342,3345,3348,3351],{"class":915,"line":1083},[913,3329,3330],{"class":1825},"        if",[913,3332,3333],{"class":930}," atomic.",[913,3335,3336],{"class":3020},"LoadInt32",[913,3338,3296],{"class":930},[913,3340,3341],{"class":1825},"&",[913,3343,3344],{"class":930},"healthy) ",[913,3346,3347],{"class":1825},"==",[913,3349,3350],{"class":1003}," 1",[913,3352,3353],{"class":930}," {\n",[913,3355,3356,3359,3362,3365,3367,3369,3372,3375,3378,3380,3383],{"class":915,"line":1096},[913,3357,3358],{"class":930},"            c.",[913,3360,3361],{"class":3020},"JSON",[913,3363,3364],{"class":930},"(http.StatusOK, ",[913,3366,3316],{"class":3020},[913,3368,3319],{"class":930},[913,3370,3371],{"class":3020},"H",[913,3373,3374],{"class":930},"{",[913,3376,3377],{"class":934},"\"status\"",[913,3379,931],{"class":930},[913,3381,3382],{"class":934},"\"healthy\"",[913,3384,3385],{"class":930},"})\n",[913,3387,3388,3391,3394],{"class":915,"line":1107},[913,3389,3390],{"class":930},"        } ",[913,3392,3393],{"class":1825},"else",[913,3395,3353],{"class":930},[913,3397,3398,3400,3402,3405,3407,3409,3411,3413,3415,3417,3420],{"class":915,"line":1115},[913,3399,3358],{"class":930},[913,3401,3361],{"class":3020},[913,3403,3404],{"class":930},"(http.StatusServiceUnavailable, ",[913,3406,3316],{"class":3020},[913,3408,3319],{"class":930},[913,3410,3371],{"class":3020},[913,3412,3374],{"class":930},[913,3414,3377],{"class":934},[913,3416,931],{"class":930},[913,3418,3419],{"class":934},"\"unhealthy\"",[913,3421,3385],{"class":930},[913,3423,3424],{"class":915,"line":1129},[913,3425,3426],{"class":930},"        }\n",[913,3428,3429],{"class":915,"line":1137},[913,3430,3431],{"class":930},"    })\n",[913,3433,3434],{"class":915,"line":1149},[913,3435,3280],{"class":930},[913,3437,3438],{"class":915,"line":1160},[913,3439,3440],{"class":919},"    \u002F\u002F 就绪检查\n",[913,3442,3443,3445,3447,3449,3452,3454,3456,3458,3460,3462,3464,3466,3468],{"class":915,"line":1172},[913,3444,3290],{"class":930},[913,3446,3293],{"class":3020},[913,3448,3296],{"class":930},[913,3450,3451],{"class":934},"\"\u002Fready\"",[913,3453,3302],{"class":930},[913,3455,3252],{"class":1825},[913,3457,3296],{"class":930},[913,3459,3310],{"class":3309},[913,3461,3313],{"class":1825},[913,3463,3316],{"class":3020},[913,3465,3319],{"class":930},[913,3467,3322],{"class":3020},[913,3469,3325],{"class":930},[913,3471,3472,3474,3476,3478,3480,3482,3485,3487,3489],{"class":915,"line":1180},[913,3473,3330],{"class":1825},[913,3475,3333],{"class":930},[913,3477,3336],{"class":3020},[913,3479,3296],{"class":930},[913,3481,3341],{"class":1825},[913,3483,3484],{"class":930},"ready) ",[913,3486,3347],{"class":1825},[913,3488,3350],{"class":1003},[913,3490,3353],{"class":930},[913,3492,3493,3495,3497,3499,3501,3503,3505,3507,3509,3511,3514],{"class":915,"line":1188},[913,3494,3358],{"class":930},[913,3496,3361],{"class":3020},[913,3498,3364],{"class":930},[913,3500,3316],{"class":3020},[913,3502,3319],{"class":930},[913,3504,3371],{"class":3020},[913,3506,3374],{"class":930},[913,3508,3377],{"class":934},[913,3510,931],{"class":930},[913,3512,3513],{"class":934},"\"ready\"",[913,3515,3385],{"class":930},[913,3517,3518,3520,3522],{"class":915,"line":1199},[913,3519,3390],{"class":930},[913,3521,3393],{"class":1825},[913,3523,3353],{"class":930},[913,3525,3526,3528,3530,3532,3534,3536,3538,3540,3542,3544,3547],{"class":915,"line":1210},[913,3527,3358],{"class":930},[913,3529,3361],{"class":3020},[913,3531,3404],{"class":930},[913,3533,3316],{"class":3020},[913,3535,3319],{"class":930},[913,3537,3371],{"class":3020},[913,3539,3374],{"class":930},[913,3541,3377],{"class":934},[913,3543,931],{"class":930},[913,3545,3546],{"class":934},"\"not ready\"",[913,3548,3385],{"class":930},[913,3550,3551],{"class":915,"line":1222},[913,3552,3426],{"class":930},[913,3554,3555],{"class":915,"line":1229},[913,3556,3431],{"class":930},[913,3558,3559],{"class":915,"line":1237},[913,3560,3280],{"class":930},[913,3562,3563],{"class":915,"line":1247},[913,3564,3565],{"class":919},"    \u002F\u002F 初始化完成后设置就绪\n",[913,3567,3568,3571,3574],{"class":915,"line":1257},[913,3569,3570],{"class":1825},"    go",[913,3572,3573],{"class":1825}," func",[913,3575,3258],{"class":930},[913,3577,3578],{"class":915,"line":1265},[913,3579,3580],{"class":919},"        \u002F\u002F 初始化数据库、缓存等...\n",[913,3582,3583,3586],{"class":915,"line":1273},[913,3584,3585],{"class":3020},"        initDB",[913,3587,3275],{"class":930},[913,3589,3590,3593],{"class":915,"line":1284},[913,3591,3592],{"class":3020},"        initCache",[913,3594,3275],{"class":930},[913,3596,3597,3600,3603,3605,3607,3610,3613],{"class":915,"line":1295},[913,3598,3599],{"class":930},"        atomic.",[913,3601,3602],{"class":3020},"StoreInt32",[913,3604,3296],{"class":930},[913,3606,3341],{"class":1825},[913,3608,3609],{"class":930},"ready, ",[913,3611,3612],{"class":1003},"1",[913,3614,3202],{"class":930},[913,3616,3617],{"class":915,"line":1303},[913,3618,3619],{"class":930},"    }()\n",[913,3621,3622],{"class":915,"line":1313},[913,3623,3280],{"class":930},[913,3625,3626,3628,3631,3633,3636],{"class":915,"line":1323},[913,3627,3290],{"class":930},[913,3629,3630],{"class":3020},"Run",[913,3632,3296],{"class":930},[913,3634,3635],{"class":934},"\":8080\"",[913,3637,3202],{"class":930},[913,3639,3640],{"class":915,"line":1331},[913,3641,3642],{"class":930},"}\n",[913,3644,3645],{"class":915,"line":1339},[913,3646,2559],{"emptyLinePlaceholder":2558},[913,3648,3649],{"class":915,"line":1350},[913,3650,3651],{"class":919},"\u002F\u002F 优雅关闭\n",[913,3653,3654,3656,3659],{"class":915,"line":1360},[913,3655,3252],{"class":1825},[913,3657,3658],{"class":3020}," gracefulShutdown",[913,3660,3258],{"class":930},[913,3662,3663],{"class":915,"line":1371},[913,3664,3665],{"class":919},"    \u002F\u002F 设置为不健康，停止接收新请求\n",[913,3667,3668,3671,3673,3675,3677,3680,3683],{"class":915,"line":1382},[913,3669,3670],{"class":930},"    atomic.",[913,3672,3602],{"class":3020},[913,3674,3296],{"class":930},[913,3676,3341],{"class":1825},[913,3678,3679],{"class":930},"healthy, ",[913,3681,3682],{"class":1003},"0",[913,3684,3202],{"class":930},[913,3686,3687],{"class":915,"line":1390},[913,3688,3280],{"class":930},[913,3690,3691],{"class":915,"line":1397},[913,3692,3693],{"class":919},"    \u002F\u002F 等待现有请求完成\n",[913,3695,3696,3699,3702,3704,3707,3709],{"class":915,"line":1407},[913,3697,3698],{"class":930},"    time.",[913,3700,3701],{"class":3020},"Sleep",[913,3703,3296],{"class":930},[913,3705,3706],{"class":1003},"5",[913,3708,3313],{"class":1825},[913,3710,3711],{"class":930}," time.Second)\n",[913,3713,3714],{"class":915,"line":1416},[913,3715,3280],{"class":930},[913,3717,3718],{"class":915,"line":1426},[913,3719,3720],{"class":919},"    \u002F\u002F 清理资源\n",[913,3722,3724,3727],{"class":915,"line":3723},55,[913,3725,3726],{"class":3020},"    cleanup",[913,3728,3275],{"class":930},[913,3730,3732],{"class":915,"line":3731},56,[913,3733,3642],{"class":930},[895,3735,3736],{"id":3736},"监控",[899,3738,3740],{"id":3739},"prometheus-指标","Prometheus 指标",[904,3742,3744],{"className":3145,"code":3743,"language":3147,"meta":11,"style":11},"import (\n    \"github.com\u002Fprometheus\u002Fclient_golang\u002Fprometheus\"\n    \"github.com\u002Fprometheus\u002Fclient_golang\u002Fprometheus\u002Fpromhttp\"\n)\n\nvar (\n    requestCount = prometheus.NewCounterVec(\n        prometheus.CounterOpts{\n            Name: \"http_requests_total\",\n            Help: \"Total number of HTTP requests\",\n        },\n        []string{\"method\", \"path\", \"status\"},\n    )\n    \n    requestDuration = prometheus.NewHistogramVec(\n        prometheus.HistogramOpts{\n            Name:    \"http_request_duration_seconds\",\n            Help:    \"HTTP request duration\",\n            Buckets: prometheus.DefBuckets,\n        },\n        []string{\"method\", \"path\"},\n    )\n)\n\nfunc init() {\n    prometheus.MustRegister(requestCount, requestDuration)\n}\n\n\u002F\u002F 中间件\nfunc PrometheusMiddleware() gin.HandlerFunc {\n    return func(c *gin.Context) {\n        start := time.Now()\n        \n        c.Next()\n        \n        duration := time.Since(start).Seconds()\n        status := strconv.Itoa(c.Writer.Status())\n        \n        requestCount.WithLabelValues(c.Request.Method, c.FullPath(), status).Inc()\n        requestDuration.WithLabelValues(c.Request.Method, c.FullPath()).Observe(duration)\n    }\n}\n\nfunc main() {\n    r := gin.Default()\n    r.Use(PrometheusMiddleware())\n    \n    \u002F\u002F Prometheus 指标端点\n    r.GET(\"\u002Fmetrics\", gin.WrapH(promhttp.Handler()))\n    \n    r.Run(\":8080\")\n}\n",[910,3745,3746,3752,3761,3770,3774,3778,3784,3801,3814,3825,3835,3840,3865,3870,3874,3888,3899,3909,3919,3924,3928,3944,3948,3952,3956,3965,3976,3980,3984,3989,4008,4029,4044,4049,4059,4063,4083,4105,4109,4131,4151,4156,4160,4164,4172,4184,4198,4202,4207,4233,4237,4249],{"__ignoreMap":11},[913,3747,3748,3750],{"class":915,"line":916},[913,3749,3166],{"class":1825},[913,3751,3169],{"class":930},[913,3753,3754,3756,3759],{"class":915,"line":923},[913,3755,3174],{"class":934},[913,3757,3758],{"class":3020},"github.com\u002Fprometheus\u002Fclient_golang\u002Fprometheus",[913,3760,3179],{"class":934},[913,3762,3763,3765,3768],{"class":915,"line":938},[913,3764,3174],{"class":934},[913,3766,3767],{"class":3020},"github.com\u002Fprometheus\u002Fclient_golang\u002Fprometheus\u002Fpromhttp",[913,3769,3179],{"class":934},[913,3771,3772],{"class":915,"line":949},[913,3773,3202],{"class":930},[913,3775,3776],{"class":915,"line":958},[913,3777,2559],{"emptyLinePlaceholder":2558},[913,3779,3780,3782],{"class":915,"line":969},[913,3781,3211],{"class":1825},[913,3783,3169],{"class":930},[913,3785,3786,3789,3792,3795,3798],{"class":915,"line":977},[913,3787,3788],{"class":930},"    requestCount ",[913,3790,3791],{"class":1825},"=",[913,3793,3794],{"class":930}," prometheus.",[913,3796,3797],{"class":3020},"NewCounterVec",[913,3799,3800],{"class":930},"(\n",[913,3802,3803,3806,3808,3811],{"class":915,"line":987},[913,3804,3805],{"class":3020},"        prometheus",[913,3807,3319],{"class":930},[913,3809,3810],{"class":3020},"CounterOpts",[913,3812,3813],{"class":930},"{\n",[913,3815,3816,3819,3822],{"class":915,"line":995},[913,3817,3818],{"class":930},"            Name: ",[913,3820,3821],{"class":934},"\"http_requests_total\"",[913,3823,3824],{"class":930},",\n",[913,3826,3827,3830,3833],{"class":915,"line":1007},[913,3828,3829],{"class":930},"            Help: ",[913,3831,3832],{"class":934},"\"Total number of HTTP requests\"",[913,3834,3824],{"class":930},[913,3836,3837],{"class":915,"line":1015},[913,3838,3839],{"class":930},"        },\n",[913,3841,3842,3845,3848,3850,3853,3855,3858,3860,3862],{"class":915,"line":1023},[913,3843,3844],{"class":930},"        []",[913,3846,3847],{"class":1825},"string",[913,3849,3374],{"class":930},[913,3851,3852],{"class":934},"\"method\"",[913,3854,3302],{"class":930},[913,3856,3857],{"class":934},"\"path\"",[913,3859,3302],{"class":930},[913,3861,3377],{"class":934},[913,3863,3864],{"class":930},"},\n",[913,3866,3867],{"class":915,"line":1033},[913,3868,3869],{"class":930},"    )\n",[913,3871,3872],{"class":915,"line":1041},[913,3873,3280],{"class":930},[913,3875,3876,3879,3881,3883,3886],{"class":915,"line":1049},[913,3877,3878],{"class":930},"    requestDuration ",[913,3880,3791],{"class":1825},[913,3882,3794],{"class":930},[913,3884,3885],{"class":3020},"NewHistogramVec",[913,3887,3800],{"class":930},[913,3889,3890,3892,3894,3897],{"class":915,"line":1057},[913,3891,3805],{"class":3020},[913,3893,3319],{"class":930},[913,3895,3896],{"class":3020},"HistogramOpts",[913,3898,3813],{"class":930},[913,3900,3901,3904,3907],{"class":915,"line":1067},[913,3902,3903],{"class":930},"            Name:    ",[913,3905,3906],{"class":934},"\"http_request_duration_seconds\"",[913,3908,3824],{"class":930},[913,3910,3911,3914,3917],{"class":915,"line":1075},[913,3912,3913],{"class":930},"            Help:    ",[913,3915,3916],{"class":934},"\"HTTP request duration\"",[913,3918,3824],{"class":930},[913,3920,3921],{"class":915,"line":1083},[913,3922,3923],{"class":930},"            Buckets: prometheus.DefBuckets,\n",[913,3925,3926],{"class":915,"line":1096},[913,3927,3839],{"class":930},[913,3929,3930,3932,3934,3936,3938,3940,3942],{"class":915,"line":1107},[913,3931,3844],{"class":930},[913,3933,3847],{"class":1825},[913,3935,3374],{"class":930},[913,3937,3852],{"class":934},[913,3939,3302],{"class":930},[913,3941,3857],{"class":934},[913,3943,3864],{"class":930},[913,3945,3946],{"class":915,"line":1115},[913,3947,3869],{"class":930},[913,3949,3950],{"class":915,"line":1129},[913,3951,3202],{"class":930},[913,3953,3954],{"class":915,"line":1137},[913,3955,2559],{"emptyLinePlaceholder":2558},[913,3957,3958,3960,3963],{"class":915,"line":1149},[913,3959,3252],{"class":1825},[913,3961,3962],{"class":3020}," init",[913,3964,3258],{"class":930},[913,3966,3967,3970,3973],{"class":915,"line":1160},[913,3968,3969],{"class":930},"    prometheus.",[913,3971,3972],{"class":3020},"MustRegister",[913,3974,3975],{"class":930},"(requestCount, requestDuration)\n",[913,3977,3978],{"class":915,"line":1172},[913,3979,3642],{"class":930},[913,3981,3982],{"class":915,"line":1180},[913,3983,2559],{"emptyLinePlaceholder":2558},[913,3985,3986],{"class":915,"line":1188},[913,3987,3988],{"class":919},"\u002F\u002F 中间件\n",[913,3990,3991,3993,3996,3999,4001,4003,4006],{"class":915,"line":1199},[913,3992,3252],{"class":1825},[913,3994,3995],{"class":3020}," PrometheusMiddleware",[913,3997,3998],{"class":930},"() ",[913,4000,3316],{"class":3020},[913,4002,3319],{"class":930},[913,4004,4005],{"class":3020},"HandlerFunc",[913,4007,3353],{"class":930},[913,4009,4010,4013,4015,4017,4019,4021,4023,4025,4027],{"class":915,"line":1210},[913,4011,4012],{"class":1825},"    return",[913,4014,3573],{"class":1825},[913,4016,3296],{"class":930},[913,4018,3310],{"class":3309},[913,4020,3313],{"class":1825},[913,4022,3316],{"class":3020},[913,4024,3319],{"class":930},[913,4026,3322],{"class":3020},[913,4028,3325],{"class":930},[913,4030,4031,4034,4036,4039,4042],{"class":915,"line":1222},[913,4032,4033],{"class":930},"        start ",[913,4035,3266],{"class":1825},[913,4037,4038],{"class":930}," time.",[913,4040,4041],{"class":3020},"Now",[913,4043,3275],{"class":930},[913,4045,4046],{"class":915,"line":1229},[913,4047,4048],{"class":930},"        \n",[913,4050,4051,4054,4057],{"class":915,"line":1237},[913,4052,4053],{"class":930},"        c.",[913,4055,4056],{"class":3020},"Next",[913,4058,3275],{"class":930},[913,4060,4061],{"class":915,"line":1247},[913,4062,4048],{"class":930},[913,4064,4065,4068,4070,4072,4075,4078,4081],{"class":915,"line":1257},[913,4066,4067],{"class":930},"        duration ",[913,4069,3266],{"class":1825},[913,4071,4038],{"class":930},[913,4073,4074],{"class":3020},"Since",[913,4076,4077],{"class":930},"(start).",[913,4079,4080],{"class":3020},"Seconds",[913,4082,3275],{"class":930},[913,4084,4085,4088,4090,4093,4096,4099,4102],{"class":915,"line":1265},[913,4086,4087],{"class":930},"        status ",[913,4089,3266],{"class":1825},[913,4091,4092],{"class":930}," strconv.",[913,4094,4095],{"class":3020},"Itoa",[913,4097,4098],{"class":930},"(c.Writer.",[913,4100,4101],{"class":3020},"Status",[913,4103,4104],{"class":930},"())\n",[913,4106,4107],{"class":915,"line":1273},[913,4108,4048],{"class":930},[913,4110,4111,4114,4117,4120,4123,4126,4129],{"class":915,"line":1284},[913,4112,4113],{"class":930},"        requestCount.",[913,4115,4116],{"class":3020},"WithLabelValues",[913,4118,4119],{"class":930},"(c.Request.Method, c.",[913,4121,4122],{"class":3020},"FullPath",[913,4124,4125],{"class":930},"(), status).",[913,4127,4128],{"class":3020},"Inc",[913,4130,3275],{"class":930},[913,4132,4133,4136,4138,4140,4142,4145,4148],{"class":915,"line":1295},[913,4134,4135],{"class":930},"        requestDuration.",[913,4137,4116],{"class":3020},[913,4139,4119],{"class":930},[913,4141,4122],{"class":3020},[913,4143,4144],{"class":930},"()).",[913,4146,4147],{"class":3020},"Observe",[913,4149,4150],{"class":930},"(duration)\n",[913,4152,4153],{"class":915,"line":1303},[913,4154,4155],{"class":930},"    }\n",[913,4157,4158],{"class":915,"line":1313},[913,4159,3642],{"class":930},[913,4161,4162],{"class":915,"line":1323},[913,4163,2559],{"emptyLinePlaceholder":2558},[913,4165,4166,4168,4170],{"class":915,"line":1331},[913,4167,3252],{"class":1825},[913,4169,3255],{"class":3020},[913,4171,3258],{"class":930},[913,4173,4174,4176,4178,4180,4182],{"class":915,"line":1339},[913,4175,3263],{"class":930},[913,4177,3266],{"class":1825},[913,4179,3269],{"class":930},[913,4181,3272],{"class":3020},[913,4183,3275],{"class":930},[913,4185,4186,4188,4191,4193,4196],{"class":915,"line":1350},[913,4187,3290],{"class":930},[913,4189,4190],{"class":3020},"Use",[913,4192,3296],{"class":930},[913,4194,4195],{"class":3020},"PrometheusMiddleware",[913,4197,4104],{"class":930},[913,4199,4200],{"class":915,"line":1360},[913,4201,3280],{"class":930},[913,4203,4204],{"class":915,"line":1371},[913,4205,4206],{"class":919},"    \u002F\u002F Prometheus 指标端点\n",[913,4208,4209,4211,4213,4215,4218,4221,4224,4227,4230],{"class":915,"line":1382},[913,4210,3290],{"class":930},[913,4212,3293],{"class":3020},[913,4214,3296],{"class":930},[913,4216,4217],{"class":934},"\"\u002Fmetrics\"",[913,4219,4220],{"class":930},", gin.",[913,4222,4223],{"class":3020},"WrapH",[913,4225,4226],{"class":930},"(promhttp.",[913,4228,4229],{"class":3020},"Handler",[913,4231,4232],{"class":930},"()))\n",[913,4234,4235],{"class":915,"line":1390},[913,4236,3280],{"class":930},[913,4238,4239,4241,4243,4245,4247],{"class":915,"line":1397},[913,4240,3290],{"class":930},[913,4242,3630],{"class":3020},[913,4244,3296],{"class":930},[913,4246,3635],{"class":934},[913,4248,3202],{"class":930},[913,4250,4251],{"class":915,"line":1407},[913,4252,3642],{"class":930},[899,4254,4256],{"id":4255},"servicemonitor","ServiceMonitor",[904,4258,4260],{"className":906,"code":4259,"language":908,"meta":11,"style":11},"# servicemonitor.yaml\napiVersion: monitoring.coreos.com\u002Fv1\nkind: ServiceMonitor\nmetadata:\n  name: myapp-monitor\n  labels:\n    release: prometheus\nspec:\n  selector:\n    matchLabels:\n      app: myapp\n  endpoints:\n  - port: http\n    path: \u002Fmetrics\n    interval: 15s\n",[910,4261,4262,4267,4276,4285,4291,4300,4306,4316,4322,4328,4334,4342,4349,4360,4370],{"__ignoreMap":11},[913,4263,4264],{"class":915,"line":916},[913,4265,4266],{"class":919},"# servicemonitor.yaml\n",[913,4268,4269,4271,4273],{"class":915,"line":923},[913,4270,927],{"class":926},[913,4272,931],{"class":930},[913,4274,4275],{"class":934},"monitoring.coreos.com\u002Fv1\n",[913,4277,4278,4280,4282],{"class":915,"line":938},[913,4279,941],{"class":926},[913,4281,931],{"class":930},[913,4283,4284],{"class":934},"ServiceMonitor\n",[913,4286,4287,4289],{"class":915,"line":949},[913,4288,952],{"class":926},[913,4290,955],{"class":930},[913,4292,4293,4295,4297],{"class":915,"line":958},[913,4294,961],{"class":926},[913,4296,931],{"class":930},[913,4298,4299],{"class":934},"myapp-monitor\n",[913,4301,4302,4304],{"class":915,"line":969},[913,4303,972],{"class":926},[913,4305,955],{"class":930},[913,4307,4308,4311,4313],{"class":915,"line":977},[913,4309,4310],{"class":926},"    release",[913,4312,931],{"class":930},[913,4314,4315],{"class":934},"prometheus\n",[913,4317,4318,4320],{"class":915,"line":987},[913,4319,990],{"class":926},[913,4321,955],{"class":930},[913,4323,4324,4326],{"class":915,"line":995},[913,4325,1010],{"class":926},[913,4327,955],{"class":930},[913,4329,4330,4332],{"class":915,"line":1007},[913,4331,1018],{"class":926},[913,4333,955],{"class":930},[913,4335,4336,4338,4340],{"class":915,"line":1015},[913,4337,1026],{"class":926},[913,4339,931],{"class":930},[913,4341,966],{"class":934},[913,4343,4344,4347],{"class":915,"line":1023},[913,4345,4346],{"class":926},"  endpoints",[913,4348,955],{"class":930},[913,4350,4351,4353,4355,4357],{"class":915,"line":1033},[913,4352,1511],{"class":930},[913,4354,1514],{"class":926},[913,4356,931],{"class":930},[913,4358,4359],{"class":934},"http\n",[913,4361,4362,4365,4367],{"class":915,"line":1041},[913,4363,4364],{"class":926},"    path",[913,4366,931],{"class":930},[913,4368,4369],{"class":934},"\u002Fmetrics\n",[913,4371,4372,4375,4377],{"class":915,"line":1049},[913,4373,4374],{"class":926},"    interval",[913,4376,931],{"class":930},[913,4378,4379],{"class":934},"15s\n",[895,4381,4382],{"id":4382},"常用命令",[904,4384,4386],{"className":3006,"code":4385,"language":3008,"meta":11,"style":11},"# 应用配置\nkubectl apply -f deployment.yaml\nkubectl apply -f service.yaml\nkubectl apply -f ingress.yaml\n\n# 查看资源\nkubectl get pods\nkubectl get deployments\nkubectl get services\n\n# 查看日志\nkubectl logs -f deployment\u002Fmyapp\n\n# 进入容器\nkubectl exec -it pod\u002Fmyapp-xxx -- sh\n\n# 扩缩容\nkubectl scale deployment myapp --replicas=5\n\n# 滚动更新\nkubectl set image deployment\u002Fmyapp myapp=myrepo\u002Fmyapp:v2.0.0\n\n# 回滚\nkubectl rollout undo deployment\u002Fmyapp\n\n# 查看部署状态\nkubectl rollout status deployment\u002Fmyapp\n\n# 端口转发（本地调试）\nkubectl port-forward service\u002Fmyapp-service 8080:80\n",[910,4387,4388,4393,4406,4417,4428,4432,4437,4447,4456,4465,4469,4474,4486,4490,4495,4514,4518,4523,4538,4542,4547,4563,4567,4572,4584,4588,4593,4604,4608,4613],{"__ignoreMap":11},[913,4389,4390],{"class":915,"line":916},[913,4391,4392],{"class":919},"# 应用配置\n",[913,4394,4395,4398,4401,4403],{"class":915,"line":923},[913,4396,4397],{"class":3020},"kubectl",[913,4399,4400],{"class":934}," apply",[913,4402,3072],{"class":1003},[913,4404,4405],{"class":934}," deployment.yaml\n",[913,4407,4408,4410,4412,4414],{"class":915,"line":938},[913,4409,4397],{"class":3020},[913,4411,4400],{"class":934},[913,4413,3072],{"class":1003},[913,4415,4416],{"class":934}," service.yaml\n",[913,4418,4419,4421,4423,4425],{"class":915,"line":949},[913,4420,4397],{"class":3020},[913,4422,4400],{"class":934},[913,4424,3072],{"class":1003},[913,4426,4427],{"class":934}," ingress.yaml\n",[913,4429,4430],{"class":915,"line":958},[913,4431,2559],{"emptyLinePlaceholder":2558},[913,4433,4434],{"class":915,"line":969},[913,4435,4436],{"class":919},"# 查看资源\n",[913,4438,4439,4441,4444],{"class":915,"line":977},[913,4440,4397],{"class":3020},[913,4442,4443],{"class":934}," get",[913,4445,4446],{"class":934}," pods\n",[913,4448,4449,4451,4453],{"class":915,"line":987},[913,4450,4397],{"class":3020},[913,4452,4443],{"class":934},[913,4454,4455],{"class":934}," deployments\n",[913,4457,4458,4460,4462],{"class":915,"line":995},[913,4459,4397],{"class":3020},[913,4461,4443],{"class":934},[913,4463,4464],{"class":934}," services\n",[913,4466,4467],{"class":915,"line":1007},[913,4468,2559],{"emptyLinePlaceholder":2558},[913,4470,4471],{"class":915,"line":1015},[913,4472,4473],{"class":919},"# 查看日志\n",[913,4475,4476,4478,4481,4483],{"class":915,"line":1023},[913,4477,4397],{"class":3020},[913,4479,4480],{"class":934}," logs",[913,4482,3072],{"class":1003},[913,4484,4485],{"class":934}," deployment\u002Fmyapp\n",[913,4487,4488],{"class":915,"line":1033},[913,4489,2559],{"emptyLinePlaceholder":2558},[913,4491,4492],{"class":915,"line":1041},[913,4493,4494],{"class":919},"# 进入容器\n",[913,4496,4497,4499,4502,4505,4508,4511],{"class":915,"line":1049},[913,4498,4397],{"class":3020},[913,4500,4501],{"class":934}," exec",[913,4503,4504],{"class":1003}," -it",[913,4506,4507],{"class":934}," pod\u002Fmyapp-xxx",[913,4509,4510],{"class":1003}," --",[913,4512,4513],{"class":934}," sh\n",[913,4515,4516],{"class":915,"line":1057},[913,4517,2559],{"emptyLinePlaceholder":2558},[913,4519,4520],{"class":915,"line":1067},[913,4521,4522],{"class":919},"# 扩缩容\n",[913,4524,4525,4527,4530,4533,4535],{"class":915,"line":1075},[913,4526,4397],{"class":3020},[913,4528,4529],{"class":934}," scale",[913,4531,4532],{"class":934}," deployment",[913,4534,3026],{"class":934},[913,4536,4537],{"class":1003}," --replicas=5\n",[913,4539,4540],{"class":915,"line":1083},[913,4541,2559],{"emptyLinePlaceholder":2558},[913,4543,4544],{"class":915,"line":1096},[913,4545,4546],{"class":919},"# 滚动更新\n",[913,4548,4549,4551,4554,4557,4560],{"class":915,"line":1107},[913,4550,4397],{"class":3020},[913,4552,4553],{"class":934}," set",[913,4555,4556],{"class":934}," image",[913,4558,4559],{"class":934}," deployment\u002Fmyapp",[913,4561,4562],{"class":934}," myapp=myrepo\u002Fmyapp:v2.0.0\n",[913,4564,4565],{"class":915,"line":1115},[913,4566,2559],{"emptyLinePlaceholder":2558},[913,4568,4569],{"class":915,"line":1129},[913,4570,4571],{"class":919},"# 回滚\n",[913,4573,4574,4576,4579,4582],{"class":915,"line":1137},[913,4575,4397],{"class":3020},[913,4577,4578],{"class":934}," rollout",[913,4580,4581],{"class":934}," undo",[913,4583,4485],{"class":934},[913,4585,4586],{"class":915,"line":1149},[913,4587,2559],{"emptyLinePlaceholder":2558},[913,4589,4590],{"class":915,"line":1160},[913,4591,4592],{"class":919},"# 查看部署状态\n",[913,4594,4595,4597,4599,4602],{"class":915,"line":1172},[913,4596,4397],{"class":3020},[913,4598,4578],{"class":934},[913,4600,4601],{"class":934}," status",[913,4603,4485],{"class":934},[913,4605,4606],{"class":915,"line":1180},[913,4607,2559],{"emptyLinePlaceholder":2558},[913,4609,4610],{"class":915,"line":1188},[913,4611,4612],{"class":919},"# 端口转发（本地调试）\n",[913,4614,4615,4617,4620,4623],{"class":915,"line":1199},[913,4616,4397],{"class":3020},[913,4618,4619],{"class":934}," port-forward",[913,4621,4622],{"class":934}," service\u002Fmyapp-service",[913,4624,4625],{"class":934}," 8080:80\n",[4627,4628,4629],"style",{},"html pre.shiki code .sCsY4, html code.shiki .sCsY4{--shiki-light:#6A737D;--shiki-default:#6A737D;--shiki-dark:#6A737D}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}html pre.shiki code .sIIMD, html code.shiki .sIIMD{--shiki-light:#032F62;--shiki-default:#032F62;--shiki-dark:#9ECBFF}html pre.shiki code .sBjJW, html code.shiki .sBjJW{--shiki-light:#005CC5;--shiki-default:#005CC5;--shiki-dark:#79B8FF}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 .snPdu, html code.shiki .snPdu{--shiki-light:#6F42C1;--shiki-default:#6F42C1;--shiki-dark:#B392F0}html pre.shiki code .sP4rz, html code.shiki .sP4rz{--shiki-light:#E36209;--shiki-default:#E36209;--shiki-dark:#FFAB70}",{"title":11,"searchDepth":923,"depth":923,"links":4631},[4632,4639,4644,4651,4652,4656],{"id":897,"depth":923,"text":897,"children":4633},[4634,4635,4636,4637,4638],{"id":901,"depth":938,"text":902},{"id":1435,"depth":938,"text":1436},{"id":1541,"depth":938,"text":1542},{"id":1746,"depth":938,"text":1747},{"id":1854,"depth":938,"text":1855},{"id":1938,"depth":923,"text":1938,"children":4640},[4641,4642,4643],{"id":1941,"depth":938,"text":1942},{"id":2156,"depth":938,"text":2157},{"id":2238,"depth":938,"text":2239},{"id":2466,"depth":923,"text":2467,"children":4645},[4646,4647,4648,4649,4650],{"id":2470,"depth":938,"text":2471},{"id":2482,"depth":938,"text":2483},{"id":2538,"depth":938,"text":2539},{"id":2793,"depth":938,"text":2793},{"id":3002,"depth":938,"text":3003},{"id":3142,"depth":923,"text":3142},{"id":3736,"depth":923,"text":3736,"children":4653},[4654,4655],{"id":3739,"depth":938,"text":3740},{"id":4255,"depth":938,"text":4256},{"id":4382,"depth":923,"text":4382},"md",{},{"title":208,"description":209},"golang\u002Fengineering\u002Fkubernetes","WJAQS5ghZzcFVYKsiCjms8Hz6rAzAqmqx6PxkJahtaU",1775496425144]