[{"data":1,"prerenderedAt":3538},["ShallowReactive",2],{"search-docs":3,"doc-\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-install":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":696,"body":888,"description":11,"extension":3533,"meta":3534,"navigation":1018,"path":695,"seo":3535,"stem":3536,"__hash__":3537},"docs\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-install.md",{"type":889,"value":890,"toc":3501},"minimark",[891,895,899,904,973,977,981,1114,1118,1198,1202,1254,1258,1343,1346,1550,1553,1556,1564,1567,1570,1713,1716,1807,1810,1922,1925,1928,2485,2488,2565,2568,2572,2678,2682,2772,2776,3006,3009,3079,3086,3089,3093,3161,3165,3224,3228,3268,3272,3317,3321,3395,3398,3492,3497],[892,893,894],"h2",{"id":894},"概述",[896,897,898],"p",{},"Nginx（发音为 \"engine-x\"）是一个高性能的 HTTP 和反向代理服务器。它以高并发、低内存消耗著称，被广泛用于 Web 服务器、反向代理、负载均衡等场景。",[900,901,903],"h3",{"id":902},"nginx-的特点","Nginx 的特点",[905,906,907,921],"table",{},[908,909,910],"thead",{},[911,912,913,918],"tr",{},[914,915,917],"th",{"align":916},"left","特点",[914,919,920],{"align":916},"说明",[922,923,924,933,941,949,957,965],"tbody",{},[911,925,926,930],{},[927,928,929],"td",{"align":916},"高性能",[927,931,932],{"align":916},"事件驱动架构，支持数万并发连接",[911,934,935,938],{},[927,936,937],{"align":916},"低内存消耗",[927,939,940],{"align":916},"相比 Apache，内存占用更少",[911,942,943,946],{},[927,944,945],{"align":916},"热部署",[927,947,948],{"align":916},"支持不停机更新配置和升级",[911,950,951,954],{},[927,952,953],{"align":916},"高可靠性",[927,955,956],{"align":916},"主进程+工作进程架构，稳定性高",[911,958,959,962],{},[927,960,961],{"align":916},"模块化",[927,963,964],{"align":916},"丰富的模块生态，易于扩展",[911,966,967,970],{},[927,968,969],{"align":916},"反向代理",[927,971,972],{"align":916},"原生支持反向代理和负载均衡",[892,974,976],{"id":975},"安装-nginx","安装 Nginx",[900,978,980],{"id":979},"ubuntudebian","Ubuntu\u002FDebian",[982,983,987],"pre",{"className":984,"code":985,"language":986,"meta":11,"style":11},"language-bash shiki shiki-themes github-light github-light github-dark","# 更新包索引\nsudo apt update\n\n# 安装 Nginx\nsudo apt install nginx -y\n\n# 启动 Nginx\nsudo systemctl start nginx\n\n# 设置开机自启\nsudo systemctl enable nginx\n\n# 检查状态\nsudo systemctl status nginx\n","bash",[988,989,990,999,1013,1020,1026,1043,1048,1054,1068,1073,1079,1091,1096,1102],"code",{"__ignoreMap":11},[991,992,995],"span",{"class":993,"line":994},"line",1,[991,996,998],{"class":997},"sCsY4","# 更新包索引\n",[991,1000,1002,1006,1010],{"class":993,"line":1001},2,[991,1003,1005],{"class":1004},"snPdu","sudo",[991,1007,1009],{"class":1008},"sIIMD"," apt",[991,1011,1012],{"class":1008}," update\n",[991,1014,1016],{"class":993,"line":1015},3,[991,1017,1019],{"emptyLinePlaceholder":1018},true,"\n",[991,1021,1023],{"class":993,"line":1022},4,[991,1024,1025],{"class":997},"# 安装 Nginx\n",[991,1027,1029,1031,1033,1036,1039],{"class":993,"line":1028},5,[991,1030,1005],{"class":1004},[991,1032,1009],{"class":1008},[991,1034,1035],{"class":1008}," install",[991,1037,1038],{"class":1008}," nginx",[991,1040,1042],{"class":1041},"sBjJW"," -y\n",[991,1044,1046],{"class":993,"line":1045},6,[991,1047,1019],{"emptyLinePlaceholder":1018},[991,1049,1051],{"class":993,"line":1050},7,[991,1052,1053],{"class":997},"# 启动 Nginx\n",[991,1055,1057,1059,1062,1065],{"class":993,"line":1056},8,[991,1058,1005],{"class":1004},[991,1060,1061],{"class":1008}," systemctl",[991,1063,1064],{"class":1008}," start",[991,1066,1067],{"class":1008}," nginx\n",[991,1069,1071],{"class":993,"line":1070},9,[991,1072,1019],{"emptyLinePlaceholder":1018},[991,1074,1076],{"class":993,"line":1075},10,[991,1077,1078],{"class":997},"# 设置开机自启\n",[991,1080,1082,1084,1086,1089],{"class":993,"line":1081},11,[991,1083,1005],{"class":1004},[991,1085,1061],{"class":1008},[991,1087,1088],{"class":1008}," enable",[991,1090,1067],{"class":1008},[991,1092,1094],{"class":993,"line":1093},12,[991,1095,1019],{"emptyLinePlaceholder":1018},[991,1097,1099],{"class":993,"line":1098},13,[991,1100,1101],{"class":997},"# 检查状态\n",[991,1103,1105,1107,1109,1112],{"class":993,"line":1104},14,[991,1106,1005],{"class":1004},[991,1108,1061],{"class":1008},[991,1110,1111],{"class":1008}," status",[991,1113,1067],{"class":1008},[900,1115,1117],{"id":1116},"centosrhel","CentOS\u002FRHEL",[982,1119,1121],{"className":984,"code":1120,"language":986,"meta":11,"style":11},"# 安装 EPEL 仓库\nsudo yum install epel-release -y\n\n# 安装 Nginx\nsudo yum install nginx -y\n\n# 启动 Nginx\nsudo systemctl start nginx\n\n# 设置开机自启\nsudo systemctl enable nginx\n",[988,1122,1123,1128,1142,1146,1150,1162,1166,1170,1180,1184,1188],{"__ignoreMap":11},[991,1124,1125],{"class":993,"line":994},[991,1126,1127],{"class":997},"# 安装 EPEL 仓库\n",[991,1129,1130,1132,1135,1137,1140],{"class":993,"line":1001},[991,1131,1005],{"class":1004},[991,1133,1134],{"class":1008}," yum",[991,1136,1035],{"class":1008},[991,1138,1139],{"class":1008}," epel-release",[991,1141,1042],{"class":1041},[991,1143,1144],{"class":993,"line":1015},[991,1145,1019],{"emptyLinePlaceholder":1018},[991,1147,1148],{"class":993,"line":1022},[991,1149,1025],{"class":997},[991,1151,1152,1154,1156,1158,1160],{"class":993,"line":1028},[991,1153,1005],{"class":1004},[991,1155,1134],{"class":1008},[991,1157,1035],{"class":1008},[991,1159,1038],{"class":1008},[991,1161,1042],{"class":1041},[991,1163,1164],{"class":993,"line":1045},[991,1165,1019],{"emptyLinePlaceholder":1018},[991,1167,1168],{"class":993,"line":1050},[991,1169,1053],{"class":997},[991,1171,1172,1174,1176,1178],{"class":993,"line":1056},[991,1173,1005],{"class":1004},[991,1175,1061],{"class":1008},[991,1177,1064],{"class":1008},[991,1179,1067],{"class":1008},[991,1181,1182],{"class":993,"line":1070},[991,1183,1019],{"emptyLinePlaceholder":1018},[991,1185,1186],{"class":993,"line":1075},[991,1187,1078],{"class":997},[991,1189,1190,1192,1194,1196],{"class":993,"line":1081},[991,1191,1005],{"class":1004},[991,1193,1061],{"class":1008},[991,1195,1088],{"class":1008},[991,1197,1067],{"class":1008},[900,1199,1201],{"id":1200},"macos","macOS",[982,1203,1205],{"className":984,"code":1204,"language":986,"meta":11,"style":11},"# 使用 Homebrew 安装\nbrew install nginx\n\n# 启动 Nginx\nbrew services start nginx\n\n# 或者前台运行\nnginx\n",[988,1206,1207,1212,1221,1225,1229,1240,1244,1249],{"__ignoreMap":11},[991,1208,1209],{"class":993,"line":994},[991,1210,1211],{"class":997},"# 使用 Homebrew 安装\n",[991,1213,1214,1217,1219],{"class":993,"line":1001},[991,1215,1216],{"class":1004},"brew",[991,1218,1035],{"class":1008},[991,1220,1067],{"class":1008},[991,1222,1223],{"class":993,"line":1015},[991,1224,1019],{"emptyLinePlaceholder":1018},[991,1226,1227],{"class":993,"line":1022},[991,1228,1053],{"class":997},[991,1230,1231,1233,1236,1238],{"class":993,"line":1028},[991,1232,1216],{"class":1004},[991,1234,1235],{"class":1008}," services",[991,1237,1064],{"class":1008},[991,1239,1067],{"class":1008},[991,1241,1242],{"class":993,"line":1045},[991,1243,1019],{"emptyLinePlaceholder":1018},[991,1245,1246],{"class":993,"line":1050},[991,1247,1248],{"class":997},"# 或者前台运行\n",[991,1250,1251],{"class":993,"line":1056},[991,1252,1253],{"class":1004},"nginx\n",[900,1255,1257],{"id":1256},"docker","Docker",[982,1259,1261],{"className":984,"code":1260,"language":986,"meta":11,"style":11},"# 拉取镜像\ndocker pull nginx:latest\n\n# 运行容器\ndocker run -d \\\n  --name nginx \\\n  -p 80:80 \\\n  -v \u002Fpath\u002Fto\u002Fhtml:\u002Fusr\u002Fshare\u002Fnginx\u002Fhtml \\\n  -v \u002Fpath\u002Fto\u002Fnginx.conf:\u002Fetc\u002Fnginx\u002Fnginx.conf \\\n  nginx:latest\n",[988,1262,1263,1268,1278,1282,1287,1300,1309,1319,1329,1338],{"__ignoreMap":11},[991,1264,1265],{"class":993,"line":994},[991,1266,1267],{"class":997},"# 拉取镜像\n",[991,1269,1270,1272,1275],{"class":993,"line":1001},[991,1271,1256],{"class":1004},[991,1273,1274],{"class":1008}," pull",[991,1276,1277],{"class":1008}," nginx:latest\n",[991,1279,1280],{"class":993,"line":1015},[991,1281,1019],{"emptyLinePlaceholder":1018},[991,1283,1284],{"class":993,"line":1022},[991,1285,1286],{"class":997},"# 运行容器\n",[991,1288,1289,1291,1294,1297],{"class":993,"line":1028},[991,1290,1256],{"class":1004},[991,1292,1293],{"class":1008}," run",[991,1295,1296],{"class":1041}," -d",[991,1298,1299],{"class":1041}," \\\n",[991,1301,1302,1305,1307],{"class":993,"line":1045},[991,1303,1304],{"class":1041},"  --name",[991,1306,1038],{"class":1008},[991,1308,1299],{"class":1041},[991,1310,1311,1314,1317],{"class":993,"line":1050},[991,1312,1313],{"class":1041},"  -p",[991,1315,1316],{"class":1008}," 80:80",[991,1318,1299],{"class":1041},[991,1320,1321,1324,1327],{"class":993,"line":1056},[991,1322,1323],{"class":1041},"  -v",[991,1325,1326],{"class":1008}," \u002Fpath\u002Fto\u002Fhtml:\u002Fusr\u002Fshare\u002Fnginx\u002Fhtml",[991,1328,1299],{"class":1041},[991,1330,1331,1333,1336],{"class":993,"line":1070},[991,1332,1323],{"class":1041},[991,1334,1335],{"class":1008}," \u002Fpath\u002Fto\u002Fnginx.conf:\u002Fetc\u002Fnginx\u002Fnginx.conf",[991,1337,1299],{"class":1041},[991,1339,1340],{"class":993,"line":1075},[991,1341,1342],{"class":1008},"  nginx:latest\n",[900,1344,1345],{"id":1345},"从源码编译",[982,1347,1349],{"className":984,"code":1348,"language":986,"meta":11,"style":11},"# 安装依赖\nsudo apt install build-essential libpcre3 libpcre3-dev zlib1g zlib1g-dev libssl-dev libgeoip-dev -y\n\n# 下载源码\nwget http:\u002F\u002Fnginx.org\u002Fdownload\u002Fnginx-1.24.0.tar.gz\ntar -zxvf nginx-1.24.0.tar.gz\ncd nginx-1.24.0\n\n# 配置编译选项\n.\u002Fconfigure \\\n  --prefix=\u002Fetc\u002Fnginx \\\n  --sbin-path=\u002Fusr\u002Fsbin\u002Fnginx \\\n  --modules-path=\u002Fusr\u002Flib64\u002Fnginx\u002Fmodules \\\n  --conf-path=\u002Fetc\u002Fnginx\u002Fnginx.conf \\\n  --error-log-path=\u002Fvar\u002Flog\u002Fnginx\u002Ferror.log \\\n  --http-log-path=\u002Fvar\u002Flog\u002Fnginx\u002Faccess.log \\\n  --pid-path=\u002Fvar\u002Frun\u002Fnginx.pid \\\n  --with-http_ssl_module \\\n  --with-http_v2_module \\\n  --with-http_realip_module \\\n  --with-http_gzip_static_module\n\n# 编译安装\nmake && sudo make install\n",[988,1350,1351,1356,1387,1391,1396,1404,1415,1423,1427,1432,1439,1446,1453,1460,1467,1475,1483,1491,1499,1507,1515,1521,1526,1532],{"__ignoreMap":11},[991,1352,1353],{"class":993,"line":994},[991,1354,1355],{"class":997},"# 安装依赖\n",[991,1357,1358,1360,1362,1364,1367,1370,1373,1376,1379,1382,1385],{"class":993,"line":1001},[991,1359,1005],{"class":1004},[991,1361,1009],{"class":1008},[991,1363,1035],{"class":1008},[991,1365,1366],{"class":1008}," build-essential",[991,1368,1369],{"class":1008}," libpcre3",[991,1371,1372],{"class":1008}," libpcre3-dev",[991,1374,1375],{"class":1008}," zlib1g",[991,1377,1378],{"class":1008}," zlib1g-dev",[991,1380,1381],{"class":1008}," libssl-dev",[991,1383,1384],{"class":1008}," libgeoip-dev",[991,1386,1042],{"class":1041},[991,1388,1389],{"class":993,"line":1015},[991,1390,1019],{"emptyLinePlaceholder":1018},[991,1392,1393],{"class":993,"line":1022},[991,1394,1395],{"class":997},"# 下载源码\n",[991,1397,1398,1401],{"class":993,"line":1028},[991,1399,1400],{"class":1004},"wget",[991,1402,1403],{"class":1008}," http:\u002F\u002Fnginx.org\u002Fdownload\u002Fnginx-1.24.0.tar.gz\n",[991,1405,1406,1409,1412],{"class":993,"line":1045},[991,1407,1408],{"class":1004},"tar",[991,1410,1411],{"class":1041}," -zxvf",[991,1413,1414],{"class":1008}," nginx-1.24.0.tar.gz\n",[991,1416,1417,1420],{"class":993,"line":1050},[991,1418,1419],{"class":1041},"cd",[991,1421,1422],{"class":1008}," nginx-1.24.0\n",[991,1424,1425],{"class":993,"line":1056},[991,1426,1019],{"emptyLinePlaceholder":1018},[991,1428,1429],{"class":993,"line":1070},[991,1430,1431],{"class":997},"# 配置编译选项\n",[991,1433,1434,1437],{"class":993,"line":1075},[991,1435,1436],{"class":1004},".\u002Fconfigure",[991,1438,1299],{"class":1041},[991,1440,1441,1444],{"class":993,"line":1081},[991,1442,1443],{"class":1041},"  --prefix=\u002Fetc\u002Fnginx",[991,1445,1299],{"class":1041},[991,1447,1448,1451],{"class":993,"line":1093},[991,1449,1450],{"class":1041},"  --sbin-path=\u002Fusr\u002Fsbin\u002Fnginx",[991,1452,1299],{"class":1041},[991,1454,1455,1458],{"class":993,"line":1098},[991,1456,1457],{"class":1041},"  --modules-path=\u002Fusr\u002Flib64\u002Fnginx\u002Fmodules",[991,1459,1299],{"class":1041},[991,1461,1462,1465],{"class":993,"line":1104},[991,1463,1464],{"class":1041},"  --conf-path=\u002Fetc\u002Fnginx\u002Fnginx.conf",[991,1466,1299],{"class":1041},[991,1468,1470,1473],{"class":993,"line":1469},15,[991,1471,1472],{"class":1041},"  --error-log-path=\u002Fvar\u002Flog\u002Fnginx\u002Ferror.log",[991,1474,1299],{"class":1041},[991,1476,1478,1481],{"class":993,"line":1477},16,[991,1479,1480],{"class":1041},"  --http-log-path=\u002Fvar\u002Flog\u002Fnginx\u002Faccess.log",[991,1482,1299],{"class":1041},[991,1484,1486,1489],{"class":993,"line":1485},17,[991,1487,1488],{"class":1041},"  --pid-path=\u002Fvar\u002Frun\u002Fnginx.pid",[991,1490,1299],{"class":1041},[991,1492,1494,1497],{"class":993,"line":1493},18,[991,1495,1496],{"class":1041},"  --with-http_ssl_module",[991,1498,1299],{"class":1041},[991,1500,1502,1505],{"class":993,"line":1501},19,[991,1503,1504],{"class":1041},"  --with-http_v2_module",[991,1506,1299],{"class":1041},[991,1508,1510,1513],{"class":993,"line":1509},20,[991,1511,1512],{"class":1041},"  --with-http_realip_module",[991,1514,1299],{"class":1041},[991,1516,1518],{"class":993,"line":1517},21,[991,1519,1520],{"class":1041},"  --with-http_gzip_static_module\n",[991,1522,1524],{"class":993,"line":1523},22,[991,1525,1019],{"emptyLinePlaceholder":1018},[991,1527,1529],{"class":993,"line":1528},23,[991,1530,1531],{"class":997},"# 编译安装\n",[991,1533,1535,1538,1542,1544,1547],{"class":993,"line":1534},24,[991,1536,1537],{"class":1004},"make",[991,1539,1541],{"class":1540},"sxrX7"," && ",[991,1543,1005],{"class":1004},[991,1545,1546],{"class":1008}," make",[991,1548,1549],{"class":1008}," install\n",[892,1551,1552],{"id":1552},"目录结构",[896,1554,1555],{},"安装完成后，Nginx 的主要目录结构如下：",[982,1557,1562],{"className":1558,"code":1560,"language":1561},[1559],"language-text","\u002Fetc\u002Fnginx\u002F                 # 配置目录\n├── nginx.conf              # 主配置文件\n├── conf.d\u002F                 # 额外配置目录\n│   └── default.conf        # 默认站点配置\n├── sites-available\u002F        # 可用站点配置（Ubuntu）\n├── sites-enabled\u002F          # 启用的站点配置（Ubuntu）\n├── mime.types              # MIME 类型映射\n├── fastcgi_params          # FastCGI 参数\n├── uwsgi_params            # uWSGI 参数\n└── snippets\u002F               # 配置片段\n\n\u002Fvar\u002Flog\u002Fnginx\u002F             # 日志目录\n├── access.log              # 访问日志\n└── error.log               # 错误日志\n\n\u002Fusr\u002Fshare\u002Fnginx\u002Fhtml\u002F      # 默认网站根目录\n├── index.html              # 默认首页\n└── 50x.html                # 错误页面\n\n\u002Fvar\u002Frun\u002Fnginx.pid          # 进程 ID 文件\n","text",[988,1563,1560],{"__ignoreMap":11},[892,1565,1566],{"id":1566},"基本命令",[900,1568,1569],{"id":1569},"服务管理",[982,1571,1573],{"className":984,"code":1572,"language":986,"meta":11,"style":11},"# 启动 Nginx\nsudo systemctl start nginx\nsudo nginx\n\n# 停止 Nginx\nsudo systemctl stop nginx\nsudo nginx -s stop      # 快速停止\nsudo nginx -s quit      # 优雅停止（等待请求处理完成）\n\n# 重启 Nginx\nsudo systemctl restart nginx\n\n# 重新加载配置（不中断服务）\nsudo systemctl reload nginx\nsudo nginx -s reload\n\n# 查看状态\nsudo systemctl status nginx\n",[988,1574,1575,1579,1589,1595,1599,1604,1615,1629,1643,1647,1652,1663,1667,1672,1683,1694,1698,1703],{"__ignoreMap":11},[991,1576,1577],{"class":993,"line":994},[991,1578,1053],{"class":997},[991,1580,1581,1583,1585,1587],{"class":993,"line":1001},[991,1582,1005],{"class":1004},[991,1584,1061],{"class":1008},[991,1586,1064],{"class":1008},[991,1588,1067],{"class":1008},[991,1590,1591,1593],{"class":993,"line":1015},[991,1592,1005],{"class":1004},[991,1594,1067],{"class":1008},[991,1596,1597],{"class":993,"line":1022},[991,1598,1019],{"emptyLinePlaceholder":1018},[991,1600,1601],{"class":993,"line":1028},[991,1602,1603],{"class":997},"# 停止 Nginx\n",[991,1605,1606,1608,1610,1613],{"class":993,"line":1045},[991,1607,1005],{"class":1004},[991,1609,1061],{"class":1008},[991,1611,1612],{"class":1008}," stop",[991,1614,1067],{"class":1008},[991,1616,1617,1619,1621,1624,1626],{"class":993,"line":1050},[991,1618,1005],{"class":1004},[991,1620,1038],{"class":1008},[991,1622,1623],{"class":1041}," -s",[991,1625,1612],{"class":1008},[991,1627,1628],{"class":997},"      # 快速停止\n",[991,1630,1631,1633,1635,1637,1640],{"class":993,"line":1056},[991,1632,1005],{"class":1004},[991,1634,1038],{"class":1008},[991,1636,1623],{"class":1041},[991,1638,1639],{"class":1008}," quit",[991,1641,1642],{"class":997},"      # 优雅停止（等待请求处理完成）\n",[991,1644,1645],{"class":993,"line":1070},[991,1646,1019],{"emptyLinePlaceholder":1018},[991,1648,1649],{"class":993,"line":1075},[991,1650,1651],{"class":997},"# 重启 Nginx\n",[991,1653,1654,1656,1658,1661],{"class":993,"line":1081},[991,1655,1005],{"class":1004},[991,1657,1061],{"class":1008},[991,1659,1660],{"class":1008}," restart",[991,1662,1067],{"class":1008},[991,1664,1665],{"class":993,"line":1093},[991,1666,1019],{"emptyLinePlaceholder":1018},[991,1668,1669],{"class":993,"line":1098},[991,1670,1671],{"class":997},"# 重新加载配置（不中断服务）\n",[991,1673,1674,1676,1678,1681],{"class":993,"line":1104},[991,1675,1005],{"class":1004},[991,1677,1061],{"class":1008},[991,1679,1680],{"class":1008}," reload",[991,1682,1067],{"class":1008},[991,1684,1685,1687,1689,1691],{"class":993,"line":1469},[991,1686,1005],{"class":1004},[991,1688,1038],{"class":1008},[991,1690,1623],{"class":1041},[991,1692,1693],{"class":1008}," reload\n",[991,1695,1696],{"class":993,"line":1477},[991,1697,1019],{"emptyLinePlaceholder":1018},[991,1699,1700],{"class":993,"line":1485},[991,1701,1702],{"class":997},"# 查看状态\n",[991,1704,1705,1707,1709,1711],{"class":993,"line":1493},[991,1706,1005],{"class":1004},[991,1708,1061],{"class":1008},[991,1710,1111],{"class":1008},[991,1712,1067],{"class":1008},[900,1714,1715],{"id":1715},"配置管理",[982,1717,1719],{"className":984,"code":1718,"language":986,"meta":11,"style":11},"# 测试配置文件语法\nsudo nginx -t\n\n# 测试配置并显示配置内容\nsudo nginx -T\n\n# 查看 Nginx 版本\nnginx -v\n\n# 查看 Nginx 版本及编译参数\nnginx -V\n\n# 指定配置文件启动\nsudo nginx -c \u002Fpath\u002Fto\u002Fnginx.conf\n",[988,1720,1721,1726,1735,1739,1744,1753,1757,1762,1770,1774,1779,1786,1790,1795],{"__ignoreMap":11},[991,1722,1723],{"class":993,"line":994},[991,1724,1725],{"class":997},"# 测试配置文件语法\n",[991,1727,1728,1730,1732],{"class":993,"line":1001},[991,1729,1005],{"class":1004},[991,1731,1038],{"class":1008},[991,1733,1734],{"class":1041}," -t\n",[991,1736,1737],{"class":993,"line":1015},[991,1738,1019],{"emptyLinePlaceholder":1018},[991,1740,1741],{"class":993,"line":1022},[991,1742,1743],{"class":997},"# 测试配置并显示配置内容\n",[991,1745,1746,1748,1750],{"class":993,"line":1028},[991,1747,1005],{"class":1004},[991,1749,1038],{"class":1008},[991,1751,1752],{"class":1041}," -T\n",[991,1754,1755],{"class":993,"line":1045},[991,1756,1019],{"emptyLinePlaceholder":1018},[991,1758,1759],{"class":993,"line":1050},[991,1760,1761],{"class":997},"# 查看 Nginx 版本\n",[991,1763,1764,1767],{"class":993,"line":1056},[991,1765,1766],{"class":1004},"nginx",[991,1768,1769],{"class":1041}," -v\n",[991,1771,1772],{"class":993,"line":1070},[991,1773,1019],{"emptyLinePlaceholder":1018},[991,1775,1776],{"class":993,"line":1075},[991,1777,1778],{"class":997},"# 查看 Nginx 版本及编译参数\n",[991,1780,1781,1783],{"class":993,"line":1081},[991,1782,1766],{"class":1004},[991,1784,1785],{"class":1041}," -V\n",[991,1787,1788],{"class":993,"line":1093},[991,1789,1019],{"emptyLinePlaceholder":1018},[991,1791,1792],{"class":993,"line":1098},[991,1793,1794],{"class":997},"# 指定配置文件启动\n",[991,1796,1797,1799,1801,1804],{"class":993,"line":1104},[991,1798,1005],{"class":1004},[991,1800,1038],{"class":1008},[991,1802,1803],{"class":1041}," -c",[991,1805,1806],{"class":1008}," \u002Fpath\u002Fto\u002Fnginx.conf\n",[900,1808,1809],{"id":1809},"进程管理",[982,1811,1813],{"className":984,"code":1812,"language":986,"meta":11,"style":11},"# 查看 Nginx 进程\nps aux | grep nginx\n\n# 查看主进程 ID\ncat \u002Fvar\u002Frun\u002Fnginx.pid\n\n# 发送信号\nkill -HUP $(cat \u002Fvar\u002Frun\u002Fnginx.pid)   # 重新加载配置\nkill -USR1 $(cat \u002Fvar\u002Frun\u002Fnginx.pid)  # 重新打开日志文件\nkill -USR2 $(cat \u002Fvar\u002Frun\u002Fnginx.pid)  # 平滑升级\n",[988,1814,1815,1820,1837,1841,1846,1854,1858,1863,1885,1904],{"__ignoreMap":11},[991,1816,1817],{"class":993,"line":994},[991,1818,1819],{"class":997},"# 查看 Nginx 进程\n",[991,1821,1822,1825,1828,1832,1835],{"class":993,"line":1001},[991,1823,1824],{"class":1004},"ps",[991,1826,1827],{"class":1008}," aux",[991,1829,1831],{"class":1830},"s8jYJ"," |",[991,1833,1834],{"class":1004}," grep",[991,1836,1067],{"class":1008},[991,1838,1839],{"class":993,"line":1015},[991,1840,1019],{"emptyLinePlaceholder":1018},[991,1842,1843],{"class":993,"line":1022},[991,1844,1845],{"class":997},"# 查看主进程 ID\n",[991,1847,1848,1851],{"class":993,"line":1028},[991,1849,1850],{"class":1004},"cat",[991,1852,1853],{"class":1008}," \u002Fvar\u002Frun\u002Fnginx.pid\n",[991,1855,1856],{"class":993,"line":1045},[991,1857,1019],{"emptyLinePlaceholder":1018},[991,1859,1860],{"class":993,"line":1050},[991,1861,1862],{"class":997},"# 发送信号\n",[991,1864,1865,1868,1871,1874,1876,1879,1882],{"class":993,"line":1056},[991,1866,1867],{"class":1041},"kill",[991,1869,1870],{"class":1041}," -HUP",[991,1872,1873],{"class":1540}," $(",[991,1875,1850],{"class":1004},[991,1877,1878],{"class":1008}," \u002Fvar\u002Frun\u002Fnginx.pid",[991,1880,1881],{"class":1540},")   ",[991,1883,1884],{"class":997},"# 重新加载配置\n",[991,1886,1887,1889,1892,1894,1896,1898,1901],{"class":993,"line":1070},[991,1888,1867],{"class":1041},[991,1890,1891],{"class":1041}," -USR1",[991,1893,1873],{"class":1540},[991,1895,1850],{"class":1004},[991,1897,1878],{"class":1008},[991,1899,1900],{"class":1540},")  ",[991,1902,1903],{"class":997},"# 重新打开日志文件\n",[991,1905,1906,1908,1911,1913,1915,1917,1919],{"class":993,"line":1075},[991,1907,1867],{"class":1041},[991,1909,1910],{"class":1041}," -USR2",[991,1912,1873],{"class":1540},[991,1914,1850],{"class":1004},[991,1916,1878],{"class":1008},[991,1918,1900],{"class":1540},[991,1920,1921],{"class":997},"# 平滑升级\n",[892,1923,1924],{"id":1924},"配置文件详解",[900,1926,1927],{"id":1927},"主配置文件结构",[982,1929,1932],{"className":1930,"code":1931,"language":1766,"meta":11,"style":11},"language-nginx shiki shiki-themes github-light github-light github-dark","# \u002Fetc\u002Fnginx\u002Fnginx.conf\n\n# 全局块：配置影响 Nginx 全局的指令\nuser nginx;                          # 运行用户\nworker_processes auto;               # 工作进程数\nerror_log \u002Fvar\u002Flog\u002Fnginx\u002Ferror.log;  # 错误日志\npid \u002Frun\u002Fnginx.pid;                  # 进程 ID 文件\n\n# 事件块：配置影响 Nginx 服务器与用户的网络连接\nevents {\n    worker_connections 1024;         # 每个进程最大连接数\n    use epoll;                       # 使用 epoll 事件模型（Linux）\n    multi_accept on;                 # 一次接受多个连接\n}\n\n# HTTP 块：配置 HTTP 服务器\nhttp {\n    # 基本设置\n    include \u002Fetc\u002Fnginx\u002Fmime.types;\n    default_type application\u002Foctet-stream;\n    \n    # 日志格式\n    log_format main '$remote_addr - $remote_user [$time_local] \"$request\" '\n                    '$status $body_bytes_sent \"$http_referer\" '\n                    '\"$http_user_agent\" \"$http_x_forwarded_for\"';\n    access_log \u002Fvar\u002Flog\u002Fnginx\u002Faccess.log main;\n    \n    # 性能优化\n    sendfile on;\n    tcp_nopush on;\n    tcp_nodelay on;\n    keepalive_timeout 65;\n    types_hash_max_size 2048;\n    \n    # Gzip 压缩\n    gzip on;\n    gzip_types text\u002Fplain text\u002Fcss application\u002Fjson application\u002Fjavascript;\n    \n    # 包含其他配置文件\n    include \u002Fetc\u002Fnginx\u002Fconf.d\u002F*.conf;\n    include \u002Fetc\u002Fnginx\u002Fsites-enabled\u002F*;\n    \n    # Server 块：配置虚拟主机\n    server {\n        listen 80;\n        server_name localhost;\n        root \u002Fusr\u002Fshare\u002Fnginx\u002Fhtml;\n        index index.html;\n        \n        # Location 块：配置请求路由\n        location \u002F {\n            try_files $uri $uri\u002F =404;\n        }\n        \n        # 错误页面\n        error_page 500 502 503 504 \u002F50x.html;\n        location = \u002F50x.html {\n            root \u002Fusr\u002Fshare\u002Fnginx\u002Fhtml;\n        }\n    }\n}\n",[988,1933,1934,1939,1943,1948,1959,1970,1981,1992,1996,2001,2009,2023,2037,2051,2056,2060,2065,2072,2077,2085,2093,2098,2103,2138,2160,2181,2194,2199,2205,2215,2225,2235,2246,2257,2262,2268,2278,2287,2292,2298,2306,2314,2319,2325,2333,2344,2353,2362,2371,2377,2383,2395,2409,2415,2420,2426,2447,2461,2469,2474,2480],{"__ignoreMap":11},[991,1935,1936],{"class":993,"line":994},[991,1937,1938],{"class":997},"# \u002Fetc\u002Fnginx\u002Fnginx.conf\n",[991,1940,1941],{"class":993,"line":1001},[991,1942,1019],{"emptyLinePlaceholder":1018},[991,1944,1945],{"class":993,"line":1015},[991,1946,1947],{"class":997},"# 全局块：配置影响 Nginx 全局的指令\n",[991,1949,1950,1953,1956],{"class":993,"line":1022},[991,1951,1952],{"class":1830},"user ",[991,1954,1955],{"class":1540},"nginx;                          ",[991,1957,1958],{"class":997},"# 运行用户\n",[991,1960,1961,1964,1967],{"class":993,"line":1028},[991,1962,1963],{"class":1830},"worker_processes ",[991,1965,1966],{"class":1540},"auto;               ",[991,1968,1969],{"class":997},"# 工作进程数\n",[991,1971,1972,1975,1978],{"class":993,"line":1045},[991,1973,1974],{"class":1830},"error_log ",[991,1976,1977],{"class":1540},"\u002Fvar\u002Flog\u002Fnginx\u002Ferror.log;  ",[991,1979,1980],{"class":997},"# 错误日志\n",[991,1982,1983,1986,1989],{"class":993,"line":1050},[991,1984,1985],{"class":1830},"pid ",[991,1987,1988],{"class":1540},"\u002Frun\u002Fnginx.pid;                  ",[991,1990,1991],{"class":997},"# 进程 ID 文件\n",[991,1993,1994],{"class":993,"line":1056},[991,1995,1019],{"emptyLinePlaceholder":1018},[991,1997,1998],{"class":993,"line":1070},[991,1999,2000],{"class":997},"# 事件块：配置影响 Nginx 服务器与用户的网络连接\n",[991,2002,2003,2006],{"class":993,"line":1075},[991,2004,2005],{"class":1830},"events",[991,2007,2008],{"class":1540}," {\n",[991,2010,2011,2014,2017,2020],{"class":993,"line":1081},[991,2012,2013],{"class":1830},"    worker_connections ",[991,2015,2016],{"class":1041},"1024",[991,2018,2019],{"class":1540},";         ",[991,2021,2022],{"class":997},"# 每个进程最大连接数\n",[991,2024,2025,2028,2031,2034],{"class":993,"line":1093},[991,2026,2027],{"class":1830},"    use ",[991,2029,2030],{"class":1041},"epoll",[991,2032,2033],{"class":1540},";                       ",[991,2035,2036],{"class":997},"# 使用 epoll 事件模型（Linux）\n",[991,2038,2039,2042,2045,2048],{"class":993,"line":1098},[991,2040,2041],{"class":1830},"    multi_accept ",[991,2043,2044],{"class":1041},"on",[991,2046,2047],{"class":1540},";                 ",[991,2049,2050],{"class":997},"# 一次接受多个连接\n",[991,2052,2053],{"class":993,"line":1104},[991,2054,2055],{"class":1540},"}\n",[991,2057,2058],{"class":993,"line":1469},[991,2059,1019],{"emptyLinePlaceholder":1018},[991,2061,2062],{"class":993,"line":1477},[991,2063,2064],{"class":997},"# HTTP 块：配置 HTTP 服务器\n",[991,2066,2067,2070],{"class":993,"line":1485},[991,2068,2069],{"class":1830},"http",[991,2071,2008],{"class":1540},[991,2073,2074],{"class":993,"line":1493},[991,2075,2076],{"class":997},"    # 基本设置\n",[991,2078,2079,2082],{"class":993,"line":1501},[991,2080,2081],{"class":1830},"    include ",[991,2083,2084],{"class":1540},"\u002Fetc\u002Fnginx\u002Fmime.types;\n",[991,2086,2087,2090],{"class":993,"line":1509},[991,2088,2089],{"class":1830},"    default_type ",[991,2091,2092],{"class":1540},"application\u002Foctet-stream;\n",[991,2094,2095],{"class":993,"line":1517},[991,2096,2097],{"class":1540},"    \n",[991,2099,2100],{"class":993,"line":1523},[991,2101,2102],{"class":997},"    # 日志格式\n",[991,2104,2105,2108,2111,2114,2117,2120,2123,2126,2129,2132,2135],{"class":993,"line":1528},[991,2106,2107],{"class":1830},"    log_format ",[991,2109,2110],{"class":1041},"main",[991,2112,2113],{"class":1008}," '$",[991,2115,2116],{"class":1540},"remote_addr",[991,2118,2119],{"class":1008}," - $",[991,2121,2122],{"class":1540},"remote_user",[991,2124,2125],{"class":1008}," [$",[991,2127,2128],{"class":1540},"time_local",[991,2130,2131],{"class":1008},"] \"$",[991,2133,2134],{"class":1540},"request",[991,2136,2137],{"class":1008},"\" '\n",[991,2139,2140,2143,2146,2149,2152,2155,2158],{"class":993,"line":1534},[991,2141,2142],{"class":1008},"                    '$",[991,2144,2145],{"class":1540},"status",[991,2147,2148],{"class":1008}," $",[991,2150,2151],{"class":1540},"body_bytes_sent",[991,2153,2154],{"class":1008}," \"$",[991,2156,2157],{"class":1540},"http_referer",[991,2159,2137],{"class":1008},[991,2161,2163,2166,2169,2172,2175,2178],{"class":993,"line":2162},25,[991,2164,2165],{"class":1008},"                    '\"$",[991,2167,2168],{"class":1540},"http_user_agent",[991,2170,2171],{"class":1008},"\" \"$",[991,2173,2174],{"class":1540},"http_x_forwarded_for",[991,2176,2177],{"class":1008},"\"'",[991,2179,2180],{"class":1540},";\n",[991,2182,2184,2187,2190,2192],{"class":993,"line":2183},26,[991,2185,2186],{"class":1830},"    access_log ",[991,2188,2189],{"class":1540},"\u002Fvar\u002Flog\u002Fnginx\u002Faccess.log ",[991,2191,2110],{"class":1041},[991,2193,2180],{"class":1540},[991,2195,2197],{"class":993,"line":2196},27,[991,2198,2097],{"class":1540},[991,2200,2202],{"class":993,"line":2201},28,[991,2203,2204],{"class":997},"    # 性能优化\n",[991,2206,2208,2211,2213],{"class":993,"line":2207},29,[991,2209,2210],{"class":1830},"    sendfile ",[991,2212,2044],{"class":1041},[991,2214,2180],{"class":1540},[991,2216,2218,2221,2223],{"class":993,"line":2217},30,[991,2219,2220],{"class":1830},"    tcp_nopush ",[991,2222,2044],{"class":1041},[991,2224,2180],{"class":1540},[991,2226,2228,2231,2233],{"class":993,"line":2227},31,[991,2229,2230],{"class":1830},"    tcp_nodelay ",[991,2232,2044],{"class":1041},[991,2234,2180],{"class":1540},[991,2236,2238,2241,2244],{"class":993,"line":2237},32,[991,2239,2240],{"class":1830},"    keepalive_timeout ",[991,2242,2243],{"class":1041},"65",[991,2245,2180],{"class":1540},[991,2247,2249,2252,2255],{"class":993,"line":2248},33,[991,2250,2251],{"class":1830},"    types_hash_max_size ",[991,2253,2254],{"class":1041},"2048",[991,2256,2180],{"class":1540},[991,2258,2260],{"class":993,"line":2259},34,[991,2261,2097],{"class":1540},[991,2263,2265],{"class":993,"line":2264},35,[991,2266,2267],{"class":997},"    # Gzip 压缩\n",[991,2269,2271,2274,2276],{"class":993,"line":2270},36,[991,2272,2273],{"class":1830},"    gzip ",[991,2275,2044],{"class":1041},[991,2277,2180],{"class":1540},[991,2279,2281,2284],{"class":993,"line":2280},37,[991,2282,2283],{"class":1830},"    gzip_types ",[991,2285,2286],{"class":1540},"text\u002Fplain text\u002Fcss application\u002Fjson application\u002Fjavascript;\n",[991,2288,2290],{"class":993,"line":2289},38,[991,2291,2097],{"class":1540},[991,2293,2295],{"class":993,"line":2294},39,[991,2296,2297],{"class":997},"    # 包含其他配置文件\n",[991,2299,2301,2303],{"class":993,"line":2300},40,[991,2302,2081],{"class":1830},[991,2304,2305],{"class":1540},"\u002Fetc\u002Fnginx\u002Fconf.d\u002F*.conf;\n",[991,2307,2309,2311],{"class":993,"line":2308},41,[991,2310,2081],{"class":1830},[991,2312,2313],{"class":1540},"\u002Fetc\u002Fnginx\u002Fsites-enabled\u002F*;\n",[991,2315,2317],{"class":993,"line":2316},42,[991,2318,2097],{"class":1540},[991,2320,2322],{"class":993,"line":2321},43,[991,2323,2324],{"class":997},"    # Server 块：配置虚拟主机\n",[991,2326,2328,2331],{"class":993,"line":2327},44,[991,2329,2330],{"class":1830},"    server",[991,2332,2008],{"class":1540},[991,2334,2336,2339,2342],{"class":993,"line":2335},45,[991,2337,2338],{"class":1830},"        listen ",[991,2340,2341],{"class":1041},"80",[991,2343,2180],{"class":1540},[991,2345,2347,2350],{"class":993,"line":2346},46,[991,2348,2349],{"class":1830},"        server_name ",[991,2351,2352],{"class":1540},"localhost;\n",[991,2354,2356,2359],{"class":993,"line":2355},47,[991,2357,2358],{"class":1830},"        root ",[991,2360,2361],{"class":1540},"\u002Fusr\u002Fshare\u002Fnginx\u002Fhtml;\n",[991,2363,2365,2368],{"class":993,"line":2364},48,[991,2366,2367],{"class":1830},"        index ",[991,2369,2370],{"class":1540},"index.html;\n",[991,2372,2374],{"class":993,"line":2373},49,[991,2375,2376],{"class":1540},"        \n",[991,2378,2380],{"class":993,"line":2379},50,[991,2381,2382],{"class":997},"        # Location 块：配置请求路由\n",[991,2384,2386,2389,2392],{"class":993,"line":2385},51,[991,2387,2388],{"class":1830},"        location",[991,2390,2391],{"class":1004}," \u002F ",[991,2393,2394],{"class":1540},"{\n",[991,2396,2398,2401,2404,2407],{"class":993,"line":2397},52,[991,2399,2400],{"class":1830},"            try_files ",[991,2402,2403],{"class":1540},"$uri $uri\u002F ",[991,2405,2406],{"class":1041},"=404",[991,2408,2180],{"class":1540},[991,2410,2412],{"class":993,"line":2411},53,[991,2413,2414],{"class":1540},"        }\n",[991,2416,2418],{"class":993,"line":2417},54,[991,2419,2376],{"class":1540},[991,2421,2423],{"class":993,"line":2422},55,[991,2424,2425],{"class":997},"        # 错误页面\n",[991,2427,2429,2432,2435,2438,2441,2444],{"class":993,"line":2428},56,[991,2430,2431],{"class":1830},"        error_page ",[991,2433,2434],{"class":1041},"500",[991,2436,2437],{"class":1041}," 502",[991,2439,2440],{"class":1041}," 503",[991,2442,2443],{"class":1041}," 504",[991,2445,2446],{"class":1540}," \u002F50x.html;\n",[991,2448,2450,2452,2455,2459],{"class":993,"line":2449},57,[991,2451,2388],{"class":1830},[991,2453,2454],{"class":1830}," =",[991,2456,2458],{"class":2457},"s3JiQ"," \u002F50x.html ",[991,2460,2394],{"class":1540},[991,2462,2464,2467],{"class":993,"line":2463},58,[991,2465,2466],{"class":1830},"            root ",[991,2468,2361],{"class":1540},[991,2470,2472],{"class":993,"line":2471},59,[991,2473,2414],{"class":1540},[991,2475,2477],{"class":993,"line":2476},60,[991,2478,2479],{"class":1540},"    }\n",[991,2481,2483],{"class":993,"line":2482},61,[991,2484,2055],{"class":1540},[900,2486,2487],{"id":2487},"配置块说明",[905,2489,2490,2502],{},[908,2491,2492],{},[911,2493,2494,2497,2500],{},[914,2495,2496],{"align":916},"配置块",[914,2498,2499],{"align":916},"作用范围",[914,2501,920],{"align":916},[922,2503,2504,2514,2523,2533,2544,2555],{},[911,2505,2506,2508,2511],{},[927,2507,2110],{"align":916},[927,2509,2510],{"align":916},"全局",[927,2512,2513],{"align":916},"配置工作进程、日志、PID 等",[911,2515,2516,2518,2520],{},[927,2517,2005],{"align":916},[927,2519,2510],{"align":916},[927,2521,2522],{"align":916},"配置事件模型和连接处理",[911,2524,2525,2527,2530],{},[927,2526,2069],{"align":916},[927,2528,2529],{"align":916},"HTTP",[927,2531,2532],{"align":916},"配置 HTTP 服务器通用选项",[911,2534,2535,2538,2541],{},[927,2536,2537],{"align":916},"server",[927,2539,2540],{"align":916},"虚拟主机",[927,2542,2543],{"align":916},"配置一个虚拟主机",[911,2545,2546,2549,2552],{},[927,2547,2548],{"align":916},"location",[927,2550,2551],{"align":916},"URL 路径",[927,2553,2554],{"align":916},"配置特定 URL 的处理方式",[911,2556,2557,2560,2562],{},[927,2558,2559],{"align":916},"upstream",[927,2561,2529],{"align":916},[927,2563,2564],{"align":916},"配置后端服务器组（用于负载均衡）",[900,2566,2567],{"id":2567},"常用指令",[2569,2570,2571],"h4",{"id":2571},"全局指令",[982,2573,2575],{"className":1930,"code":2574,"language":1766,"meta":11,"style":11},"# 运行用户和用户组\nuser nginx nginx;\n\n# 工作进程数（通常设为 CPU 核心数）\nworker_processes auto;\n# 或指定具体数字\nworker_processes 4;\n\n# 错误日志\nerror_log \u002Fvar\u002Flog\u002Fnginx\u002Ferror.log warn;\n# 日志级别: debug, info, notice, warn, error, crit, alert, emerg\n\n# 进程 ID 文件\npid \u002Fvar\u002Frun\u002Fnginx.pid;\n\n# 工作进程打开的最大文件描述符数\nworker_rlimit_nofile 65535;\n",[988,2576,2577,2582,2589,2593,2598,2605,2610,2619,2623,2627,2639,2644,2648,2652,2659,2663,2668],{"__ignoreMap":11},[991,2578,2579],{"class":993,"line":994},[991,2580,2581],{"class":997},"# 运行用户和用户组\n",[991,2583,2584,2586],{"class":993,"line":1001},[991,2585,1952],{"class":1830},[991,2587,2588],{"class":1540},"nginx nginx;\n",[991,2590,2591],{"class":993,"line":1015},[991,2592,1019],{"emptyLinePlaceholder":1018},[991,2594,2595],{"class":993,"line":1022},[991,2596,2597],{"class":997},"# 工作进程数（通常设为 CPU 核心数）\n",[991,2599,2600,2602],{"class":993,"line":1028},[991,2601,1963],{"class":1830},[991,2603,2604],{"class":1540},"auto;\n",[991,2606,2607],{"class":993,"line":1045},[991,2608,2609],{"class":997},"# 或指定具体数字\n",[991,2611,2612,2614,2617],{"class":993,"line":1050},[991,2613,1963],{"class":1830},[991,2615,2616],{"class":1041},"4",[991,2618,2180],{"class":1540},[991,2620,2621],{"class":993,"line":1056},[991,2622,1019],{"emptyLinePlaceholder":1018},[991,2624,2625],{"class":993,"line":1070},[991,2626,1980],{"class":997},[991,2628,2629,2631,2634,2637],{"class":993,"line":1075},[991,2630,1974],{"class":1830},[991,2632,2633],{"class":1540},"\u002Fvar\u002Flog\u002Fnginx\u002Ferror.log ",[991,2635,2636],{"class":1041},"warn",[991,2638,2180],{"class":1540},[991,2640,2641],{"class":993,"line":1081},[991,2642,2643],{"class":997},"# 日志级别: debug, info, notice, warn, error, crit, alert, emerg\n",[991,2645,2646],{"class":993,"line":1093},[991,2647,1019],{"emptyLinePlaceholder":1018},[991,2649,2650],{"class":993,"line":1098},[991,2651,1991],{"class":997},[991,2653,2654,2656],{"class":993,"line":1104},[991,2655,1985],{"class":1830},[991,2657,2658],{"class":1540},"\u002Fvar\u002Frun\u002Fnginx.pid;\n",[991,2660,2661],{"class":993,"line":1469},[991,2662,1019],{"emptyLinePlaceholder":1018},[991,2664,2665],{"class":993,"line":1477},[991,2666,2667],{"class":997},"# 工作进程打开的最大文件描述符数\n",[991,2669,2670,2673,2676],{"class":993,"line":1485},[991,2671,2672],{"class":1830},"worker_rlimit_nofile ",[991,2674,2675],{"class":1041},"65535",[991,2677,2180],{"class":1540},[2569,2679,2681],{"id":2680},"events-指令","events 指令",[982,2683,2685],{"className":1930,"code":2684,"language":1766,"meta":11,"style":11},"events {\n    # 每个工作进程的最大连接数\n    worker_connections 10240;\n    \n    # 事件驱动模型\n    use epoll;  # Linux\n    # use kqueue;  # FreeBSD\u002FmacOS\n    \n    # 是否一次接受多个连接\n    multi_accept on;\n    \n    # 是否接受互斥锁\n    accept_mutex on;\n}\n",[988,2686,2687,2693,2698,2707,2711,2716,2728,2733,2737,2742,2750,2754,2759,2768],{"__ignoreMap":11},[991,2688,2689,2691],{"class":993,"line":994},[991,2690,2005],{"class":1830},[991,2692,2008],{"class":1540},[991,2694,2695],{"class":993,"line":1001},[991,2696,2697],{"class":997},"    # 每个工作进程的最大连接数\n",[991,2699,2700,2702,2705],{"class":993,"line":1015},[991,2701,2013],{"class":1830},[991,2703,2704],{"class":1041},"10240",[991,2706,2180],{"class":1540},[991,2708,2709],{"class":993,"line":1022},[991,2710,2097],{"class":1540},[991,2712,2713],{"class":993,"line":1028},[991,2714,2715],{"class":997},"    # 事件驱动模型\n",[991,2717,2718,2720,2722,2725],{"class":993,"line":1045},[991,2719,2027],{"class":1830},[991,2721,2030],{"class":1041},[991,2723,2724],{"class":1540},";  ",[991,2726,2727],{"class":997},"# Linux\n",[991,2729,2730],{"class":993,"line":1050},[991,2731,2732],{"class":997},"    # use kqueue;  # FreeBSD\u002FmacOS\n",[991,2734,2735],{"class":993,"line":1056},[991,2736,2097],{"class":1540},[991,2738,2739],{"class":993,"line":1070},[991,2740,2741],{"class":997},"    # 是否一次接受多个连接\n",[991,2743,2744,2746,2748],{"class":993,"line":1075},[991,2745,2041],{"class":1830},[991,2747,2044],{"class":1041},[991,2749,2180],{"class":1540},[991,2751,2752],{"class":993,"line":1081},[991,2753,2097],{"class":1540},[991,2755,2756],{"class":993,"line":1093},[991,2757,2758],{"class":997},"    # 是否接受互斥锁\n",[991,2760,2761,2764,2766],{"class":993,"line":1098},[991,2762,2763],{"class":1830},"    accept_mutex ",[991,2765,2044],{"class":1041},[991,2767,2180],{"class":1540},[991,2769,2770],{"class":993,"line":1104},[991,2771,2055],{"class":1540},[2569,2773,2775],{"id":2774},"http-指令","http 指令",[982,2777,2779],{"className":1930,"code":2778,"language":1766,"meta":11,"style":11},"http {\n    # MIME 类型\n    include mime.types;\n    default_type application\u002Foctet-stream;\n    \n    # 字符集\n    charset utf-8;\n    \n    # 日志格式\n    log_format main '$remote_addr - $remote_user [$time_local] '\n                    '\"$request\" $status $body_bytes_sent '\n                    '\"$http_referer\" \"$http_user_agent\"';\n    \n    # 访问日志\n    access_log \u002Fvar\u002Flog\u002Fnginx\u002Faccess.log main;\n    \n    # 高效文件传输\n    sendfile on;\n    tcp_nopush on;\n    tcp_nodelay on;\n    \n    # 连接超时\n    keepalive_timeout 65;\n    \n    # 客户端请求体大小限制\n    client_max_body_size 100m;\n    \n    # 请求头大小\n    client_header_buffer_size 4k;\n    large_client_header_buffers 4 32k;\n}\n",[988,2780,2781,2787,2792,2799,2805,2809,2814,2822,2826,2830,2851,2869,2883,2887,2892,2902,2906,2911,2919,2927,2935,2939,2944,2952,2956,2961,2971,2975,2980,2990,3002],{"__ignoreMap":11},[991,2782,2783,2785],{"class":993,"line":994},[991,2784,2069],{"class":1830},[991,2786,2008],{"class":1540},[991,2788,2789],{"class":993,"line":1001},[991,2790,2791],{"class":997},"    # MIME 类型\n",[991,2793,2794,2796],{"class":993,"line":1015},[991,2795,2081],{"class":1830},[991,2797,2798],{"class":1540},"mime.types;\n",[991,2800,2801,2803],{"class":993,"line":1022},[991,2802,2089],{"class":1830},[991,2804,2092],{"class":1540},[991,2806,2807],{"class":993,"line":1028},[991,2808,2097],{"class":1540},[991,2810,2811],{"class":993,"line":1045},[991,2812,2813],{"class":997},"    # 字符集\n",[991,2815,2816,2819],{"class":993,"line":1050},[991,2817,2818],{"class":1830},"    charset ",[991,2820,2821],{"class":1540},"utf-8;\n",[991,2823,2824],{"class":993,"line":1056},[991,2825,2097],{"class":1540},[991,2827,2828],{"class":993,"line":1070},[991,2829,2102],{"class":997},[991,2831,2832,2834,2836,2838,2840,2842,2844,2846,2848],{"class":993,"line":1075},[991,2833,2107],{"class":1830},[991,2835,2110],{"class":1041},[991,2837,2113],{"class":1008},[991,2839,2116],{"class":1540},[991,2841,2119],{"class":1008},[991,2843,2122],{"class":1540},[991,2845,2125],{"class":1008},[991,2847,2128],{"class":1540},[991,2849,2850],{"class":1008},"] '\n",[991,2852,2853,2855,2857,2860,2862,2864,2866],{"class":993,"line":1081},[991,2854,2165],{"class":1008},[991,2856,2134],{"class":1540},[991,2858,2859],{"class":1008},"\" $",[991,2861,2145],{"class":1540},[991,2863,2148],{"class":1008},[991,2865,2151],{"class":1540},[991,2867,2868],{"class":1008}," '\n",[991,2870,2871,2873,2875,2877,2879,2881],{"class":993,"line":1093},[991,2872,2165],{"class":1008},[991,2874,2157],{"class":1540},[991,2876,2171],{"class":1008},[991,2878,2168],{"class":1540},[991,2880,2177],{"class":1008},[991,2882,2180],{"class":1540},[991,2884,2885],{"class":993,"line":1098},[991,2886,2097],{"class":1540},[991,2888,2889],{"class":993,"line":1104},[991,2890,2891],{"class":997},"    # 访问日志\n",[991,2893,2894,2896,2898,2900],{"class":993,"line":1469},[991,2895,2186],{"class":1830},[991,2897,2189],{"class":1540},[991,2899,2110],{"class":1041},[991,2901,2180],{"class":1540},[991,2903,2904],{"class":993,"line":1477},[991,2905,2097],{"class":1540},[991,2907,2908],{"class":993,"line":1485},[991,2909,2910],{"class":997},"    # 高效文件传输\n",[991,2912,2913,2915,2917],{"class":993,"line":1493},[991,2914,2210],{"class":1830},[991,2916,2044],{"class":1041},[991,2918,2180],{"class":1540},[991,2920,2921,2923,2925],{"class":993,"line":1501},[991,2922,2220],{"class":1830},[991,2924,2044],{"class":1041},[991,2926,2180],{"class":1540},[991,2928,2929,2931,2933],{"class":993,"line":1509},[991,2930,2230],{"class":1830},[991,2932,2044],{"class":1041},[991,2934,2180],{"class":1540},[991,2936,2937],{"class":993,"line":1517},[991,2938,2097],{"class":1540},[991,2940,2941],{"class":993,"line":1523},[991,2942,2943],{"class":997},"    # 连接超时\n",[991,2945,2946,2948,2950],{"class":993,"line":1528},[991,2947,2240],{"class":1830},[991,2949,2243],{"class":1041},[991,2951,2180],{"class":1540},[991,2953,2954],{"class":993,"line":1534},[991,2955,2097],{"class":1540},[991,2957,2958],{"class":993,"line":2162},[991,2959,2960],{"class":997},"    # 客户端请求体大小限制\n",[991,2962,2963,2966,2969],{"class":993,"line":2183},[991,2964,2965],{"class":1830},"    client_max_body_size ",[991,2967,2968],{"class":1041},"100m",[991,2970,2180],{"class":1540},[991,2972,2973],{"class":993,"line":2196},[991,2974,2097],{"class":1540},[991,2976,2977],{"class":993,"line":2201},[991,2978,2979],{"class":997},"    # 请求头大小\n",[991,2981,2982,2985,2988],{"class":993,"line":2207},[991,2983,2984],{"class":1830},"    client_header_buffer_size ",[991,2986,2987],{"class":1041},"4k",[991,2989,2180],{"class":1540},[991,2991,2992,2995,2997,3000],{"class":993,"line":2217},[991,2993,2994],{"class":1830},"    large_client_header_buffers ",[991,2996,2616],{"class":1041},[991,2998,2999],{"class":1041}," 32k",[991,3001,2180],{"class":1540},[991,3003,3004],{"class":993,"line":2227},[991,3005,2055],{"class":1540},[892,3007,3008],{"id":3008},"验证安装",[982,3010,3012],{"className":984,"code":3011,"language":986,"meta":11,"style":11},"# 检查 Nginx 版本\nnginx -v\n\n# 检查配置语法\nsudo nginx -t\n\n# 查看 Nginx 进程\nps aux | grep nginx\n\n# 访问默认页面\ncurl http:\u002F\u002Flocalhost\n",[988,3013,3014,3019,3025,3029,3034,3042,3046,3050,3062,3066,3071],{"__ignoreMap":11},[991,3015,3016],{"class":993,"line":994},[991,3017,3018],{"class":997},"# 检查 Nginx 版本\n",[991,3020,3021,3023],{"class":993,"line":1001},[991,3022,1766],{"class":1004},[991,3024,1769],{"class":1041},[991,3026,3027],{"class":993,"line":1015},[991,3028,1019],{"emptyLinePlaceholder":1018},[991,3030,3031],{"class":993,"line":1022},[991,3032,3033],{"class":997},"# 检查配置语法\n",[991,3035,3036,3038,3040],{"class":993,"line":1028},[991,3037,1005],{"class":1004},[991,3039,1038],{"class":1008},[991,3041,1734],{"class":1041},[991,3043,3044],{"class":993,"line":1045},[991,3045,1019],{"emptyLinePlaceholder":1018},[991,3047,3048],{"class":993,"line":1050},[991,3049,1819],{"class":997},[991,3051,3052,3054,3056,3058,3060],{"class":993,"line":1056},[991,3053,1824],{"class":1004},[991,3055,1827],{"class":1008},[991,3057,1831],{"class":1830},[991,3059,1834],{"class":1004},[991,3061,1067],{"class":1008},[991,3063,3064],{"class":993,"line":1070},[991,3065,1019],{"emptyLinePlaceholder":1018},[991,3067,3068],{"class":993,"line":1075},[991,3069,3070],{"class":997},"# 访问默认页面\n",[991,3072,3073,3076],{"class":993,"line":1081},[991,3074,3075],{"class":1004},"curl",[991,3077,3078],{"class":1008}," http:\u002F\u002Flocalhost\n",[896,3080,3081,3082,3085],{},"浏览器访问 ",[988,3083,3084],{},"http:\u002F\u002Fyour-server-ip","，如果看到 Nginx 欢迎页面，说明安装成功。",[892,3087,3088],{"id":3088},"常见问题",[900,3090,3092],{"id":3091},"_1-端口被占用","1. 端口被占用",[982,3094,3096],{"className":984,"code":3095,"language":986,"meta":11,"style":11},"# 查看 80 端口占用\nsudo lsof -i:80\nsudo netstat -tlnp | grep :80\n\n# 杀掉占用进程\nsudo kill -9 \u003CPID>\n",[988,3097,3098,3103,3113,3130,3134,3139],{"__ignoreMap":11},[991,3099,3100],{"class":993,"line":994},[991,3101,3102],{"class":997},"# 查看 80 端口占用\n",[991,3104,3105,3107,3110],{"class":993,"line":1001},[991,3106,1005],{"class":1004},[991,3108,3109],{"class":1008}," lsof",[991,3111,3112],{"class":1041}," -i:80\n",[991,3114,3115,3117,3120,3123,3125,3127],{"class":993,"line":1015},[991,3116,1005],{"class":1004},[991,3118,3119],{"class":1008}," netstat",[991,3121,3122],{"class":1041}," -tlnp",[991,3124,1831],{"class":1830},[991,3126,1834],{"class":1004},[991,3128,3129],{"class":1008}," :80\n",[991,3131,3132],{"class":993,"line":1022},[991,3133,1019],{"emptyLinePlaceholder":1018},[991,3135,3136],{"class":993,"line":1028},[991,3137,3138],{"class":997},"# 杀掉占用进程\n",[991,3140,3141,3143,3146,3149,3152,3155,3158],{"class":993,"line":1045},[991,3142,1005],{"class":1004},[991,3144,3145],{"class":1008}," kill",[991,3147,3148],{"class":1041}," -9",[991,3150,3151],{"class":1830}," \u003C",[991,3153,3154],{"class":1008},"PI",[991,3156,3157],{"class":1540},"D",[991,3159,3160],{"class":1830},">\n",[900,3162,3164],{"id":3163},"_2-权限问题","2. 权限问题",[982,3166,3168],{"className":984,"code":3167,"language":986,"meta":11,"style":11},"# 检查目录权限\nls -la \u002Fusr\u002Fshare\u002Fnginx\u002Fhtml\n\n# 修改权限\nsudo chown -R nginx:nginx \u002Fusr\u002Fshare\u002Fnginx\u002Fhtml\nsudo chmod -R 755 \u002Fusr\u002Fshare\u002Fnginx\u002Fhtml\n",[988,3169,3170,3175,3186,3190,3195,3210],{"__ignoreMap":11},[991,3171,3172],{"class":993,"line":994},[991,3173,3174],{"class":997},"# 检查目录权限\n",[991,3176,3177,3180,3183],{"class":993,"line":1001},[991,3178,3179],{"class":1004},"ls",[991,3181,3182],{"class":1041}," -la",[991,3184,3185],{"class":1008}," \u002Fusr\u002Fshare\u002Fnginx\u002Fhtml\n",[991,3187,3188],{"class":993,"line":1015},[991,3189,1019],{"emptyLinePlaceholder":1018},[991,3191,3192],{"class":993,"line":1022},[991,3193,3194],{"class":997},"# 修改权限\n",[991,3196,3197,3199,3202,3205,3208],{"class":993,"line":1028},[991,3198,1005],{"class":1004},[991,3200,3201],{"class":1008}," chown",[991,3203,3204],{"class":1041}," -R",[991,3206,3207],{"class":1008}," nginx:nginx",[991,3209,3185],{"class":1008},[991,3211,3212,3214,3217,3219,3222],{"class":993,"line":1045},[991,3213,1005],{"class":1004},[991,3215,3216],{"class":1008}," chmod",[991,3218,3204],{"class":1041},[991,3220,3221],{"class":1041}," 755",[991,3223,3185],{"class":1008},[900,3225,3227],{"id":3226},"_3-配置语法错误","3. 配置语法错误",[982,3229,3231],{"className":984,"code":3230,"language":986,"meta":11,"style":11},"# 测试配置\nsudo nginx -t\n\n# 查看错误日志\nsudo tail -f \u002Fvar\u002Flog\u002Fnginx\u002Ferror.log\n",[988,3232,3233,3238,3246,3250,3255],{"__ignoreMap":11},[991,3234,3235],{"class":993,"line":994},[991,3236,3237],{"class":997},"# 测试配置\n",[991,3239,3240,3242,3244],{"class":993,"line":1001},[991,3241,1005],{"class":1004},[991,3243,1038],{"class":1008},[991,3245,1734],{"class":1041},[991,3247,3248],{"class":993,"line":1015},[991,3249,1019],{"emptyLinePlaceholder":1018},[991,3251,3252],{"class":993,"line":1022},[991,3253,3254],{"class":997},"# 查看错误日志\n",[991,3256,3257,3259,3262,3265],{"class":993,"line":1028},[991,3258,1005],{"class":1004},[991,3260,3261],{"class":1008}," tail",[991,3263,3264],{"class":1041}," -f",[991,3266,3267],{"class":1008}," \u002Fvar\u002Flog\u002Fnginx\u002Ferror.log\n",[900,3269,3271],{"id":3270},"_4-selinux-问题centos","4. SELinux 问题（CentOS）",[982,3273,3275],{"className":984,"code":3274,"language":986,"meta":11,"style":11},"# 临时关闭 SELinux\nsudo setenforce 0\n\n# 或者允许 Nginx 网络连接\nsudo setsebool -P httpd_can_network_connect 1\n",[988,3276,3277,3282,3292,3296,3301],{"__ignoreMap":11},[991,3278,3279],{"class":993,"line":994},[991,3280,3281],{"class":997},"# 临时关闭 SELinux\n",[991,3283,3284,3286,3289],{"class":993,"line":1001},[991,3285,1005],{"class":1004},[991,3287,3288],{"class":1008}," setenforce",[991,3290,3291],{"class":1041}," 0\n",[991,3293,3294],{"class":993,"line":1015},[991,3295,1019],{"emptyLinePlaceholder":1018},[991,3297,3298],{"class":993,"line":1022},[991,3299,3300],{"class":997},"# 或者允许 Nginx 网络连接\n",[991,3302,3303,3305,3308,3311,3314],{"class":993,"line":1028},[991,3304,1005],{"class":1004},[991,3306,3307],{"class":1008}," setsebool",[991,3309,3310],{"class":1041}," -P",[991,3312,3313],{"class":1008}," httpd_can_network_connect",[991,3315,3316],{"class":1041}," 1\n",[900,3318,3320],{"id":3319},"_5-防火墙问题","5. 防火墙问题",[982,3322,3324],{"className":984,"code":3323,"language":986,"meta":11,"style":11},"# Ubuntu (UFW)\nsudo ufw allow 'Nginx Full'\nsudo ufw status\n\n# CentOS (firewalld)\nsudo firewall-cmd --permanent --add-service=http\nsudo firewall-cmd --permanent --add-service=https\nsudo firewall-cmd --reload\n",[988,3325,3326,3331,3344,3353,3357,3362,3375,3386],{"__ignoreMap":11},[991,3327,3328],{"class":993,"line":994},[991,3329,3330],{"class":997},"# Ubuntu (UFW)\n",[991,3332,3333,3335,3338,3341],{"class":993,"line":1001},[991,3334,1005],{"class":1004},[991,3336,3337],{"class":1008}," ufw",[991,3339,3340],{"class":1008}," allow",[991,3342,3343],{"class":1008}," 'Nginx Full'\n",[991,3345,3346,3348,3350],{"class":993,"line":1015},[991,3347,1005],{"class":1004},[991,3349,3337],{"class":1008},[991,3351,3352],{"class":1008}," status\n",[991,3354,3355],{"class":993,"line":1022},[991,3356,1019],{"emptyLinePlaceholder":1018},[991,3358,3359],{"class":993,"line":1028},[991,3360,3361],{"class":997},"# CentOS (firewalld)\n",[991,3363,3364,3366,3369,3372],{"class":993,"line":1045},[991,3365,1005],{"class":1004},[991,3367,3368],{"class":1008}," firewall-cmd",[991,3370,3371],{"class":1041}," --permanent",[991,3373,3374],{"class":1041}," --add-service=http\n",[991,3376,3377,3379,3381,3383],{"class":993,"line":1050},[991,3378,1005],{"class":1004},[991,3380,3368],{"class":1008},[991,3382,3371],{"class":1041},[991,3384,3385],{"class":1041}," --add-service=https\n",[991,3387,3388,3390,3392],{"class":993,"line":1056},[991,3389,1005],{"class":1004},[991,3391,3368],{"class":1008},[991,3393,3394],{"class":1041}," --reload\n",[892,3396,3397],{"id":3397},"总结",[905,3399,3400,3410],{},[908,3401,3402],{},[911,3403,3404,3407],{},[914,3405,3406],{"align":916},"操作",[914,3408,3409],{"align":916},"命令",[922,3411,3412,3422,3432,3442,3452,3462,3472,3482],{},[911,3413,3414,3417],{},[927,3415,3416],{"align":916},"安装",[927,3418,3419],{"align":916},[988,3420,3421],{},"apt install nginx",[911,3423,3424,3427],{},[927,3425,3426],{"align":916},"启动",[927,3428,3429],{"align":916},[988,3430,3431],{},"systemctl start nginx",[911,3433,3434,3437],{},[927,3435,3436],{"align":916},"停止",[927,3438,3439],{"align":916},[988,3440,3441],{},"systemctl stop nginx",[911,3443,3444,3447],{},[927,3445,3446],{"align":916},"重启",[927,3448,3449],{"align":916},[988,3450,3451],{},"systemctl restart nginx",[911,3453,3454,3457],{},[927,3455,3456],{"align":916},"重载配置",[927,3458,3459],{"align":916},[988,3460,3461],{},"systemctl reload nginx",[911,3463,3464,3467],{},[927,3465,3466],{"align":916},"测试配置",[927,3468,3469],{"align":916},[988,3470,3471],{},"nginx -t",[911,3473,3474,3477],{},[927,3475,3476],{"align":916},"查看版本",[927,3478,3479],{"align":916},[988,3480,3481],{},"nginx -v",[911,3483,3484,3487],{},[927,3485,3486],{"align":916},"查看进程",[927,3488,3489],{"align":916},[988,3490,3491],{},"ps aux | grep nginx",[3493,3494,3496],"note",{"title":3495},"下一步","\n安装完成后，接下来学习如何配置 Nginx 来托管静态资源。\n",[3498,3499,3500],"style",{},"html pre.shiki code .sCsY4, html code.shiki .sCsY4{--shiki-light:#6A737D;--shiki-default:#6A737D;--shiki-dark:#6A737D}html pre.shiki code .snPdu, html code.shiki .snPdu{--shiki-light:#6F42C1;--shiki-default:#6F42C1;--shiki-dark:#B392F0}html pre.shiki code .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 .sxrX7, html code.shiki .sxrX7{--shiki-light:#24292E;--shiki-default:#24292E;--shiki-dark:#E1E4E8}html pre.shiki code .s8jYJ, html code.shiki .s8jYJ{--shiki-light:#D73A49;--shiki-default:#D73A49;--shiki-dark:#F97583}html pre.shiki code .s3JiQ, html code.shiki .s3JiQ{--shiki-light:#032F62;--shiki-default:#032F62;--shiki-dark:#DBEDFF}",{"title":11,"searchDepth":1001,"depth":1001,"links":3502},[3503,3506,3513,3514,3519,3524,3525,3532],{"id":894,"depth":1001,"text":894,"children":3504},[3505],{"id":902,"depth":1015,"text":903},{"id":975,"depth":1001,"text":976,"children":3507},[3508,3509,3510,3511,3512],{"id":979,"depth":1015,"text":980},{"id":1116,"depth":1015,"text":1117},{"id":1200,"depth":1015,"text":1201},{"id":1256,"depth":1015,"text":1257},{"id":1345,"depth":1015,"text":1345},{"id":1552,"depth":1001,"text":1552},{"id":1566,"depth":1001,"text":1566,"children":3515},[3516,3517,3518],{"id":1569,"depth":1015,"text":1569},{"id":1715,"depth":1015,"text":1715},{"id":1809,"depth":1015,"text":1809},{"id":1924,"depth":1001,"text":1924,"children":3520},[3521,3522,3523],{"id":1927,"depth":1015,"text":1927},{"id":2487,"depth":1015,"text":2487},{"id":2567,"depth":1015,"text":2567},{"id":3008,"depth":1001,"text":3008},{"id":3088,"depth":1001,"text":3088,"children":3526},[3527,3528,3529,3530,3531],{"id":3091,"depth":1015,"text":3092},{"id":3163,"depth":1015,"text":3164},{"id":3226,"depth":1015,"text":3227},{"id":3270,"depth":1015,"text":3271},{"id":3319,"depth":1015,"text":3320},{"id":3397,"depth":1001,"text":3397},"md",{},{"title":696,"description":11},"tutorials\u002Fcloud\u002Fnginx\u002Fnginx-install","CkBatZafeyVmPChdyDAsIIlOZX6SVqueALI-60P1MVA",1775496411557]