【云原生】Kubernetes CEL 速查表

news2025/4/3 3:48:55

以下是一份 Kubernetes CEL 速查表(Cheat Sheet),涵盖了常见的语法、宏、标准函数和一些在 Kubernetes 中常见的使用示例。可在编写或调试 CEL 表达式时用作快速参考。


1. 基础概念

概念说明
语言特点无副作用、逐渐类型化(Gradual Typing)、无循环、短小单行表达式
常见用法- CRD 校验(selfoldSelf 变量)
- Admission 策略(objectrequest 变量)
关键变量- self:当前资源对象
- oldSelf:更新前的资源对象
- object:Admission 请求中的对象
- request:Admission 请求信息等
错误处理无法捕捉错误;遇到运算错误直接结束(部分逻辑运算可“吸收”错误见 ||、&&)
常见库- K8s 列表库
- K8s 正则库
- K8s URL 库
- K8s 鉴权库
- K8s 数量库

2. 语法与操作符

2.1 操作符优先级(从高到低)

  1. . / [] / () 成员访问、索引、函数调用
  2. 一元运算-(取负)、!(逻辑非)
  3. */%
  4. +-
  5. 比较<><=>===!=in
  6. 逻辑与&&
  7. 逻辑或\|\|
  8. 三元运算?:

2.2 标识符转义

当字段名含 -./、保留关键字等,需要使用以下转义:

转义序列实际含义示例
__underscores____redact__dredact__underscores__d
__dot__.
__dash__-x__dash__prop 表示字段 x-prop
__slash__/
__{keyword}__关键字转义__namespace__ 表示字段 namespace

3. 常用宏(Macros)

语法描述
has(e.f)has(e.f)判断 fe 中是否被“设置”。e 可为 map 或 proto message。
all(x, predicate)list.all(x, p)
map.all(x, p)
列表/Map 所有元素/键都满足 p 时返回 true;否则 false
exists(x, predicate)list.exists(x, p)
map.exists(x, p)
列表/Map 中是否存在任意一个元素满足 p
exists_one(x, predicate)list.exists_one(x, p)
map.exists_one(x, p)
是否恰好只有一个元素满足 p
filter(x, predicate)list.filter(x, p)
map.filter(x, p)
返回过滤后的子集(列表)。map 时返回满足 p 的键的列表。
map(x, transform)list.map(x, expr)
map.map(x, expr)
遍历列表/Map,对元素/键执行 expr,返回列表。
map(x, filter_expr, transform)同上,多一个先过滤再变换的逻辑。

常见示例

[1, 2, 3].all(x, x > 0)          // true
[1, 2, 3].exists(x, x == 2)      // true
[1, 2, 3].filter(x, x > 1)       // [2, 3]
[1, 2, 3].map(x, x * 2)          // [2, 4, 6]
has(object.metadata.name)        // 是否设置了 name 字段

4. 逻辑与条件

运算符含义示例
&&逻辑与(可“吸收”错误)
只有当无法确定结果时才会抛出错误
true && error => error
false && error => false
||逻辑或(可“吸收”错误)
只有当无法确定结果时才会抛出错误
false || error => error
true || error => true
? :条件(三元运算符)(cond) ? exprTrue : exprFalse
true ? error : 1 => error

5. 常用运算符与函数

5.1 等值与比较

运算签名备注
==, !=同类型或数值跨类型(int,uint,double)比较对 PB message 则比较字段逐一相等,NaN == NaN => false
<,>,<=,>=同类型(或跨数值)、string/bytes/Timestamp/Duration字符串/bytes 按字典序;bool 有序:false < true

5.2 算术

运算签名说明
+int + int、double + double、string + string、list + list、timestamp + duration …数字相加 / 字符串拼接 / 列表拼接 / 时间加法
-int - int、timestamp - timestamp、duration - duration …数字相减 / 时间差
*/%数值运算(整型或浮点,不混用)无自动提升,需显式转换

5.3 列表与 Map

表达式示例说明
list[index][1,2,3][1] -> 2越界时报错
map[key]{"a":1}["a"] -> 1不存在 key 时报错
x in list / x in map2 in [1,2,3] -> true
"a" in {"a":10} -> true
是否存在(对 map 判断的是 key)
list.size()[1,2,3].size() -> 3获取元素数量
map.size(){"a":1,"b":2}.size() -> 2获取键数量

