[{"data":1,"prerenderedAt":3704},["ShallowReactive",2],{"search-docs":3,"doc-\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-user-permission":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":690,"body":888,"description":11,"extension":3699,"meta":3700,"navigation":996,"path":689,"seo":3701,"stem":3702,"__hash__":3703},"docs\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-user-permission.md",{"type":889,"value":890,"toc":3656},"minimark",[891,895,899,902,959,962,966,1105,1109,1356,1360,1537,1541,1600,1604,1733,1736,1739,1805,1809,1851,1855,1901,1905,1919,1923,1991,1994,1997,2071,2074,2219,2223,2229,2366,2371,2424,2429,2451,2456,2500,2504,2609,2613,2655,2658,2662,2665,2732,2736,2746,2840,2844,2847,2913,2916,2919,2922,3020,3024,3028,3163,3167,3263,3266,3270,3341,3344,3387,3391,3394,3534,3537,3647,3652],[892,893,894],"h2",{"id":894},"概述",[896,897,898],"p",{},"Linux 是多用户操作系统，通过用户和权限机制来保护系统安全。理解用户、组和权限的概念是系统管理的基础。",[892,900,901],{"id":901},"用户类型",[903,904,905,922],"table",{},[906,907,908],"thead",{},[909,910,911,916,919],"tr",{},[912,913,915],"th",{"align":914},"left","类型",[912,917,918],{"align":914},"UID 范围",[912,920,921],{"align":914},"说明",[923,924,925,937,948],"tbody",{},[909,926,927,931,934],{},[928,929,930],"td",{"align":914},"root",[928,932,933],{"align":914},"0",[928,935,936],{"align":914},"超级管理员，拥有最高权限",[909,938,939,942,945],{},[928,940,941],{"align":914},"系统用户",[928,943,944],{"align":914},"1-999",[928,946,947],{"align":914},"系统服务使用的用户",[909,949,950,953,956],{},[928,951,952],{"align":914},"普通用户",[928,954,955],{"align":914},"1000+",[928,957,958],{"align":914},"一般登录用户",[892,960,961],{"id":961},"用户管理",[963,964,965],"h3",{"id":965},"查看用户信息",[967,968,972],"pre",{"className":969,"code":970,"language":971,"meta":11,"style":11},"language-bash shiki shiki-themes github-light github-light github-dark","# 查看当前用户\nwhoami\n\n# 查看用户 ID\nid\nid username\n\n# 查看登录用户\nwho\nw\n\n# 查看用户信息\nfinger username\n\n# 查看 \u002Fetc\u002Fpasswd\ncat \u002Fetc\u002Fpasswd\n\n# 用户信息格式：\n# username:password:UID:GID:comment:home:shell\n# root:x:0:0:root:\u002Froot:\u002Fbin\u002Fbash\n","bash",[973,974,975,984,991,998,1004,1010,1020,1025,1031,1037,1043,1048,1054,1062,1067,1073,1082,1087,1093,1099],"code",{"__ignoreMap":11},[976,977,980],"span",{"class":978,"line":979},"line",1,[976,981,983],{"class":982},"sCsY4","# 查看当前用户\n",[976,985,987],{"class":978,"line":986},2,[976,988,990],{"class":989},"snPdu","whoami\n",[976,992,994],{"class":978,"line":993},3,[976,995,997],{"emptyLinePlaceholder":996},true,"\n",[976,999,1001],{"class":978,"line":1000},4,[976,1002,1003],{"class":982},"# 查看用户 ID\n",[976,1005,1007],{"class":978,"line":1006},5,[976,1008,1009],{"class":989},"id\n",[976,1011,1013,1016],{"class":978,"line":1012},6,[976,1014,1015],{"class":989},"id",[976,1017,1019],{"class":1018},"sIIMD"," username\n",[976,1021,1023],{"class":978,"line":1022},7,[976,1024,997],{"emptyLinePlaceholder":996},[976,1026,1028],{"class":978,"line":1027},8,[976,1029,1030],{"class":982},"# 查看登录用户\n",[976,1032,1034],{"class":978,"line":1033},9,[976,1035,1036],{"class":989},"who\n",[976,1038,1040],{"class":978,"line":1039},10,[976,1041,1042],{"class":989},"w\n",[976,1044,1046],{"class":978,"line":1045},11,[976,1047,997],{"emptyLinePlaceholder":996},[976,1049,1051],{"class":978,"line":1050},12,[976,1052,1053],{"class":982},"# 查看用户信息\n",[976,1055,1057,1060],{"class":978,"line":1056},13,[976,1058,1059],{"class":989},"finger",[976,1061,1019],{"class":1018},[976,1063,1065],{"class":978,"line":1064},14,[976,1066,997],{"emptyLinePlaceholder":996},[976,1068,1070],{"class":978,"line":1069},15,[976,1071,1072],{"class":982},"# 查看 \u002Fetc\u002Fpasswd\n",[976,1074,1076,1079],{"class":978,"line":1075},16,[976,1077,1078],{"class":989},"cat",[976,1080,1081],{"class":1018}," \u002Fetc\u002Fpasswd\n",[976,1083,1085],{"class":978,"line":1084},17,[976,1086,997],{"emptyLinePlaceholder":996},[976,1088,1090],{"class":978,"line":1089},18,[976,1091,1092],{"class":982},"# 用户信息格式：\n",[976,1094,1096],{"class":978,"line":1095},19,[976,1097,1098],{"class":982},"# username:password:UID:GID:comment:home:shell\n",[976,1100,1102],{"class":978,"line":1101},20,[976,1103,1104],{"class":982},"# root:x:0:0:root:\u002Froot:\u002Fbin\u002Fbash\n",[963,1106,1108],{"id":1107},"useradd-创建用户","useradd - 创建用户",[967,1110,1112],{"className":969,"code":1111,"language":971,"meta":11,"style":11},"# 创建用户（使用默认设置）\nsudo useradd username\n\n# 创建用户并指定主目录\nsudo useradd -m username\n\n# 指定主目录路径\nsudo useradd -m -d \u002Fhome\u002Fcustom username\n\n# 指定 shell\nsudo useradd -s \u002Fbin\u002Fbash username\n\n# 指定用户 ID\nsudo useradd -u 1500 username\n\n# 指定主组\nsudo useradd -g groupname username\n\n# 指定附加组\nsudo useradd -G group1,group2 username\n\n# 设置账户过期时间\nsudo useradd -e 2024-12-31 username\n\n# 添加注释\nsudo useradd -c \"John Doe\" username\n\n# 完整示例\nsudo useradd -m -s \u002Fbin\u002Fbash -c \"New User\" -G sudo,docker newuser\n",[973,1113,1114,1119,1129,1133,1138,1150,1154,1159,1175,1179,1184,1198,1202,1207,1221,1225,1230,1244,1248,1253,1267,1272,1278,1293,1298,1304,1319,1324,1330],{"__ignoreMap":11},[976,1115,1116],{"class":978,"line":979},[976,1117,1118],{"class":982},"# 创建用户（使用默认设置）\n",[976,1120,1121,1124,1127],{"class":978,"line":986},[976,1122,1123],{"class":989},"sudo",[976,1125,1126],{"class":1018}," useradd",[976,1128,1019],{"class":1018},[976,1130,1131],{"class":978,"line":993},[976,1132,997],{"emptyLinePlaceholder":996},[976,1134,1135],{"class":978,"line":1000},[976,1136,1137],{"class":982},"# 创建用户并指定主目录\n",[976,1139,1140,1142,1144,1148],{"class":978,"line":1006},[976,1141,1123],{"class":989},[976,1143,1126],{"class":1018},[976,1145,1147],{"class":1146},"sBjJW"," -m",[976,1149,1019],{"class":1018},[976,1151,1152],{"class":978,"line":1012},[976,1153,997],{"emptyLinePlaceholder":996},[976,1155,1156],{"class":978,"line":1022},[976,1157,1158],{"class":982},"# 指定主目录路径\n",[976,1160,1161,1163,1165,1167,1170,1173],{"class":978,"line":1027},[976,1162,1123],{"class":989},[976,1164,1126],{"class":1018},[976,1166,1147],{"class":1146},[976,1168,1169],{"class":1146}," -d",[976,1171,1172],{"class":1018}," \u002Fhome\u002Fcustom",[976,1174,1019],{"class":1018},[976,1176,1177],{"class":978,"line":1033},[976,1178,997],{"emptyLinePlaceholder":996},[976,1180,1181],{"class":978,"line":1039},[976,1182,1183],{"class":982},"# 指定 shell\n",[976,1185,1186,1188,1190,1193,1196],{"class":978,"line":1045},[976,1187,1123],{"class":989},[976,1189,1126],{"class":1018},[976,1191,1192],{"class":1146}," -s",[976,1194,1195],{"class":1018}," \u002Fbin\u002Fbash",[976,1197,1019],{"class":1018},[976,1199,1200],{"class":978,"line":1050},[976,1201,997],{"emptyLinePlaceholder":996},[976,1203,1204],{"class":978,"line":1056},[976,1205,1206],{"class":982},"# 指定用户 ID\n",[976,1208,1209,1211,1213,1216,1219],{"class":978,"line":1064},[976,1210,1123],{"class":989},[976,1212,1126],{"class":1018},[976,1214,1215],{"class":1146}," -u",[976,1217,1218],{"class":1146}," 1500",[976,1220,1019],{"class":1018},[976,1222,1223],{"class":978,"line":1069},[976,1224,997],{"emptyLinePlaceholder":996},[976,1226,1227],{"class":978,"line":1075},[976,1228,1229],{"class":982},"# 指定主组\n",[976,1231,1232,1234,1236,1239,1242],{"class":978,"line":1084},[976,1233,1123],{"class":989},[976,1235,1126],{"class":1018},[976,1237,1238],{"class":1146}," -g",[976,1240,1241],{"class":1018}," groupname",[976,1243,1019],{"class":1018},[976,1245,1246],{"class":978,"line":1089},[976,1247,997],{"emptyLinePlaceholder":996},[976,1249,1250],{"class":978,"line":1095},[976,1251,1252],{"class":982},"# 指定附加组\n",[976,1254,1255,1257,1259,1262,1265],{"class":978,"line":1101},[976,1256,1123],{"class":989},[976,1258,1126],{"class":1018},[976,1260,1261],{"class":1146}," -G",[976,1263,1264],{"class":1018}," group1,group2",[976,1266,1019],{"class":1018},[976,1268,1270],{"class":978,"line":1269},21,[976,1271,997],{"emptyLinePlaceholder":996},[976,1273,1275],{"class":978,"line":1274},22,[976,1276,1277],{"class":982},"# 设置账户过期时间\n",[976,1279,1281,1283,1285,1288,1291],{"class":978,"line":1280},23,[976,1282,1123],{"class":989},[976,1284,1126],{"class":1018},[976,1286,1287],{"class":1146}," -e",[976,1289,1290],{"class":1018}," 2024-12-31",[976,1292,1019],{"class":1018},[976,1294,1296],{"class":978,"line":1295},24,[976,1297,997],{"emptyLinePlaceholder":996},[976,1299,1301],{"class":978,"line":1300},25,[976,1302,1303],{"class":982},"# 添加注释\n",[976,1305,1307,1309,1311,1314,1317],{"class":978,"line":1306},26,[976,1308,1123],{"class":989},[976,1310,1126],{"class":1018},[976,1312,1313],{"class":1146}," -c",[976,1315,1316],{"class":1018}," \"John Doe\"",[976,1318,1019],{"class":1018},[976,1320,1322],{"class":978,"line":1321},27,[976,1323,997],{"emptyLinePlaceholder":996},[976,1325,1327],{"class":978,"line":1326},28,[976,1328,1329],{"class":982},"# 完整示例\n",[976,1331,1333,1335,1337,1339,1341,1343,1345,1348,1350,1353],{"class":978,"line":1332},29,[976,1334,1123],{"class":989},[976,1336,1126],{"class":1018},[976,1338,1147],{"class":1146},[976,1340,1192],{"class":1146},[976,1342,1195],{"class":1018},[976,1344,1313],{"class":1146},[976,1346,1347],{"class":1018}," \"New User\"",[976,1349,1261],{"class":1146},[976,1351,1352],{"class":1018}," sudo,docker",[976,1354,1355],{"class":1018}," newuser\n",[963,1357,1359],{"id":1358},"usermod-修改用户","usermod - 修改用户",[967,1361,1363],{"className":969,"code":1362,"language":971,"meta":11,"style":11},"# 修改用户名\nsudo usermod -l newname oldname\n\n# 修改主目录\nsudo usermod -d \u002Fnew\u002Fhome -m username\n\n# 修改 shell\nsudo usermod -s \u002Fbin\u002Fzsh username\n\n# 修改主组\nsudo usermod -g newgroup username\n\n# 添加到附加组\nsudo usermod -aG groupname username\n\n# 锁定用户\nsudo usermod -L username\n\n# 解锁用户\nsudo usermod -U username\n\n# 设置过期时间\nsudo usermod -e 2024-12-31 username\n",[973,1364,1365,1370,1386,1390,1395,1410,1414,1419,1432,1436,1441,1454,1458,1463,1476,1480,1485,1496,1500,1505,1516,1520,1525],{"__ignoreMap":11},[976,1366,1367],{"class":978,"line":979},[976,1368,1369],{"class":982},"# 修改用户名\n",[976,1371,1372,1374,1377,1380,1383],{"class":978,"line":986},[976,1373,1123],{"class":989},[976,1375,1376],{"class":1018}," usermod",[976,1378,1379],{"class":1146}," -l",[976,1381,1382],{"class":1018}," newname",[976,1384,1385],{"class":1018}," oldname\n",[976,1387,1388],{"class":978,"line":993},[976,1389,997],{"emptyLinePlaceholder":996},[976,1391,1392],{"class":978,"line":1000},[976,1393,1394],{"class":982},"# 修改主目录\n",[976,1396,1397,1399,1401,1403,1406,1408],{"class":978,"line":1006},[976,1398,1123],{"class":989},[976,1400,1376],{"class":1018},[976,1402,1169],{"class":1146},[976,1404,1405],{"class":1018}," \u002Fnew\u002Fhome",[976,1407,1147],{"class":1146},[976,1409,1019],{"class":1018},[976,1411,1412],{"class":978,"line":1012},[976,1413,997],{"emptyLinePlaceholder":996},[976,1415,1416],{"class":978,"line":1022},[976,1417,1418],{"class":982},"# 修改 shell\n",[976,1420,1421,1423,1425,1427,1430],{"class":978,"line":1027},[976,1422,1123],{"class":989},[976,1424,1376],{"class":1018},[976,1426,1192],{"class":1146},[976,1428,1429],{"class":1018}," \u002Fbin\u002Fzsh",[976,1431,1019],{"class":1018},[976,1433,1434],{"class":978,"line":1033},[976,1435,997],{"emptyLinePlaceholder":996},[976,1437,1438],{"class":978,"line":1039},[976,1439,1440],{"class":982},"# 修改主组\n",[976,1442,1443,1445,1447,1449,1452],{"class":978,"line":1045},[976,1444,1123],{"class":989},[976,1446,1376],{"class":1018},[976,1448,1238],{"class":1146},[976,1450,1451],{"class":1018}," newgroup",[976,1453,1019],{"class":1018},[976,1455,1456],{"class":978,"line":1050},[976,1457,997],{"emptyLinePlaceholder":996},[976,1459,1460],{"class":978,"line":1056},[976,1461,1462],{"class":982},"# 添加到附加组\n",[976,1464,1465,1467,1469,1472,1474],{"class":978,"line":1064},[976,1466,1123],{"class":989},[976,1468,1376],{"class":1018},[976,1470,1471],{"class":1146}," -aG",[976,1473,1241],{"class":1018},[976,1475,1019],{"class":1018},[976,1477,1478],{"class":978,"line":1069},[976,1479,997],{"emptyLinePlaceholder":996},[976,1481,1482],{"class":978,"line":1075},[976,1483,1484],{"class":982},"# 锁定用户\n",[976,1486,1487,1489,1491,1494],{"class":978,"line":1084},[976,1488,1123],{"class":989},[976,1490,1376],{"class":1018},[976,1492,1493],{"class":1146}," -L",[976,1495,1019],{"class":1018},[976,1497,1498],{"class":978,"line":1089},[976,1499,997],{"emptyLinePlaceholder":996},[976,1501,1502],{"class":978,"line":1095},[976,1503,1504],{"class":982},"# 解锁用户\n",[976,1506,1507,1509,1511,1514],{"class":978,"line":1101},[976,1508,1123],{"class":989},[976,1510,1376],{"class":1018},[976,1512,1513],{"class":1146}," -U",[976,1515,1019],{"class":1018},[976,1517,1518],{"class":978,"line":1269},[976,1519,997],{"emptyLinePlaceholder":996},[976,1521,1522],{"class":978,"line":1274},[976,1523,1524],{"class":982},"# 设置过期时间\n",[976,1526,1527,1529,1531,1533,1535],{"class":978,"line":1280},[976,1528,1123],{"class":989},[976,1530,1376],{"class":1018},[976,1532,1287],{"class":1146},[976,1534,1290],{"class":1018},[976,1536,1019],{"class":1018},[963,1538,1540],{"id":1539},"userdel-删除用户","userdel - 删除用户",[967,1542,1544],{"className":969,"code":1543,"language":971,"meta":11,"style":11},"# 删除用户（保留主目录）\nsudo userdel username\n\n# 删除用户及主目录\nsudo userdel -r username\n\n# 强制删除（即使用户登录中）\nsudo userdel -f username\n",[973,1545,1546,1551,1560,1564,1569,1580,1584,1589],{"__ignoreMap":11},[976,1547,1548],{"class":978,"line":979},[976,1549,1550],{"class":982},"# 删除用户（保留主目录）\n",[976,1552,1553,1555,1558],{"class":978,"line":986},[976,1554,1123],{"class":989},[976,1556,1557],{"class":1018}," userdel",[976,1559,1019],{"class":1018},[976,1561,1562],{"class":978,"line":993},[976,1563,997],{"emptyLinePlaceholder":996},[976,1565,1566],{"class":978,"line":1000},[976,1567,1568],{"class":982},"# 删除用户及主目录\n",[976,1570,1571,1573,1575,1578],{"class":978,"line":1006},[976,1572,1123],{"class":989},[976,1574,1557],{"class":1018},[976,1576,1577],{"class":1146}," -r",[976,1579,1019],{"class":1018},[976,1581,1582],{"class":978,"line":1012},[976,1583,997],{"emptyLinePlaceholder":996},[976,1585,1586],{"class":978,"line":1022},[976,1587,1588],{"class":982},"# 强制删除（即使用户登录中）\n",[976,1590,1591,1593,1595,1598],{"class":978,"line":1027},[976,1592,1123],{"class":989},[976,1594,1557],{"class":1018},[976,1596,1597],{"class":1146}," -f",[976,1599,1019],{"class":1018},[963,1601,1603],{"id":1602},"passwd-管理密码","passwd - 管理密码",[967,1605,1607],{"className":969,"code":1606,"language":971,"meta":11,"style":11},"# 修改当前用户密码\npasswd\n\n# 修改指定用户密码\nsudo passwd username\n\n# 锁定用户密码\nsudo passwd -l username\n\n# 解锁用户密码\nsudo passwd -u username\n\n# 删除密码（无密码登录）\nsudo passwd -d username\n\n# 设置密码过期\nsudo passwd -e username\n\n# 查看密码状态\nsudo passwd -S username\n",[973,1608,1609,1614,1619,1623,1628,1637,1641,1646,1656,1660,1665,1675,1679,1684,1694,1698,1703,1713,1717,1722],{"__ignoreMap":11},[976,1610,1611],{"class":978,"line":979},[976,1612,1613],{"class":982},"# 修改当前用户密码\n",[976,1615,1616],{"class":978,"line":986},[976,1617,1618],{"class":989},"passwd\n",[976,1620,1621],{"class":978,"line":993},[976,1622,997],{"emptyLinePlaceholder":996},[976,1624,1625],{"class":978,"line":1000},[976,1626,1627],{"class":982},"# 修改指定用户密码\n",[976,1629,1630,1632,1635],{"class":978,"line":1006},[976,1631,1123],{"class":989},[976,1633,1634],{"class":1018}," passwd",[976,1636,1019],{"class":1018},[976,1638,1639],{"class":978,"line":1012},[976,1640,997],{"emptyLinePlaceholder":996},[976,1642,1643],{"class":978,"line":1022},[976,1644,1645],{"class":982},"# 锁定用户密码\n",[976,1647,1648,1650,1652,1654],{"class":978,"line":1027},[976,1649,1123],{"class":989},[976,1651,1634],{"class":1018},[976,1653,1379],{"class":1146},[976,1655,1019],{"class":1018},[976,1657,1658],{"class":978,"line":1033},[976,1659,997],{"emptyLinePlaceholder":996},[976,1661,1662],{"class":978,"line":1039},[976,1663,1664],{"class":982},"# 解锁用户密码\n",[976,1666,1667,1669,1671,1673],{"class":978,"line":1045},[976,1668,1123],{"class":989},[976,1670,1634],{"class":1018},[976,1672,1215],{"class":1146},[976,1674,1019],{"class":1018},[976,1676,1677],{"class":978,"line":1050},[976,1678,997],{"emptyLinePlaceholder":996},[976,1680,1681],{"class":978,"line":1056},[976,1682,1683],{"class":982},"# 删除密码（无密码登录）\n",[976,1685,1686,1688,1690,1692],{"class":978,"line":1064},[976,1687,1123],{"class":989},[976,1689,1634],{"class":1018},[976,1691,1169],{"class":1146},[976,1693,1019],{"class":1018},[976,1695,1696],{"class":978,"line":1069},[976,1697,997],{"emptyLinePlaceholder":996},[976,1699,1700],{"class":978,"line":1075},[976,1701,1702],{"class":982},"# 设置密码过期\n",[976,1704,1705,1707,1709,1711],{"class":978,"line":1084},[976,1706,1123],{"class":989},[976,1708,1634],{"class":1018},[976,1710,1287],{"class":1146},[976,1712,1019],{"class":1018},[976,1714,1715],{"class":978,"line":1089},[976,1716,997],{"emptyLinePlaceholder":996},[976,1718,1719],{"class":978,"line":1095},[976,1720,1721],{"class":982},"# 查看密码状态\n",[976,1723,1724,1726,1728,1731],{"class":978,"line":1101},[976,1725,1123],{"class":989},[976,1727,1634],{"class":1018},[976,1729,1730],{"class":1146}," -S",[976,1732,1019],{"class":1018},[892,1734,1735],{"id":1735},"组管理",[963,1737,1738],{"id":1738},"查看组信息",[967,1740,1742],{"className":969,"code":1741,"language":971,"meta":11,"style":11},"# 查看当前用户的组\ngroups\n\n# 查看指定用户的组\ngroups username\n\n# 查看组文件\ncat \u002Fetc\u002Fgroup\n\n# 组信息格式：\n# groupname:password:GID:members\n# sudo:x:27:user1,user2\n",[973,1743,1744,1749,1754,1758,1763,1770,1774,1779,1786,1790,1795,1800],{"__ignoreMap":11},[976,1745,1746],{"class":978,"line":979},[976,1747,1748],{"class":982},"# 查看当前用户的组\n",[976,1750,1751],{"class":978,"line":986},[976,1752,1753],{"class":989},"groups\n",[976,1755,1756],{"class":978,"line":993},[976,1757,997],{"emptyLinePlaceholder":996},[976,1759,1760],{"class":978,"line":1000},[976,1761,1762],{"class":982},"# 查看指定用户的组\n",[976,1764,1765,1768],{"class":978,"line":1006},[976,1766,1767],{"class":989},"groups",[976,1769,1019],{"class":1018},[976,1771,1772],{"class":978,"line":1012},[976,1773,997],{"emptyLinePlaceholder":996},[976,1775,1776],{"class":978,"line":1022},[976,1777,1778],{"class":982},"# 查看组文件\n",[976,1780,1781,1783],{"class":978,"line":1027},[976,1782,1078],{"class":989},[976,1784,1785],{"class":1018}," \u002Fetc\u002Fgroup\n",[976,1787,1788],{"class":978,"line":1033},[976,1789,997],{"emptyLinePlaceholder":996},[976,1791,1792],{"class":978,"line":1039},[976,1793,1794],{"class":982},"# 组信息格式：\n",[976,1796,1797],{"class":978,"line":1045},[976,1798,1799],{"class":982},"# groupname:password:GID:members\n",[976,1801,1802],{"class":978,"line":1050},[976,1803,1804],{"class":982},"# sudo:x:27:user1,user2\n",[963,1806,1808],{"id":1807},"groupadd-创建组","groupadd - 创建组",[967,1810,1812],{"className":969,"code":1811,"language":971,"meta":11,"style":11},"# 创建组\nsudo groupadd groupname\n\n# 指定 GID\nsudo groupadd -g 2000 groupname\n",[973,1813,1814,1819,1829,1833,1838],{"__ignoreMap":11},[976,1815,1816],{"class":978,"line":979},[976,1817,1818],{"class":982},"# 创建组\n",[976,1820,1821,1823,1826],{"class":978,"line":986},[976,1822,1123],{"class":989},[976,1824,1825],{"class":1018}," groupadd",[976,1827,1828],{"class":1018}," groupname\n",[976,1830,1831],{"class":978,"line":993},[976,1832,997],{"emptyLinePlaceholder":996},[976,1834,1835],{"class":978,"line":1000},[976,1836,1837],{"class":982},"# 指定 GID\n",[976,1839,1840,1842,1844,1846,1849],{"class":978,"line":1006},[976,1841,1123],{"class":989},[976,1843,1825],{"class":1018},[976,1845,1238],{"class":1146},[976,1847,1848],{"class":1146}," 2000",[976,1850,1828],{"class":1018},[963,1852,1854],{"id":1853},"groupmod-修改组","groupmod - 修改组",[967,1856,1858],{"className":969,"code":1857,"language":971,"meta":11,"style":11},"# 修改组名\nsudo groupmod -n newname oldname\n\n# 修改 GID\nsudo groupmod -g 3000 groupname\n",[973,1859,1860,1865,1879,1883,1888],{"__ignoreMap":11},[976,1861,1862],{"class":978,"line":979},[976,1863,1864],{"class":982},"# 修改组名\n",[976,1866,1867,1869,1872,1875,1877],{"class":978,"line":986},[976,1868,1123],{"class":989},[976,1870,1871],{"class":1018}," groupmod",[976,1873,1874],{"class":1146}," -n",[976,1876,1382],{"class":1018},[976,1878,1385],{"class":1018},[976,1880,1881],{"class":978,"line":993},[976,1882,997],{"emptyLinePlaceholder":996},[976,1884,1885],{"class":978,"line":1000},[976,1886,1887],{"class":982},"# 修改 GID\n",[976,1889,1890,1892,1894,1896,1899],{"class":978,"line":1006},[976,1891,1123],{"class":989},[976,1893,1871],{"class":1018},[976,1895,1238],{"class":1146},[976,1897,1898],{"class":1146}," 3000",[976,1900,1828],{"class":1018},[963,1902,1904],{"id":1903},"groupdel-删除组","groupdel - 删除组",[967,1906,1908],{"className":969,"code":1907,"language":971,"meta":11,"style":11},"sudo groupdel groupname\n",[973,1909,1910],{"__ignoreMap":11},[976,1911,1912,1914,1917],{"class":978,"line":979},[976,1913,1123],{"class":989},[976,1915,1916],{"class":1018}," groupdel",[976,1918,1828],{"class":1018},[963,1920,1922],{"id":1921},"gpasswd-组成员管理","gpasswd - 组成员管理",[967,1924,1926],{"className":969,"code":1925,"language":971,"meta":11,"style":11},"# 添加用户到组\nsudo gpasswd -a username groupname\n\n# 从组中移除用户\nsudo gpasswd -d username groupname\n\n# 设置组管理员\nsudo gpasswd -A username groupname\n",[973,1927,1928,1933,1948,1952,1957,1969,1973,1978],{"__ignoreMap":11},[976,1929,1930],{"class":978,"line":979},[976,1931,1932],{"class":982},"# 添加用户到组\n",[976,1934,1935,1937,1940,1943,1946],{"class":978,"line":986},[976,1936,1123],{"class":989},[976,1938,1939],{"class":1018}," gpasswd",[976,1941,1942],{"class":1146}," -a",[976,1944,1945],{"class":1018}," username",[976,1947,1828],{"class":1018},[976,1949,1950],{"class":978,"line":993},[976,1951,997],{"emptyLinePlaceholder":996},[976,1953,1954],{"class":978,"line":1000},[976,1955,1956],{"class":982},"# 从组中移除用户\n",[976,1958,1959,1961,1963,1965,1967],{"class":978,"line":1006},[976,1960,1123],{"class":989},[976,1962,1939],{"class":1018},[976,1964,1169],{"class":1146},[976,1966,1945],{"class":1018},[976,1968,1828],{"class":1018},[976,1970,1971],{"class":978,"line":1012},[976,1972,997],{"emptyLinePlaceholder":996},[976,1974,1975],{"class":978,"line":1022},[976,1976,1977],{"class":982},"# 设置组管理员\n",[976,1979,1980,1982,1984,1987,1989],{"class":978,"line":1027},[976,1981,1123],{"class":989},[976,1983,1939],{"class":1018},[976,1985,1986],{"class":1146}," -A",[976,1988,1945],{"class":1018},[976,1990,1828],{"class":1018},[892,1992,1993],{"id":1993},"权限管理",[963,1995,1996],{"id":1996},"权限类型",[903,1998,1999,2018],{},[906,2000,2001],{},[909,2002,2003,2006,2009,2012,2015],{},[912,2004,2005],{"align":914},"权限",[912,2007,2008],{"align":914},"字母",[912,2010,2011],{"align":914},"数字",[912,2013,2014],{"align":914},"对文件的含义",[912,2016,2017],{"align":914},"对目录的含义",[923,2019,2020,2037,2054],{},[909,2021,2022,2025,2028,2031,2034],{},[928,2023,2024],{"align":914},"读",[928,2026,2027],{"align":914},"r",[928,2029,2030],{"align":914},"4",[928,2032,2033],{"align":914},"读取内容",[928,2035,2036],{"align":914},"列出目录内容",[909,2038,2039,2042,2045,2048,2051],{},[928,2040,2041],{"align":914},"写",[928,2043,2044],{"align":914},"w",[928,2046,2047],{"align":914},"2",[928,2049,2050],{"align":914},"修改内容",[928,2052,2053],{"align":914},"创建\u002F删除文件",[909,2055,2056,2059,2062,2065,2068],{},[928,2057,2058],{"align":914},"执行",[928,2060,2061],{"align":914},"x",[928,2063,2064],{"align":914},"1",[928,2066,2067],{"align":914},"执行文件",[928,2069,2070],{"align":914},"进入目录",[963,2072,2073],{"id":2073},"权限表示",[967,2075,2077],{"className":969,"code":2076,"language":971,"meta":11,"style":11},"# 符号表示\n-rwxr-xr--\n│└┬┘└┬┘└┬┘\n│ │  │  └── 其他用户权限 (r--)\n│ │  └───── 组权限 (r-x)\n│ └──────── 所有者权限 (rwx)\n└────────── 文件类型\n\n# 数字表示\nrwx = 4+2+1 = 7\nr-x = 4+0+1 = 5\nr-- = 4+0+0 = 4\n所以 rwxr-xr-- = 754\n",[973,2078,2079,2084,2089,2094,2115,2130,2143,2151,2155,2160,2176,2191,2206],{"__ignoreMap":11},[976,2080,2081],{"class":978,"line":979},[976,2082,2083],{"class":982},"# 符号表示\n",[976,2085,2086],{"class":978,"line":986},[976,2087,2088],{"class":989},"-rwxr-xr--\n",[976,2090,2091],{"class":978,"line":993},[976,2092,2093],{"class":989},"│└┬┘└┬┘└┬┘\n",[976,2095,2096,2099,2102,2105,2108,2111],{"class":978,"line":1000},[976,2097,2098],{"class":989},"│",[976,2100,2101],{"class":1018}," │",[976,2103,2104],{"class":1018},"  │",[976,2106,2107],{"class":1018},"  └──",[976,2109,2110],{"class":1018}," 其他用户权限",[976,2112,2114],{"class":2113},"sxrX7"," (r--)\n",[976,2116,2117,2119,2121,2124,2127],{"class":978,"line":1006},[976,2118,2098],{"class":989},[976,2120,2101],{"class":1018},[976,2122,2123],{"class":1018},"  └─────",[976,2125,2126],{"class":1018}," 组权限",[976,2128,2129],{"class":2113}," (r-x)\n",[976,2131,2132,2134,2137,2140],{"class":978,"line":1012},[976,2133,2098],{"class":989},[976,2135,2136],{"class":1018}," └────────",[976,2138,2139],{"class":1018}," 所有者权限",[976,2141,2142],{"class":2113}," (rwx)\n",[976,2144,2145,2148],{"class":978,"line":1022},[976,2146,2147],{"class":989},"└──────────",[976,2149,2150],{"class":1018}," 文件类型\n",[976,2152,2153],{"class":978,"line":1027},[976,2154,997],{"emptyLinePlaceholder":996},[976,2156,2157],{"class":978,"line":1033},[976,2158,2159],{"class":982},"# 数字表示\n",[976,2161,2162,2165,2168,2171,2173],{"class":978,"line":1039},[976,2163,2164],{"class":989},"rwx",[976,2166,2167],{"class":1018}," =",[976,2169,2170],{"class":1018}," 4+2+1",[976,2172,2167],{"class":1018},[976,2174,2175],{"class":1146}," 7\n",[976,2177,2178,2181,2183,2186,2188],{"class":978,"line":1045},[976,2179,2180],{"class":989},"r-x",[976,2182,2167],{"class":1018},[976,2184,2185],{"class":1018}," 4+0+1",[976,2187,2167],{"class":1018},[976,2189,2190],{"class":1146}," 5\n",[976,2192,2193,2196,2198,2201,2203],{"class":978,"line":1050},[976,2194,2195],{"class":989},"r--",[976,2197,2167],{"class":1018},[976,2199,2200],{"class":1018}," 4+0+0",[976,2202,2167],{"class":1018},[976,2204,2205],{"class":1146}," 4\n",[976,2207,2208,2211,2214,2216],{"class":978,"line":1056},[976,2209,2210],{"class":989},"所以",[976,2212,2213],{"class":1018}," rwxr-xr--",[976,2215,2167],{"class":1018},[976,2217,2218],{"class":1146}," 754\n",[963,2220,2222],{"id":2221},"chmod-修改权限","chmod - 修改权限",[896,2224,2225],{},[2226,2227,2228],"strong",{},"符号模式：",[967,2230,2232],{"className":969,"code":2231,"language":971,"meta":11,"style":11},"# 用户类别\n# u: 所有者 (user)\n# g: 所属组 (group)\n# o: 其他人 (others)\n# a: 所有人 (all)\n\n# 操作符\n# +: 添加权限\n# -: 移除权限\n# =: 设置权限\n\n# 示例\nchmod u+x file.txt        # 所有者添加执行权限\nchmod g-w file.txt        # 组移除写权限\nchmod o=r file.txt        # 其他人只有读权限\nchmod a+x file.txt        # 所有人添加执行权限\nchmod u+x,g-w file.txt    # 组合操作\nchmod ug=rw,o=r file.txt  # 设置多个\n",[973,2233,2234,2239,2244,2249,2254,2259,2263,2268,2273,2278,2283,2287,2292,2306,2318,2330,2342,2354],{"__ignoreMap":11},[976,2235,2236],{"class":978,"line":979},[976,2237,2238],{"class":982},"# 用户类别\n",[976,2240,2241],{"class":978,"line":986},[976,2242,2243],{"class":982},"# u: 所有者 (user)\n",[976,2245,2246],{"class":978,"line":993},[976,2247,2248],{"class":982},"# g: 所属组 (group)\n",[976,2250,2251],{"class":978,"line":1000},[976,2252,2253],{"class":982},"# o: 其他人 (others)\n",[976,2255,2256],{"class":978,"line":1006},[976,2257,2258],{"class":982},"# a: 所有人 (all)\n",[976,2260,2261],{"class":978,"line":1012},[976,2262,997],{"emptyLinePlaceholder":996},[976,2264,2265],{"class":978,"line":1022},[976,2266,2267],{"class":982},"# 操作符\n",[976,2269,2270],{"class":978,"line":1027},[976,2271,2272],{"class":982},"# +: 添加权限\n",[976,2274,2275],{"class":978,"line":1033},[976,2276,2277],{"class":982},"# -: 移除权限\n",[976,2279,2280],{"class":978,"line":1039},[976,2281,2282],{"class":982},"# =: 设置权限\n",[976,2284,2285],{"class":978,"line":1045},[976,2286,997],{"emptyLinePlaceholder":996},[976,2288,2289],{"class":978,"line":1050},[976,2290,2291],{"class":982},"# 示例\n",[976,2293,2294,2297,2300,2303],{"class":978,"line":1056},[976,2295,2296],{"class":989},"chmod",[976,2298,2299],{"class":1018}," u+x",[976,2301,2302],{"class":1018}," file.txt",[976,2304,2305],{"class":982},"        # 所有者添加执行权限\n",[976,2307,2308,2310,2313,2315],{"class":978,"line":1064},[976,2309,2296],{"class":989},[976,2311,2312],{"class":1018}," g-w",[976,2314,2302],{"class":1018},[976,2316,2317],{"class":982},"        # 组移除写权限\n",[976,2319,2320,2322,2325,2327],{"class":978,"line":1069},[976,2321,2296],{"class":989},[976,2323,2324],{"class":1018}," o=r",[976,2326,2302],{"class":1018},[976,2328,2329],{"class":982},"        # 其他人只有读权限\n",[976,2331,2332,2334,2337,2339],{"class":978,"line":1075},[976,2333,2296],{"class":989},[976,2335,2336],{"class":1018}," a+x",[976,2338,2302],{"class":1018},[976,2340,2341],{"class":982},"        # 所有人添加执行权限\n",[976,2343,2344,2346,2349,2351],{"class":978,"line":1084},[976,2345,2296],{"class":989},[976,2347,2348],{"class":1018}," u+x,g-w",[976,2350,2302],{"class":1018},[976,2352,2353],{"class":982},"    # 组合操作\n",[976,2355,2356,2358,2361,2363],{"class":978,"line":1089},[976,2357,2296],{"class":989},[976,2359,2360],{"class":1018}," ug=rw,o=r",[976,2362,2302],{"class":1018},[976,2364,2365],{"class":982},"  # 设置多个\n",[896,2367,2368],{},[2226,2369,2370],{},"数字模式：",[967,2372,2374],{"className":969,"code":2373,"language":971,"meta":11,"style":11},"chmod 755 file.txt    # rwxr-xr-x\nchmod 644 file.txt    # rw-r--r--\nchmod 700 file.txt    # rwx------\nchmod 777 file.txt    # rwxrwxrwx（不推荐）\n",[973,2375,2376,2388,2400,2412],{"__ignoreMap":11},[976,2377,2378,2380,2383,2385],{"class":978,"line":979},[976,2379,2296],{"class":989},[976,2381,2382],{"class":1146}," 755",[976,2384,2302],{"class":1018},[976,2386,2387],{"class":982},"    # rwxr-xr-x\n",[976,2389,2390,2392,2395,2397],{"class":978,"line":986},[976,2391,2296],{"class":989},[976,2393,2394],{"class":1146}," 644",[976,2396,2302],{"class":1018},[976,2398,2399],{"class":982},"    # rw-r--r--\n",[976,2401,2402,2404,2407,2409],{"class":978,"line":993},[976,2403,2296],{"class":989},[976,2405,2406],{"class":1146}," 700",[976,2408,2302],{"class":1018},[976,2410,2411],{"class":982},"    # rwx------\n",[976,2413,2414,2416,2419,2421],{"class":978,"line":1000},[976,2415,2296],{"class":989},[976,2417,2418],{"class":1146}," 777",[976,2420,2302],{"class":1018},[976,2422,2423],{"class":982},"    # rwxrwxrwx（不推荐）\n",[896,2425,2426],{},[2226,2427,2428],{},"递归修改：",[967,2430,2432],{"className":969,"code":2431,"language":971,"meta":11,"style":11},"# 递归修改目录及其内容\nchmod -R 755 directory\u002F\n",[973,2433,2434,2439],{"__ignoreMap":11},[976,2435,2436],{"class":978,"line":979},[976,2437,2438],{"class":982},"# 递归修改目录及其内容\n",[976,2440,2441,2443,2446,2448],{"class":978,"line":986},[976,2442,2296],{"class":989},[976,2444,2445],{"class":1146}," -R",[976,2447,2382],{"class":1146},[976,2449,2450],{"class":1018}," directory\u002F\n",[896,2452,2453],{},[2226,2454,2455],{},"常用权限组合：",[903,2457,2458,2466],{},[906,2459,2460],{},[909,2461,2462,2464],{},[912,2463,2005],{"align":914},[912,2465,921],{"align":914},[923,2467,2468,2476,2484,2492],{},[909,2469,2470,2473],{},[928,2471,2472],{"align":914},"755",[928,2474,2475],{"align":914},"目录\u002F可执行文件",[909,2477,2478,2481],{},[928,2479,2480],{"align":914},"644",[928,2482,2483],{"align":914},"普通文件",[909,2485,2486,2489],{},[928,2487,2488],{"align":914},"600",[928,2490,2491],{"align":914},"私密文件（如密钥）",[909,2493,2494,2497],{},[928,2495,2496],{"align":914},"700",[928,2498,2499],{"align":914},"私密目录",[963,2501,2503],{"id":2502},"chown-修改所有者","chown - 修改所有者",[967,2505,2507],{"className":969,"code":2506,"language":971,"meta":11,"style":11},"# 修改所有者\nsudo chown user file.txt\n\n# 修改所有者和组\nsudo chown user:group file.txt\n\n# 只修改组\nsudo chown :group file.txt\n\n# 递归修改\nsudo chown -R user:group directory\u002F\n\n# 参考其他文件\nsudo chown --reference=ref_file target_file\n",[973,2508,2509,2514,2527,2531,2536,2547,2551,2556,2567,2571,2576,2588,2592,2597],{"__ignoreMap":11},[976,2510,2511],{"class":978,"line":979},[976,2512,2513],{"class":982},"# 修改所有者\n",[976,2515,2516,2518,2521,2524],{"class":978,"line":986},[976,2517,1123],{"class":989},[976,2519,2520],{"class":1018}," chown",[976,2522,2523],{"class":1018}," user",[976,2525,2526],{"class":1018}," file.txt\n",[976,2528,2529],{"class":978,"line":993},[976,2530,997],{"emptyLinePlaceholder":996},[976,2532,2533],{"class":978,"line":1000},[976,2534,2535],{"class":982},"# 修改所有者和组\n",[976,2537,2538,2540,2542,2545],{"class":978,"line":1006},[976,2539,1123],{"class":989},[976,2541,2520],{"class":1018},[976,2543,2544],{"class":1018}," user:group",[976,2546,2526],{"class":1018},[976,2548,2549],{"class":978,"line":1012},[976,2550,997],{"emptyLinePlaceholder":996},[976,2552,2553],{"class":978,"line":1022},[976,2554,2555],{"class":982},"# 只修改组\n",[976,2557,2558,2560,2562,2565],{"class":978,"line":1027},[976,2559,1123],{"class":989},[976,2561,2520],{"class":1018},[976,2563,2564],{"class":1018}," :group",[976,2566,2526],{"class":1018},[976,2568,2569],{"class":978,"line":1033},[976,2570,997],{"emptyLinePlaceholder":996},[976,2572,2573],{"class":978,"line":1039},[976,2574,2575],{"class":982},"# 递归修改\n",[976,2577,2578,2580,2582,2584,2586],{"class":978,"line":1045},[976,2579,1123],{"class":989},[976,2581,2520],{"class":1018},[976,2583,2445],{"class":1146},[976,2585,2544],{"class":1018},[976,2587,2450],{"class":1018},[976,2589,2590],{"class":978,"line":1050},[976,2591,997],{"emptyLinePlaceholder":996},[976,2593,2594],{"class":978,"line":1056},[976,2595,2596],{"class":982},"# 参考其他文件\n",[976,2598,2599,2601,2603,2606],{"class":978,"line":1064},[976,2600,1123],{"class":989},[976,2602,2520],{"class":1018},[976,2604,2605],{"class":1146}," --reference=ref_file",[976,2607,2608],{"class":1018}," target_file\n",[963,2610,2612],{"id":2611},"chgrp-修改所属组","chgrp - 修改所属组",[967,2614,2616],{"className":969,"code":2615,"language":971,"meta":11,"style":11},"# 修改组\nsudo chgrp group file.txt\n\n# 递归修改\nsudo chgrp -R group directory\u002F\n",[973,2617,2618,2623,2635,2639,2643],{"__ignoreMap":11},[976,2619,2620],{"class":978,"line":979},[976,2621,2622],{"class":982},"# 修改组\n",[976,2624,2625,2627,2630,2633],{"class":978,"line":986},[976,2626,1123],{"class":989},[976,2628,2629],{"class":1018}," chgrp",[976,2631,2632],{"class":1018}," group",[976,2634,2526],{"class":1018},[976,2636,2637],{"class":978,"line":993},[976,2638,997],{"emptyLinePlaceholder":996},[976,2640,2641],{"class":978,"line":1000},[976,2642,2575],{"class":982},[976,2644,2645,2647,2649,2651,2653],{"class":978,"line":1006},[976,2646,1123],{"class":989},[976,2648,2629],{"class":1018},[976,2650,2445],{"class":1146},[976,2652,2632],{"class":1018},[976,2654,2450],{"class":1018},[892,2656,2657],{"id":2657},"特殊权限",[963,2659,2661],{"id":2660},"suidset-user-id","SUID（Set User ID）",[896,2663,2664],{},"文件执行时以所有者身份运行。",[967,2666,2668],{"className":969,"code":2667,"language":971,"meta":11,"style":11},"# 设置 SUID\nchmod u+s file\nchmod 4755 file\n\n# 查看（s 在所有者执行位）\n-rwsr-xr-x\n\n# 典型例子\nls -l \u002Fusr\u002Fbin\u002Fpasswd\n# -rwsr-xr-x 1 root root ... \u002Fusr\u002Fbin\u002Fpasswd\n",[973,2669,2670,2675,2685,2694,2698,2703,2708,2712,2717,2727],{"__ignoreMap":11},[976,2671,2672],{"class":978,"line":979},[976,2673,2674],{"class":982},"# 设置 SUID\n",[976,2676,2677,2679,2682],{"class":978,"line":986},[976,2678,2296],{"class":989},[976,2680,2681],{"class":1018}," u+s",[976,2683,2684],{"class":1018}," file\n",[976,2686,2687,2689,2692],{"class":978,"line":993},[976,2688,2296],{"class":989},[976,2690,2691],{"class":1146}," 4755",[976,2693,2684],{"class":1018},[976,2695,2696],{"class":978,"line":1000},[976,2697,997],{"emptyLinePlaceholder":996},[976,2699,2700],{"class":978,"line":1006},[976,2701,2702],{"class":982},"# 查看（s 在所有者执行位）\n",[976,2704,2705],{"class":978,"line":1012},[976,2706,2707],{"class":989},"-rwsr-xr-x\n",[976,2709,2710],{"class":978,"line":1022},[976,2711,997],{"emptyLinePlaceholder":996},[976,2713,2714],{"class":978,"line":1027},[976,2715,2716],{"class":982},"# 典型例子\n",[976,2718,2719,2722,2724],{"class":978,"line":1033},[976,2720,2721],{"class":989},"ls",[976,2723,1379],{"class":1146},[976,2725,2726],{"class":1018}," \u002Fusr\u002Fbin\u002Fpasswd\n",[976,2728,2729],{"class":978,"line":1039},[976,2730,2731],{"class":982},"# -rwsr-xr-x 1 root root ... \u002Fusr\u002Fbin\u002Fpasswd\n",[963,2733,2735],{"id":2734},"sgidset-group-id","SGID（Set Group ID）",[2737,2738,2739,2743],"ul",{},[2740,2741,2742],"li",{},"文件：执行时以组身份运行",[2740,2744,2745],{},"目录：新建文件继承目录的组",[967,2747,2749],{"className":969,"code":2748,"language":971,"meta":11,"style":11},"# 设置 SGID\nchmod g+s file\nchmod 2755 file\n\n# 查看（s 在组执行位）\n-rwxr-sr-x\ndrwxr-sr-x\n\n# 目录 SGID 示例\nsudo mkdir \u002Fshared\nsudo chown :developers \u002Fshared\nsudo chmod 2775 \u002Fshared\n# 新建文件自动属于 developers 组\n",[973,2750,2751,2756,2765,2774,2778,2783,2788,2793,2797,2802,2812,2823,2835],{"__ignoreMap":11},[976,2752,2753],{"class":978,"line":979},[976,2754,2755],{"class":982},"# 设置 SGID\n",[976,2757,2758,2760,2763],{"class":978,"line":986},[976,2759,2296],{"class":989},[976,2761,2762],{"class":1018}," g+s",[976,2764,2684],{"class":1018},[976,2766,2767,2769,2772],{"class":978,"line":993},[976,2768,2296],{"class":989},[976,2770,2771],{"class":1146}," 2755",[976,2773,2684],{"class":1018},[976,2775,2776],{"class":978,"line":1000},[976,2777,997],{"emptyLinePlaceholder":996},[976,2779,2780],{"class":978,"line":1006},[976,2781,2782],{"class":982},"# 查看（s 在组执行位）\n",[976,2784,2785],{"class":978,"line":1012},[976,2786,2787],{"class":989},"-rwxr-sr-x\n",[976,2789,2790],{"class":978,"line":1022},[976,2791,2792],{"class":989},"drwxr-sr-x\n",[976,2794,2795],{"class":978,"line":1027},[976,2796,997],{"emptyLinePlaceholder":996},[976,2798,2799],{"class":978,"line":1033},[976,2800,2801],{"class":982},"# 目录 SGID 示例\n",[976,2803,2804,2806,2809],{"class":978,"line":1039},[976,2805,1123],{"class":989},[976,2807,2808],{"class":1018}," mkdir",[976,2810,2811],{"class":1018}," \u002Fshared\n",[976,2813,2814,2816,2818,2821],{"class":978,"line":1045},[976,2815,1123],{"class":989},[976,2817,2520],{"class":1018},[976,2819,2820],{"class":1018}," :developers",[976,2822,2811],{"class":1018},[976,2824,2825,2827,2830,2833],{"class":978,"line":1050},[976,2826,1123],{"class":989},[976,2828,2829],{"class":1018}," chmod",[976,2831,2832],{"class":1146}," 2775",[976,2834,2811],{"class":1018},[976,2836,2837],{"class":978,"line":1056},[976,2838,2839],{"class":982},"# 新建文件自动属于 developers 组\n",[963,2841,2843],{"id":2842},"sticky-bit","Sticky Bit",[896,2845,2846],{},"目录中的文件只能由所有者删除。",[967,2848,2850],{"className":969,"code":2849,"language":971,"meta":11,"style":11},"# 设置 Sticky Bit\nchmod +t directory\nchmod 1777 directory\n\n# 查看（t 在其他用户执行位）\ndrwxrwxrwt\n\n# 典型例子\nls -ld \u002Ftmp\n# drwxrwxrwt 1 root root ... \u002Ftmp\n",[973,2851,2852,2857,2867,2876,2880,2885,2890,2894,2898,2908],{"__ignoreMap":11},[976,2853,2854],{"class":978,"line":979},[976,2855,2856],{"class":982},"# 设置 Sticky Bit\n",[976,2858,2859,2861,2864],{"class":978,"line":986},[976,2860,2296],{"class":989},[976,2862,2863],{"class":1018}," +t",[976,2865,2866],{"class":1018}," directory\n",[976,2868,2869,2871,2874],{"class":978,"line":993},[976,2870,2296],{"class":989},[976,2872,2873],{"class":1146}," 1777",[976,2875,2866],{"class":1018},[976,2877,2878],{"class":978,"line":1000},[976,2879,997],{"emptyLinePlaceholder":996},[976,2881,2882],{"class":978,"line":1006},[976,2883,2884],{"class":982},"# 查看（t 在其他用户执行位）\n",[976,2886,2887],{"class":978,"line":1012},[976,2888,2889],{"class":989},"drwxrwxrwt\n",[976,2891,2892],{"class":978,"line":1022},[976,2893,997],{"emptyLinePlaceholder":996},[976,2895,2896],{"class":978,"line":1027},[976,2897,2716],{"class":982},[976,2899,2900,2902,2905],{"class":978,"line":1033},[976,2901,2721],{"class":989},[976,2903,2904],{"class":1146}," -ld",[976,2906,2907],{"class":1018}," \u002Ftmp\n",[976,2909,2910],{"class":978,"line":1039},[976,2911,2912],{"class":982},"# drwxrwxrwt 1 root root ... \u002Ftmp\n",[892,2914,2915],{"id":2915},"默认权限",[963,2917,2918],{"id":2918},"umask",[896,2920,2921],{},"umask 决定新建文件\u002F目录的默认权限。",[967,2923,2925],{"className":969,"code":2924,"language":971,"meta":11,"style":11},"# 查看 umask\numask\n\n# 设置 umask\numask 022\n\n# 计算默认权限\n# 文件：666 - umask = 666 - 022 = 644\n# 目录：777 - umask = 777 - 022 = 755\n\n# 常见 umask 值\n# 022: 文件 644，目录 755（默认）\n# 027: 文件 640，目录 750\n# 077: 文件 600，目录 700\n\n# 永久设置（添加到 ~\u002F.bashrc）\necho \"umask 027\" >> ~\u002F.bashrc\n",[973,2926,2927,2932,2937,2941,2946,2953,2957,2962,2967,2972,2976,2981,2986,2991,2996,3000,3005],{"__ignoreMap":11},[976,2928,2929],{"class":978,"line":979},[976,2930,2931],{"class":982},"# 查看 umask\n",[976,2933,2934],{"class":978,"line":986},[976,2935,2936],{"class":1146},"umask\n",[976,2938,2939],{"class":978,"line":993},[976,2940,997],{"emptyLinePlaceholder":996},[976,2942,2943],{"class":978,"line":1000},[976,2944,2945],{"class":982},"# 设置 umask\n",[976,2947,2948,2950],{"class":978,"line":1006},[976,2949,2918],{"class":1146},[976,2951,2952],{"class":1146}," 022\n",[976,2954,2955],{"class":978,"line":1012},[976,2956,997],{"emptyLinePlaceholder":996},[976,2958,2959],{"class":978,"line":1022},[976,2960,2961],{"class":982},"# 计算默认权限\n",[976,2963,2964],{"class":978,"line":1027},[976,2965,2966],{"class":982},"# 文件：666 - umask = 666 - 022 = 644\n",[976,2968,2969],{"class":978,"line":1033},[976,2970,2971],{"class":982},"# 目录：777 - umask = 777 - 022 = 755\n",[976,2973,2974],{"class":978,"line":1039},[976,2975,997],{"emptyLinePlaceholder":996},[976,2977,2978],{"class":978,"line":1045},[976,2979,2980],{"class":982},"# 常见 umask 值\n",[976,2982,2983],{"class":978,"line":1050},[976,2984,2985],{"class":982},"# 022: 文件 644，目录 755（默认）\n",[976,2987,2988],{"class":978,"line":1056},[976,2989,2990],{"class":982},"# 027: 文件 640，目录 750\n",[976,2992,2993],{"class":978,"line":1064},[976,2994,2995],{"class":982},"# 077: 文件 600，目录 700\n",[976,2997,2998],{"class":978,"line":1069},[976,2999,997],{"emptyLinePlaceholder":996},[976,3001,3002],{"class":978,"line":1075},[976,3003,3004],{"class":982},"# 永久设置（添加到 ~\u002F.bashrc）\n",[976,3006,3007,3010,3013,3017],{"class":978,"line":1084},[976,3008,3009],{"class":1146},"echo",[976,3011,3012],{"class":1018}," \"umask 027\"",[976,3014,3016],{"class":3015},"s8jYJ"," >>",[976,3018,3019],{"class":1018}," ~\u002F.bashrc\n",[892,3021,3023],{"id":3022},"sudo-权限","sudo 权限",[963,3025,3027],{"id":3026},"配置-sudo","配置 sudo",[967,3029,3031],{"className":969,"code":3030,"language":971,"meta":11,"style":11},"# 编辑 sudoers 文件（使用 visudo）\nsudo visudo\n\n# 配置格式\n# 用户 主机=(运行身份) 命令\nusername ALL=(ALL) ALL              # 完全权限\nusername ALL=(ALL) NOPASSWD: ALL    # 无需密码\nusername ALL=(ALL) \u002Fusr\u002Fbin\u002Fapt     # 只能执行特定命令\n\n# 组配置（% 表示组）\n%sudo ALL=(ALL) ALL\n%admin ALL=(ALL) NOPASSWD: ALL\n",[973,3032,3033,3038,3045,3049,3054,3059,3081,3102,3120,3124,3129,3145],{"__ignoreMap":11},[976,3034,3035],{"class":978,"line":979},[976,3036,3037],{"class":982},"# 编辑 sudoers 文件（使用 visudo）\n",[976,3039,3040,3042],{"class":978,"line":986},[976,3041,1123],{"class":989},[976,3043,3044],{"class":1018}," visudo\n",[976,3046,3047],{"class":978,"line":993},[976,3048,997],{"emptyLinePlaceholder":996},[976,3050,3051],{"class":978,"line":1000},[976,3052,3053],{"class":982},"# 配置格式\n",[976,3055,3056],{"class":978,"line":1006},[976,3057,3058],{"class":982},"# 用户 主机=(运行身份) 命令\n",[976,3060,3061,3064,3067,3070,3073,3076,3078],{"class":978,"line":1012},[976,3062,3063],{"class":989},"username",[976,3065,3066],{"class":1018}," ALL=",[976,3068,3069],{"class":2113},"(",[976,3071,3072],{"class":989},"ALL",[976,3074,3075],{"class":2113},") ",[976,3077,3072],{"class":1018},[976,3079,3080],{"class":982},"              # 完全权限\n",[976,3082,3083,3085,3087,3089,3091,3093,3096,3099],{"class":978,"line":1022},[976,3084,3063],{"class":989},[976,3086,3066],{"class":1018},[976,3088,3069],{"class":2113},[976,3090,3072],{"class":989},[976,3092,3075],{"class":2113},[976,3094,3095],{"class":1018},"NOPASSWD:",[976,3097,3098],{"class":1018}," ALL",[976,3100,3101],{"class":982},"    # 无需密码\n",[976,3103,3104,3106,3108,3110,3112,3114,3117],{"class":978,"line":1027},[976,3105,3063],{"class":989},[976,3107,3066],{"class":1018},[976,3109,3069],{"class":2113},[976,3111,3072],{"class":989},[976,3113,3075],{"class":2113},[976,3115,3116],{"class":1018},"\u002Fusr\u002Fbin\u002Fapt",[976,3118,3119],{"class":982},"     # 只能执行特定命令\n",[976,3121,3122],{"class":978,"line":1033},[976,3123,997],{"emptyLinePlaceholder":996},[976,3125,3126],{"class":978,"line":1039},[976,3127,3128],{"class":982},"# 组配置（% 表示组）\n",[976,3130,3131,3134,3136,3138,3140,3142],{"class":978,"line":1045},[976,3132,3133],{"class":989},"%sudo",[976,3135,3066],{"class":1018},[976,3137,3069],{"class":2113},[976,3139,3072],{"class":989},[976,3141,3075],{"class":2113},[976,3143,3144],{"class":1018},"ALL\n",[976,3146,3147,3150,3152,3154,3156,3158,3160],{"class":978,"line":1050},[976,3148,3149],{"class":989},"%admin",[976,3151,3066],{"class":1018},[976,3153,3069],{"class":2113},[976,3155,3072],{"class":989},[976,3157,3075],{"class":2113},[976,3159,3095],{"class":1018},[976,3161,3162],{"class":1018}," ALL\n",[963,3164,3166],{"id":3165},"使用-sudo","使用 sudo",[967,3168,3170],{"className":969,"code":3169,"language":971,"meta":11,"style":11},"# 以 root 执行命令\nsudo command\n\n# 以指定用户执行\nsudo -u username command\n\n# 切换到 root shell\nsudo -i\nsudo su -\n\n# 编辑文件\nsudo -e \u002Fetc\u002Fconfig\n\n# 查看 sudo 权限\nsudo -l\n",[973,3171,3172,3177,3184,3188,3193,3203,3207,3212,3219,3229,3233,3238,3247,3251,3256],{"__ignoreMap":11},[976,3173,3174],{"class":978,"line":979},[976,3175,3176],{"class":982},"# 以 root 执行命令\n",[976,3178,3179,3181],{"class":978,"line":986},[976,3180,1123],{"class":989},[976,3182,3183],{"class":1018}," command\n",[976,3185,3186],{"class":978,"line":993},[976,3187,997],{"emptyLinePlaceholder":996},[976,3189,3190],{"class":978,"line":1000},[976,3191,3192],{"class":982},"# 以指定用户执行\n",[976,3194,3195,3197,3199,3201],{"class":978,"line":1006},[976,3196,1123],{"class":989},[976,3198,1215],{"class":1146},[976,3200,1945],{"class":1018},[976,3202,3183],{"class":1018},[976,3204,3205],{"class":978,"line":1012},[976,3206,997],{"emptyLinePlaceholder":996},[976,3208,3209],{"class":978,"line":1022},[976,3210,3211],{"class":982},"# 切换到 root shell\n",[976,3213,3214,3216],{"class":978,"line":1027},[976,3215,1123],{"class":989},[976,3217,3218],{"class":1146}," -i\n",[976,3220,3221,3223,3226],{"class":978,"line":1033},[976,3222,1123],{"class":989},[976,3224,3225],{"class":1018}," su",[976,3227,3228],{"class":1018}," -\n",[976,3230,3231],{"class":978,"line":1039},[976,3232,997],{"emptyLinePlaceholder":996},[976,3234,3235],{"class":978,"line":1045},[976,3236,3237],{"class":982},"# 编辑文件\n",[976,3239,3240,3242,3244],{"class":978,"line":1050},[976,3241,1123],{"class":989},[976,3243,1287],{"class":1146},[976,3245,3246],{"class":1018}," \u002Fetc\u002Fconfig\n",[976,3248,3249],{"class":978,"line":1056},[976,3250,997],{"emptyLinePlaceholder":996},[976,3252,3253],{"class":978,"line":1064},[976,3254,3255],{"class":982},"# 查看 sudo 权限\n",[976,3257,3258,3260],{"class":978,"line":1069},[976,3259,1123],{"class":989},[976,3261,3262],{"class":1146}," -l\n",[892,3264,3265],{"id":3265},"切换用户",[963,3267,3269],{"id":3268},"su-切换用户","su - 切换用户",[967,3271,3273],{"className":969,"code":3272,"language":971,"meta":11,"style":11},"# 切换到 root\nsu\nsu -\n\n# 切换到指定用户\nsu username\nsu - username    # 同时加载环境变量\n\n# 以用户身份执行命令\nsu - username -c \"command\"\n",[973,3274,3275,3280,3285,3292,3296,3301,3307,3319,3323,3328],{"__ignoreMap":11},[976,3276,3277],{"class":978,"line":979},[976,3278,3279],{"class":982},"# 切换到 root\n",[976,3281,3282],{"class":978,"line":986},[976,3283,3284],{"class":989},"su\n",[976,3286,3287,3290],{"class":978,"line":993},[976,3288,3289],{"class":989},"su",[976,3291,3228],{"class":1018},[976,3293,3294],{"class":978,"line":1000},[976,3295,997],{"emptyLinePlaceholder":996},[976,3297,3298],{"class":978,"line":1006},[976,3299,3300],{"class":982},"# 切换到指定用户\n",[976,3302,3303,3305],{"class":978,"line":1012},[976,3304,3289],{"class":989},[976,3306,1019],{"class":1018},[976,3308,3309,3311,3314,3316],{"class":978,"line":1022},[976,3310,3289],{"class":989},[976,3312,3313],{"class":1018}," -",[976,3315,1945],{"class":1018},[976,3317,3318],{"class":982},"    # 同时加载环境变量\n",[976,3320,3321],{"class":978,"line":1027},[976,3322,997],{"emptyLinePlaceholder":996},[976,3324,3325],{"class":978,"line":1033},[976,3326,3327],{"class":982},"# 以用户身份执行命令\n",[976,3329,3330,3332,3334,3336,3338],{"class":978,"line":1039},[976,3331,3289],{"class":989},[976,3333,3313],{"class":1018},[976,3335,1945],{"class":1018},[976,3337,1313],{"class":1146},[976,3339,3340],{"class":1018}," \"command\"\n",[963,3342,3343],{"id":3343},"区别",[903,3345,3346,3355],{},[906,3347,3348],{},[909,3349,3350,3353],{},[912,3351,3352],{"align":914},"命令",[912,3354,921],{"align":914},[923,3356,3357,3364,3372,3379],{},[909,3358,3359,3361],{},[928,3360,3289],{"align":914},[928,3362,3363],{"align":914},"只切换用户",[909,3365,3366,3369],{},[928,3367,3368],{"align":914},"su -",[928,3370,3371],{"align":914},"切换用户并加载环境",[909,3373,3374,3376],{},[928,3375,1123],{"align":914},[928,3377,3378],{"align":914},"以其他用户身份执行命令",[909,3380,3381,3384],{},[928,3382,3383],{"align":914},"sudo -i",[928,3385,3386],{"align":914},"切换到 root 并加载环境",[892,3388,3390],{"id":3389},"acl访问控制列表","ACL（访问控制列表）",[896,3392,3393],{},"ACL 提供更细粒度的权限控制。",[967,3395,3397],{"className":969,"code":3396,"language":971,"meta":11,"style":11},"# 查看 ACL\ngetfacl file.txt\n\n# 设置用户 ACL\nsetfacl -m u:username:rw file.txt\n\n# 设置组 ACL\nsetfacl -m g:groupname:rx file.txt\n\n# 设置默认 ACL（对目录新建文件生效）\nsetfacl -d -m u:username:rw directory\u002F\n\n# 移除 ACL\nsetfacl -x u:username file.txt\n\n# 移除所有 ACL\nsetfacl -b file.txt\n\n# 递归设置\nsetfacl -R -m u:username:rx directory\u002F\n",[973,3398,3399,3404,3411,3415,3420,3432,3436,3441,3452,3456,3461,3473,3477,3482,3494,3498,3503,3512,3516,3521],{"__ignoreMap":11},[976,3400,3401],{"class":978,"line":979},[976,3402,3403],{"class":982},"# 查看 ACL\n",[976,3405,3406,3409],{"class":978,"line":986},[976,3407,3408],{"class":989},"getfacl",[976,3410,2526],{"class":1018},[976,3412,3413],{"class":978,"line":993},[976,3414,997],{"emptyLinePlaceholder":996},[976,3416,3417],{"class":978,"line":1000},[976,3418,3419],{"class":982},"# 设置用户 ACL\n",[976,3421,3422,3425,3427,3430],{"class":978,"line":1006},[976,3423,3424],{"class":989},"setfacl",[976,3426,1147],{"class":1146},[976,3428,3429],{"class":1018}," u:username:rw",[976,3431,2526],{"class":1018},[976,3433,3434],{"class":978,"line":1012},[976,3435,997],{"emptyLinePlaceholder":996},[976,3437,3438],{"class":978,"line":1022},[976,3439,3440],{"class":982},"# 设置组 ACL\n",[976,3442,3443,3445,3447,3450],{"class":978,"line":1027},[976,3444,3424],{"class":989},[976,3446,1147],{"class":1146},[976,3448,3449],{"class":1018}," g:groupname:rx",[976,3451,2526],{"class":1018},[976,3453,3454],{"class":978,"line":1033},[976,3455,997],{"emptyLinePlaceholder":996},[976,3457,3458],{"class":978,"line":1039},[976,3459,3460],{"class":982},"# 设置默认 ACL（对目录新建文件生效）\n",[976,3462,3463,3465,3467,3469,3471],{"class":978,"line":1045},[976,3464,3424],{"class":989},[976,3466,1169],{"class":1146},[976,3468,1147],{"class":1146},[976,3470,3429],{"class":1018},[976,3472,2450],{"class":1018},[976,3474,3475],{"class":978,"line":1050},[976,3476,997],{"emptyLinePlaceholder":996},[976,3478,3479],{"class":978,"line":1056},[976,3480,3481],{"class":982},"# 移除 ACL\n",[976,3483,3484,3486,3489,3492],{"class":978,"line":1064},[976,3485,3424],{"class":989},[976,3487,3488],{"class":1146}," -x",[976,3490,3491],{"class":1018}," u:username",[976,3493,2526],{"class":1018},[976,3495,3496],{"class":978,"line":1069},[976,3497,997],{"emptyLinePlaceholder":996},[976,3499,3500],{"class":978,"line":1075},[976,3501,3502],{"class":982},"# 移除所有 ACL\n",[976,3504,3505,3507,3510],{"class":978,"line":1084},[976,3506,3424],{"class":989},[976,3508,3509],{"class":1146}," -b",[976,3511,2526],{"class":1018},[976,3513,3514],{"class":978,"line":1089},[976,3515,997],{"emptyLinePlaceholder":996},[976,3517,3518],{"class":978,"line":1095},[976,3519,3520],{"class":982},"# 递归设置\n",[976,3522,3523,3525,3527,3529,3532],{"class":978,"line":1101},[976,3524,3424],{"class":989},[976,3526,2445],{"class":1146},[976,3528,1147],{"class":1146},[976,3530,3531],{"class":1018}," u:username:rx",[976,3533,2450],{"class":1018},[892,3535,3536],{"id":3536},"常用命令总结",[903,3538,3539,3551],{},[906,3540,3541],{},[909,3542,3543,3545,3548],{},[912,3544,3352],{"align":914},[912,3546,3547],{"align":914},"功能",[912,3549,3550],{"align":914},"常用选项",[923,3552,3553,3564,3575,3586,3597,3608,3618,3628,3637],{},[909,3554,3555,3558,3561],{},[928,3556,3557],{"align":914},"useradd",[928,3559,3560],{"align":914},"创建用户",[928,3562,3563],{"align":914},"-m, -s, -G",[909,3565,3566,3569,3572],{},[928,3567,3568],{"align":914},"usermod",[928,3570,3571],{"align":914},"修改用户",[928,3573,3574],{"align":914},"-aG, -L, -U",[909,3576,3577,3580,3583],{},[928,3578,3579],{"align":914},"userdel",[928,3581,3582],{"align":914},"删除用户",[928,3584,3585],{"align":914},"-r",[909,3587,3588,3591,3594],{},[928,3589,3590],{"align":914},"passwd",[928,3592,3593],{"align":914},"修改密码",[928,3595,3596],{"align":914},"-l, -u",[909,3598,3599,3602,3605],{},[928,3600,3601],{"align":914},"groupadd",[928,3603,3604],{"align":914},"创建组",[928,3606,3607],{"align":914},"-g",[909,3609,3610,3612,3615],{},[928,3611,2296],{"align":914},[928,3613,3614],{"align":914},"修改权限",[928,3616,3617],{"align":914},"-R",[909,3619,3620,3623,3626],{},[928,3621,3622],{"align":914},"chown",[928,3624,3625],{"align":914},"修改所有者",[928,3627,3617],{"align":914},[909,3629,3630,3632,3634],{},[928,3631,3289],{"align":914},[928,3633,3265],{"align":914},[928,3635,3636],{"align":914},"-",[909,3638,3639,3641,3644],{},[928,3640,1123],{"align":914},[928,3642,3643],{"align":914},"提权执行",[928,3645,3646],{"align":914},"-i, -u",[3648,3649,3651],"note",{"title":3650},"最佳实践","\n1. 遵循最小权限原则\n2. 避免直接使用 root 登录\n3. 敏感文件权限设为 600\n4. 可执行文件权限设为 755\n5. 使用 sudo 代替 su\n",[3653,3654,3655],"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 .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 .sBjJW, html code.shiki .sBjJW{--shiki-light:#005CC5;--shiki-default:#005CC5;--shiki-dark:#79B8FF}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}",{"title":11,"searchDepth":986,"depth":986,"links":3657},[3658,3659,3660,3667,3674,3681,3686,3689,3693,3697,3698],{"id":894,"depth":986,"text":894},{"id":901,"depth":986,"text":901},{"id":961,"depth":986,"text":961,"children":3661},[3662,3663,3664,3665,3666],{"id":965,"depth":993,"text":965},{"id":1107,"depth":993,"text":1108},{"id":1358,"depth":993,"text":1359},{"id":1539,"depth":993,"text":1540},{"id":1602,"depth":993,"text":1603},{"id":1735,"depth":986,"text":1735,"children":3668},[3669,3670,3671,3672,3673],{"id":1738,"depth":993,"text":1738},{"id":1807,"depth":993,"text":1808},{"id":1853,"depth":993,"text":1854},{"id":1903,"depth":993,"text":1904},{"id":1921,"depth":993,"text":1922},{"id":1993,"depth":986,"text":1993,"children":3675},[3676,3677,3678,3679,3680],{"id":1996,"depth":993,"text":1996},{"id":2073,"depth":993,"text":2073},{"id":2221,"depth":993,"text":2222},{"id":2502,"depth":993,"text":2503},{"id":2611,"depth":993,"text":2612},{"id":2657,"depth":986,"text":2657,"children":3682},[3683,3684,3685],{"id":2660,"depth":993,"text":2661},{"id":2734,"depth":993,"text":2735},{"id":2842,"depth":993,"text":2843},{"id":2915,"depth":986,"text":2915,"children":3687},[3688],{"id":2918,"depth":993,"text":2918},{"id":3022,"depth":986,"text":3023,"children":3690},[3691,3692],{"id":3026,"depth":993,"text":3027},{"id":3165,"depth":993,"text":3166},{"id":3265,"depth":986,"text":3265,"children":3694},[3695,3696],{"id":3268,"depth":993,"text":3269},{"id":3343,"depth":993,"text":3343},{"id":3389,"depth":986,"text":3390},{"id":3536,"depth":986,"text":3536},"md",{},{"title":690,"description":11},"tutorials\u002Fcloud\u002Flinux\u002Flinux-user-permission","9Iz09GMoaAh5lYWlTbcYEOAwt-z6m8IkeUPoYwBaGQk",1775496416112]