前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >介绍一个小工具:Kubeval

介绍一个小工具:Kubeval

作者头像
崔秀龙
发布2019-07-22 11:36:34
1.7K0
发布2019-07-22 11:36:34
举报
文章被收录于专栏:伪架构师伪架构师

这次要介绍的是一个用于验证 Kubernetes 对象文档结构的小工具:kubeval。它能够对一个或多个 Kubernetes 或 OpenShift 的对象文档进行校验。它所依赖的 Schema 数据来自于 Open API 所生成的内容,所以校验过程中无需和 API Server 进行交互,也正因如此,对各种第三方 CRD 的支持也暂时无能为力,另外还需要有 Schema 库的支持。

这个工具在直接和 Kubernetes 交互的环境中有点画蛇添足,但是如果是在 CICD Pipeline 中,或者是没有 Kubernetes 集群可用的情况下,就很趁手了。

安装

Linux

直接下载安装版即可。

代码语言:javascript
复制
wget https://github.com/instrumenta/kubeval/releases/download/0.9.2/kubeval-linux-amd64.tar.gz
tar xf kubeval-linux-amd64.tar.gzsudo cp kubeval /usr/local/bin

MacOS

可以下载安装:

代码语言:javascript
复制
wget https://github.com/instrumenta/kubeval/releases/download/0.9.2/kubeval-darwin-amd64.tar.gz
tar xf kubeval-darwin-amd64.tar.gzsudo cp kubeval /usr/local/bin

也可以使用 Homebrew:

代码语言:javascript
复制
brew tap instrumenta/instrumenta
brew install kubeval

Windows

除了在 Release 页面下载 zip 包之外,还可以用 scoop 进行安装:

代码语言:javascript
复制
scoop bucket add instrumenta https://github.com/instrumenta/bucket-instrumenta
scoop install kubeval

Docker

还提供了 Docker 的运行方式,例如:

代码语言:javascript
复制
$ docker run -it -v `pwd`/fixtures:/fixtures garethr/kubeval fixtures/*
Missing a kind key in /fixtures/blank.yaml
The document fixtures/int_or_string.yaml contains a valid Service
The document fixtures/int_or_string_false.yaml contains an invalid Deployment
--> spec.template.spec.containers.0.env.0.value: Invalid type. Expected: string, given: integer
The document fixtures/invalid.yaml contains an invalid ReplicationController
--> spec.replicas: Invalid type. Expected: integer, given: string
Missing a kind key in /fixtures/missing-kind.yaml
The document fixtures/valid.json contains a valid Deployment
The document fixtures/valid.yaml contains a valid ReplicationController

使用

代码语言:javascript
复制
$ kubeval --help
Validate a Kubernetes YAML file against the relevant schemaUsage:
kubeval <file> [file...] [flags]Flags:
-f, --filename string             filename to be displayed when testing manifests read from stdin (default "stdin")
-h, --help                        help for kubeval
-v, --kubernetes-version string   Version of Kubernetes to validate against (default "master")
--openshift                   Use OpenShift schemas instead of upstream Kubernetes
--schema-location string      Base URL used to download schemas. Can also be specified with the environment variable KUBEVAL_SCHEMA_LOCATION (default "https://kubernetesjsonschema.dev")
--strict                      Disallow additional properties not in schema
--version                     version for kubeval

参数很少,但是都比较有用:

  • -v:指定 Kubernetes 版本,例如 1.14.2
  • --openshift:对 Openshift 对象进行校验。
  • --schema-location:指定 Schema 库的位置,缺省为 https://kubernetesjsonschema.dev,可以使用环境变量 KUBEVAL_SCHEMA_LOCATION
  • --strict:禁止出现 Schema 中未规定的字段。

例如:

代码语言:javascript
复制
$ kubeval sleep.yaml
The document sleep.yaml contains a valid ServiceAccount
The document sleep.yaml contains a valid Service
The document sleep.yaml contains a valid Deployment

或者也可以使用管道:

代码语言:javascript
复制
$ cat sleep.yaml|kubeval
The document stdin contains a valid ServiceAccount
The document stdin contains a valid Service
The document stdin contains a valid Deployment

指定版本进行校验:

代码语言:javascript
复制
$ kubeval -v 1.10.0 sleep.yaml
The document sleep.yaml contains a valid ServiceAccount
The document sleep.yaml contains a valid Service
The document sleep.yaml contains a valid Deployment

使用自己的 Schema 库

前面提到过一个参数:--schema-location,推测应该是用于在无法访问缺省模式库的时候的替补方案,要建立自己的模式库也很方便,只要使用 git 获取在线内容,并使用 Web Server 或者本地文件系统提供服务就可以了:

代码语言:javascript
复制
$ cd /doc
$ git clone https://github.com/instrumenta/kubernetes-json-schema
正克隆到 'kubernetes-json-schema'...
...
$ kubeval --schema-location file:///doc/kubernetes-json-schema  test.yaml
The document test.yaml contains a valid Service

问题

似乎目前对 1.8 之前的版本支持还不够好,慎用。

参考

  • 项目地址:https://github.com/instrumenta/kubeval
  • 文档结构库:https://github.com/instrumenta/kubernetes-json-schema
  • 使用说明:https://kubeval.instrumenta.dev/
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-06-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 伪架构师 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装
    • Linux
      • MacOS
        • Windows
          • Docker
          • 使用
          • 使用自己的 Schema 库
          • 问题
          • 参考
          相关产品与服务
          容器服务
          腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档