5.4 字符串、Bytes、正则

函数签名示例
size()string.size()
bytes.size()
"abc".size() => 3
b"abc".size() => 3
contains(sub)string.contains(string)"hello".contains("ll") => true
startsWith(pre)string.startsWith(string)"hello".startsWith("he") => true
endsWith(suf)string.endsWith(string)"hello".endsWith("lo") => true
matches(regex)string.matches(string)"abc".matches("^a.*") => true
find(regex)
findAll(regex) (K8s 扩展)
string.find(string)
string.findAll(string)
"abc 123".find("[0-9]+") => "123"
"1,2".findAll("[0-9]+") => ["1","2"]

5.5 时间与 Duration

用法示例说明
解析timestamp("2023-01-01T00:00:00Z")
duration("1h")
将字符串解析为 TimestampDuration 对象
运算timestamp("2023-01-01T00:00:00Z") + duration("1h")
timestamp("2023-01-02T00:00:00Z") - timestamp("2023-01-01T00:00:00Z")
时间加减;支持比较运算 <,>
提取ts.getDate(), ts.getMonth(), ts.getFullYear(), ts.getDayOfWeek(), ts.getHours(), ts.getMinutes()可带时区字符串,默认 UTC

5.6 类型转换

函数示例说明
int(x)uint(x)int(3.14) -> 3
uint("123") -> 123u
超出范围会报错
double(x)double("2.5") => 2.5
string(x)string(3) => "3"
string(duration("1s")) => "1s"
对 bytes 尝试按 UTF-8 解码,失败报错
timestamp(x)timestamp("2023-08-26T12:00:00Z")按 RFC3339 解析
duration(x)duration("1h30m")解析为 Duration
quantity(x) (K8s)quantity("1Gi").add(quantity("500Mi"))在 v1.29+ 中可用,用于 ResourceQuantity

6. Kubernetes 额外扩展

6.1 列表库(min、max、sum、isSorted 等)

list.min()     
list.max()     
list.sum()     
list.isSorted() 
list.indexOf(x)
list.lastIndexOf(x)

