xChar
·9 months ago

用途

整理k8s资源分布情况,查看各个命名空间下分配的资源额度

#!/bin/bash

# 获取所有命名空间的列表
namespaces=$(kubectl get namespaces -o jsonpath='{.items[*].metadata.name}')

# 遍历每个命名空间
for namespace in $namespaces
do
    echo "Namespace: $namespace"

    # 获取命名空间中的所有 Pod
    pods=$(kubectl get pods --namespace=$namespace -o jsonpath='{.items[*].metadata.name}')

    total_cpu_limit=0
    total_memory_limit=0

    # 遍历每个 Pod,并累加其 CPU 和内存限制
    for pod in $pods
    do
        cpu_limit=$(kubectl get pod $pod --namespace=$namespace -o jsonpath='{.spec.containers[*].resources.limits.cpu}')
        memory_limit=$(kubectl get pod $pod --namespace=$namespace -o jsonpath='{.spec.containers[*].resources.limits.memory}')

        # 处理 CPU 限制
        if [[ $cpu_limit =~ ^[0-9]+m$ ]]; then
            cpu_limit=${cpu_limit%m}
        elif [[ $cpu_limit =~ ^[0-9]+$ ]]; then
            cpu_limit=$((cpu_limit * 1000))  # 转换为 millicores
        else
            cpu_limit=0
        fi

        # 处理内存限制
        if [[ $memory_limit =~ ^[0-9]+Mi$ ]]; then
            memory_limit=${memory_limit%Mi}
        elif [[ $memory_limit =~ ^[0-9]+Gi$ ]]; then
            memory_limit=$((${memory_limit%Gi} * 1024))  # 转换为 MiB
        elif [[ $memory_limit =~ ^[0-9]+$ ]]; then
            memory_limit=$((memory_limit / 1024))  # 假设是 KiB,转换为 MiB
        else
            memory_limit=0
        fi

        # 累加 CPU 和内存限制
        total_cpu_limit=$((total_cpu_limit + cpu_limit))
        total_memory_limit=$((total_memory_limit + memory_limit))
    done

    echo "  Total CPU Limit: $total_cpu_limit mCPU"
    echo "  Total Memory Limit: $total_memory_limit MiB"
    echo
done

最终脚本会在根目录导出一个output.txt文件
实现效果类似于这样:

Namespace: kube-public
  Total CPU Limit: 0 mCPU
  Total Memory Limit: 0 MiB

Namespace: kube-system
  Total CPU Limit: 0 mCPU
  Total Memory Limit: 340 MiB

Namespace: local
  Total CPU Limit: 0 mCPU
  Total Memory Limit: 0 MiB

Namespace: monitoring
  Total CPU Limit: 0 mCPU
  Total Memory Limit: 0 MiB

Loading comments...