Linux yq命令

参考资料

  1. Linux yq 命令使用详解

目录

  • [一. 简介](#一. 简介)
  • [二. 安装](#二. 安装)
  • [三. 常用](#三. 常用)
    • [3.0 文件准备](#3.0 文件准备)
    • [3.1 查询](#3.1 查询)
      • [3.1.1 普通查询](#3.1.1 普通查询)
      • [3.1.2 过滤查询](#3.1.2 过滤查询)
    • [3.2 更新](#3.2 更新)
    • [3.3 删除](#3.3 删除)
    • [3.4 转换](#3.4 转换)
      • [3.4.1 yaml 转换 json](#3.4.1 yaml 转换 json)
      • [3.4.2 json 转换 yaml](#3.4.2 json 转换 yaml)
    • [3.5 统计](#3.5 统计)
    • [3.6 判断](#3.6 判断)
  • [四. 案例](#四. 案例)
    • [4.1 案例1](#4.1 案例1)
      • [4.1.1 文件准备](#4.1.1 文件准备)
      • [4.1.2 查看所有的服务名](#4.1.2 查看所有的服务名)
      • [4.1.3 查看某个服务的镜像](#4.1.3 查看某个服务的镜像)
      • [4.1.4 批量查看所有服务的 image](#4.1.4 批量查看所有服务的 image)
    • [4.2 案例2](#4.2 案例2)
      • [4.2.1 文件准备](#4.2.1 文件准备)
      • [4.2.2 查看所有 `kind` 字段](#4.2.2 查看所有 kind 字段)
      • [4.2.3 只修改 Deployment,不碰 Service](#4.2.3 只修改 Deployment,不碰 Service)

一. 简介

🔷在Linux中,处理Json数据的话,会用到jq命令。与此相对的是,处理Yaml文件的话,会用到yq命令。
jqyq 的使用方法类似,基本上掌握了jq之后,yq也差不多就掌握了。

工具 处理格式 核心用途
jq JSON 查询 / 修改 JSON
yq YAML 查询 / 修改 YAML(也能转 JSON)

🔷在Kubernetes中,有很多Yaml的配置文件,使用yq命令,可以更加方便的对其进行查询,编辑与修改。


二. 安装

🔷Ubuntu安装

bash 复制代码
# 切换为root用户
wget https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64 -O yq
chmod +x yq
mv yq /usr/local/bin/

🔷验证安装效果

bash 复制代码
apluser@FengYeHong-HP:~$ yq --version
yq (https://github.com/mikefarah/yq/) version v4.52.2

💥注意事项

  • yq 命令不是 Ubuntu 官方稳定包,无法通过 apt install yq 进行安装
  • 早年有个 Python 版的 yq,现在基本没人用了,目前主流的是使用 Go 写的 mikefarah/yq(v4)

三. 常用

3.0 文件准备

🔷config.yaml

bash 复制代码
server:
  host: localhost
  port: 8080
users:
  - name: Tom
    age: 18
  - name: Jack
    age: 20

3.1 查询

3.1.1 普通查询

🔷普通查询

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.server.host' config.yaml
localhost
apluser@FengYeHong-HP:20260208$ yq '.server.port' config.yaml
8080
apluser@FengYeHong-HP:20260208$

🔷数组查询

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.users' config.yaml
- name: Tom
  age: 18
- name: Jack
  age: 20
apluser@FengYeHong-HP:20260208$ yq '.users[0]' config.yaml
name: Tom
age: 18
apluser@FengYeHong-HP:20260208$
apluser@FengYeHong-HP:20260208$ yq '.users[0].name' config.yaml
Tom

3.1.2 过滤查询

🔷age > 18 的人

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.users[] | select(.age > 18)' config.yaml
name: Jack
age: 20

🔷name为Tom的人

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.users[] | select(.name == "Tom")' config.yaml
name: Tom
age: 18

🔷name为Tom的人的年龄

  • --unwrapScalar可以保证获取到的数据没有yaml样式
bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.users[] | select(.name == "Tom") | .age' --unwrapScalar config.yaml
18

🔷格式化输出

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.users[] | select(.name == "Tom") | "\(.name),\(.age)"' config.yaml
Tom,18

3.2 更新

🔷修改字段(不覆盖文件)

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.server.port = 9090' config.yaml
server:
  host: localhost
  port: 9090
users:
  - name: Tom
    age: 18
  - name: Jack
    age: 20

🔷-i直接修改原文件

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq -i '.server.port = 9090' config.yaml
apluser@FengYeHong-HP:20260208$
apluser@FengYeHong-HP:20260208$ cat config.yaml
server:
  host: localhost
  port: 9090
users:
  - name: Tom
    age: 18
  - name: Jack
    age: 20
apluser@FengYeHong-HP:20260208$

🔷直接新增字段

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq -i '.server.debug = true' config.yaml
apluser@FengYeHong-HP:20260208$
apluser@FengYeHong-HP:20260208$ cat config.yaml
server:
  host: localhost
  port: 9090
  debug: true
users:
  - name: Tom
    age: 18
  - name: Jack
    age: 20

3.3 删除

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq -i 'del(.server.debug)' config.yaml
apluser@FengYeHong-HP:20260208$
apluser@FengYeHong-HP:20260208$ cat config.yaml
server:
  host: localhost
  port: 9090
users:
  - name: Tom
    age: 18
  - name: Jack
    age: 20

3.4 转换

3.4.1 yaml 转换 json

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq -o=json '.' config.yaml
{
  "server": {
    "host": "localhost",
    "port": 9090
  },
  "users": [
    {
      "name": "Tom",
      "age": 18
    },
    {
      "name": "Jack",
      "age": 20
    }
  ]
}

3.4.2 json 转换 yaml

bash 复制代码
apluser@FengYeHong-HP:20260208$ cat config.json
{
  "server": {
    "host": "localhost",
    "port": 9090
  },
  "users": [
    {
      "name": "Tom",
      "age": 18
    },
    {
      "name": "Jack",
      "age": 20
    }
  ]
}
apluser@FengYeHong-HP:20260208$ yq -o=yaml '.' config.json
server:
  host: localhost
  port: 9090
users:
  - name: Tom
    age: 18
  - name: Jack
    age: 20

3.5 统计

🔷获取数组长度

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.users | length' config.yaml
2

3.6 判断

🔷判断指定的字段是否存在

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq 'has("server")' config.yaml
true

四. 案例

4.1 案例1

4.1.1 文件准备

🔷docker-compose.yml

bash 复制代码
version: "3.9"
services:
  web:
    image: nginx:1.25
    ports:
      - "8080:80"
    environment:
      - ENV=prod
      - DEBUG=false

  api:
    image: myapi:1.0
    ports:
      - "9000:9000"
    environment:
      ENV: dev
      LOG_LEVEL: info

4.1.2 查看所有的服务名

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.services | keys' docker-compose.yml
- web
- api

4.1.3 查看某个服务的镜像

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.services.web.image' docker-compose.yml
nginx:1.25

4.1.4 批量查看所有服务的 image

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.services[].image' docker-compose.yml
nginx:1.25
myapi:1.0
bash 复制代码
apluser@FengYeHong-HP:20260208$ yq '.services | to_entries[] | "\(.key): \(.value.image)"' docker-compose.yml
web: nginx:1.25
api: myapi:1.0

4.2 案例2

4.2.1 文件准备

🔷多文档 YAML → all.yaml

bash 复制代码
---
apiVersion: v1
kind: Service
metadata:
  name: myapp
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: myapp

4.2.2 查看所有 kind 字段

bash 复制代码
apluser@FengYeHong-HP:20260208$ yq 'select(.kind != null) | .kind' all.yaml
Service
---
Deployment

4.2.3 只修改 Deployment,不碰 Service

bash 复制代码
apluser@FengYeHong-HP:20260208$ cat all.yaml
---
apiVersion: v1
kind: Service
metadata:
  name: myapp
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: myapp
apluser@FengYeHong-HP:20260208$ yq 'select(.kind == "Deployment") | .metadata.name = "myapp_v1"' all.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: myapp_v1
相关推荐
深紫色的三北六号3 小时前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash7 小时前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI17 小时前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行1 天前
Linux和window共享文件夹
linux
Sinclair2 天前
简单几步,安卓手机秒变服务器,安装 CMS 程序
android·服务器
木心月转码ing2 天前
WSL+Cpp开发环境配置
linux
Rockbean3 天前
用40行代码搭建自己的无服务器OCR
服务器·python·deepseek
蝎子莱莱爱打怪3 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes
茶杯梦轩3 天前
CompletableFuture 在 项目实战 中 创建异步任务 的核心优势及使用场景
服务器·后端·面试
崔小汤呀3 天前
最全的docker安装笔记,包含CentOS和Ubuntu
linux·后端