6.2 正则库(find, findAll

"abc 123".find("[0-9]+")  // "123"
"1,2,3".findAll("[0-9]+") // ["1","2","3"]

6.3 URL 库(isURL, url(...)

isURL("https://example.com")          
url("https://example.com").getHost()  

6.4 数量库(quantity(...)

isQuantity("50Mi")               
quantity("50Mi").isInteger()     
quantity("50Mi").add(10).asInteger() 

6.5 鉴权库(authorizer 变量)

authorizer.group('').resource('pods').namespace('default').check('create').allowed()
authorizer.serviceAccount('default','mysa').resource('deployments').check('delete').allowed()

7. 常见示例

  1. CRD 校验副本数关系

    self.minReplicas <= self.replicas && self.replicas <= self.maxReplicas
    
  2. 检查字段是否存在

    has(self.expired) && self.created + self.ttl < self.expired
    
  3. 两个列表不同时为空

    (self.list1.size() == 0) != (self.list2.size() == 0)
    
  4. Map 必须包含键 'Available'

    'Available' in self.stateCounts
    
  5. 检查某 listMap 项的值

    self.envars.filter(e, e.name == 'MY_ENV').all(e, e.value.matches('^[a-zA-Z]*$'))
    
  6. ListSet 不相交

    self.set1.all(e, !(e in self.set2))
    
  7. 对 URL 字段解析

    isURL(self.url) && url(self.url).getHost() == "example.com"
    

8. 注意事项与小贴士

  1. 防止溢出:int/uint/double 运算可能产生溢出报错,duration/timestamp 超过范围也会报错。
  2. 逻辑运算符短路吸收错误true \|\| error => truefalse && error => false。但要注意顺序不固定。
  3. 正则与字符串:正则复杂度约为 O(len(regex) * len(input)),写表达式时需留意性能。
  4. K8s Schema 集成:CRD 中的 x-kubernetes-* 属性会影响 list、map、int-or-string 等在 CEL 中的行为,如 set/map 列表的比较、键名是否互斥等。
  5. 表达式长度与预算:Kubernetes 会对表达式做静态与运行时的资源开销评估,过大或过于复杂的表达式可能被拒绝写入或执行。

参考链接

  • Kubernetes 官方文档 - Using CEL
  • CEL Spec (GitHub)
  • CEL Go 实现示例

速查表只是简要概览,完整细节请参考 Kubernetes/CEL 官方文档。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2326936.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于聚类与引力斥力优化的选址算法

在众多实际场景中&#xff0c;诸如消防设施选址、基站布局规划以及充电桩站点部署等&#xff0c;都面临着如何利用最少的资源&#xff0c;实现对所有目标对象全面覆盖的难题。为有效解决这类问题&#xff0c;本文提出一种全新的组合算法模型 —— 基于聚类与引力斥力优化的选址…

Mac 电脑移动硬盘无法识别的解决方法

在使用 Mac 电脑的过程中&#xff0c;不少用户都遇到过移动硬盘没有正常推出&#xff0c;导致无法识别的问题。这不仅影响了数据的传输&#xff0c;还可能让人担心硬盘内数据的安全。今天&#xff0c;我们就来详细探讨一下针对这一问题的解决方法。 当发现移动硬盘无法识别时&…

LeetCode Hot100 刷题笔记(4)—— 二叉树、图论

目录 一、二叉树 1. 二叉树的深度遍历&#xff08;DFS&#xff1a;前序、中序、后序遍历&#xff09; 2. 二叉树的最大深度 3. 翻转二叉树 4. 对称二叉树 5. 二叉树的直径 6. 二叉树的层序遍历 7. 将有序数组转换为二叉搜索树 8. 验证二叉搜索树 9. 二叉搜索树中第 K 小的元素 …

【计算机视觉】YOLO语义分割

一、语义分割简介 1. 定义 语义分割&#xff08;Semantic Segmentation&#xff09;是计算机视觉中的一项任务&#xff0c;其目标是对图像中的每一个像素赋予一个类别标签。与目标检测只给出目标的边界框不同&#xff0c;语义分割能够在像素级别上区分不同类别&#xff0c;从…

【SpringBoot + MyBatis + MySQL + Thymeleaf 的使用】

目录&#xff1a; 一&#xff1a;创建项目二&#xff1a;修改目录三&#xff1a;添加配置四&#xff1a;创建数据表五&#xff1a;创建实体类六&#xff1a;创建数据接口七&#xff1a;编写xml文件八&#xff1a;单元测试九&#xff1a;编写服务层十&#xff1a;编写控制层十一…

在ensp进行OSPF+RIP+静态网络架构配置

一、实验目的 1.Ospf与RIP的双向引入路由消息 2.Ospf引入静态路由信息 二、实验要求 需求&#xff1a; 路由器可以互相ping通 实验设备&#xff1a; 路由器router7台 使用ensp搭建实验坏境&#xff0c;结构如图所示 三、实验内容 1.配置R1、R2、R3路由器使用Ospf动态路由…

Redis安全与配置问题——AOF文件损坏问题及解决方案

Java 中的 Redis AOF 文件损坏问题全面解析 一、AOF 文件损坏的本质与危害 1.1 AOF 持久化原理 Redis 的 AOF&#xff08;Append-Only File&#xff09; 通过记录所有写操作命令实现持久化。文件格式如下&#xff1a; *2\r\n$6\r\nSELECT\r\n$1\r\n0\r\n *3\r\n$3\r\nSET\r\…

3.第二阶段x64游戏实战-分析人物移动实现人物加速

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 本次游戏没法给 内容参考于&#xff1a;微尘网络安全 上一个内容&#xff1a;2.第二阶段x64游戏实战-x64dbg的使用 想找人物的速度&#xff0c;就需要使用Ch…

Scala(三)

本节课学习了函数式编程&#xff0c;了解到它与Java、C函数式编程的区别&#xff1b;学习了函数的基础&#xff0c;了解到它的基本语法、函数和方法的定义、函数高级。。。学习到函数至简原则&#xff0c;高阶函数&#xff0c;匿名函数等。 函数的定义 函数基本语法 例子&…

什么是 Java 泛型

一、什么是 Java 泛型&#xff1f; 泛型&#xff08;Generics&#xff09; 是 Java 中一种强大的编程机制&#xff0c;允许在定义类、接口和方法时使用类型参数。通过泛型&#xff0c;可以将数据类型作为参数传递&#xff0c;从而实现代码的通用性和类型安全。 简单来说&…

Unity中根据文字数量自适应长宽的对话气泡框UI 会自动换行

使用Ugui制作一个可以根据文本数量自动调整宽度,并可以自动换行的文字UI 或者不要独立的Bg,那么一定要把bg的img设置成切片

【小也的Java之旅系列】02 分布式集群详解

文章目录 前言为什么叫小也 本系列适合什么样的人阅读正文单体优点缺点 CAP为什么CAP不可能全部满足&#xff1f;CAP 三选二 分布式事务分布式方案——SeataXA模式&#xff08;强一致&#xff09;AT模式&#xff08;自动补偿&#xff0c;默认模式&#xff09;TCC模式&#xff0…

Ubuntu里安装Jenkins

【方式1】&#xff1a;下载war包&#xff0c;直接运行&#xff0c;需提前搭建Java环境&#xff0c;要求11或17&#xff0c;不推荐&#xff0c;war包下载地址&#xff0c;将war包上传到服务器&#xff0c;直接使用命令启动 java -jar /data/jenkins/jenkins.war【方式2】&#…

C++包管理工具vcpkg的安装使用教程

前言 使用vcpkg可以更方便地安装各种库&#xff0c;省去配置的时间和配置失败的风险&#xff0c;类似python中的anaconda&#xff0c;懒人必备 参考 安装参考&#xff1a;https://bqcode.blog.csdn.net/article/details/135831901?fromshareblogdetail&sharetypeblogde…

微服务面试题:配置中心

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;https://literature.sinhy.com/#/?__c1000&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;精通Java编…

Qt msvc2017程序无法用enigma vitrual box打包,用winrar打包

我们通常打包Qt程序用Enigma virtual box。这样我们的程序就可以在别的电脑上也能运行&#xff0c;但是有时候&#xff0c;我们发现Enigma virtual box在打包的时候&#xff0c;对于msvc2017需要编译的程序中引用webengineview模块&#xff0c;打包时候发现不能运行。 我们如何…

微服务集成测试 -华为OD机试真题(A卷、JavaScript)

题目描述 现在有n个容器服务&#xff0c;服务的启动可能有一定的依赖性&#xff08;有些服务启动没有依赖&#xff09;&#xff0c;其次&#xff0c;服务自身启动加载会消耗一些时间。 给你一个n n 的二维矩阵useTime&#xff0c;其中useTime[i][i]10表示服务i自身启动加载需…

Mac: 运行python读取CSV出现 permissionError

在MAC机器里&#xff0c;之前一直运行程序在某个指定的目录下读取excel和csv文件&#xff0c;没有出现错误&#xff0c;有一天突然出现错误&#xff1a;permissionError:[Errno 1] Operation not permitted&#xff0c; 具体错误信息如下&#xff1a; 经过调查得知&#xff0c…

UE5 学习笔记 FPS游戏制作30 显示击杀信息 水平框 UI模板(预制体)

文章目录 一制作单条死亡信息框水平框的使用创建一个水平框添加子元素调整子元素顺序子元素的布局插槽尺寸填充对齐 制作UI 根据队伍&#xff0c;设置文本的名字和颜色声明变量 将变量设置为构造参数根据队伍&#xff0c;设置文本的名字和颜色在构造事件中&#xff0c;获取玩家…

西门子TCP通讯过程中硬件连接突然断开

通信原理探秘又结合在工作中遇到的问题,关注到了通讯中的KeepAlive定时器的设置,所以做了如下实验。 硬件: 1513PLC TCP客户端 PC TCP服务器 前提条件:禁用PLC侧KeepAlive 程序: 测试流程: 打开PC端网络调试助手,设置为TCP服务器,打开链接; PC端打开WireShack软…