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
相关推荐
bjzhang751 小时前
CentOS下安装MySQL详解
linux·mysql·centos
Jason_chen3 小时前
Linux 6.2 音频机制深度解析:AI驱动的低延迟音频与零信任音频安全架构
linux
下午写HelloWorld3 小时前
Linux系统及Ubuntu常用指令
linux·ubuntu·操作系统
lizhihai_994 小时前
股市学习心得-AI 产业链核心标的梳理清单
大数据·服务器·人工智能·科技·学习
云计算磊哥@4 小时前
运维开发宝典026-MySQL02数据库表操作
运维·数据库·运维开发
weixin_523185324 小时前
Collections.unmodifiableMap详解:真的不可修改吗?
java·linux·前端
黄同学real4 小时前
解决 Visual Studio Web Deploy 远程发布报 401 未授权 (ERROR\_USER\_UNAUTHORIZED)
服务器
天天进步20155 小时前
Tunnelto 源码解析 #9:控制服务器设计:Warp、WebSocket、Ping/Pong 与连接保活
运维·服务器·websocket
凡人叶枫5 小时前
Effective C++ 条款04:确定对象被使用前已先被初始化
java·linux·开发语言·c++·嵌入式开发
云栖梦泽5 小时前
玩转RK3506SDK
linux·嵌入式硬件