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
相关推荐
weixin_404679316 小时前
docker部署ollama
运维·docker·容器
岁岁种桃花儿6 小时前
Flink从入门到上天系列第一篇:搭建第一个Flink程序
大数据·linux·flink·数据同步
匀泪6 小时前
云原生(LVS DR模式ipvs实验)
服务器·网络·lvs
_OP_CHEN6 小时前
【Linux系统编程】(二十九)深度解密静态链接:从目标文件到可执行程序的底层魔法
linux·操作系统·链接·文件系统·c/c++·静态链接
草莓熊Lotso6 小时前
Qt 主窗口核心组件实战:菜单栏、工具栏、状态栏、浮动窗口全攻略
运维·开发语言·人工智能·python·qt·ui
RisunJan6 小时前
Linux命令-lprm(删除打印队列中任务)
linux·运维·服务器
Web极客码6 小时前
WordPress从经典编辑器升级到古腾堡编辑器
运维·编辑器·wordpress
云姜.6 小时前
TCP协议特性
服务器·网络·tcp/ip
zzzsde6 小时前
【Linux】进程(5):命令行参数和环境变量
linux·运维·服务器