
emberstack/kubernetes-reflectorReflector是一个Kubernetes插件,旨在监控secrets和configmaps资源的变化,并将这些变化反映到同一或其他命名空间的镜像资源中。支持amd64、arm和arm64架构。
如果需要帮助或发现bug,请在GitHub上提交Issue([***]
Reflector可通过手动方式或使用Helm(推荐)进行部署。
使用Helm安装最新发布的chart:
shellsession$ helm repo add emberstack [***] $ helm repo update $ helm upgrade --install reflector emberstack/reflector
可通过以下参数自定义Helm部署的值:
| 参数 | 描述 | 默认值 |
|---|---|---|
nameOverride | 覆盖发布名称 | "" |
fullnameOverride | 覆盖发布全名 | "" |
image.repository | 容器镜像仓库 | emberstack/kubernetes-reflector |
image.tag | 容器镜像标签 | 与chart版本相同 |
image.pullPolicy | 容器镜像拉取策略 | IfNotPresent |
configuration.logging.minimumLevel | 日志最低级别 | Information |
rbac.enabled | 创建并使用RBAC资源 | true |
serviceAccount.create | 创建ServiceAccount | true |
serviceAccount.name | ServiceAccount名称 | 发布名称 |
livenessProbe.initialDelaySeconds | livenessProbe初始延迟 | 5 |
livenessProbe.periodSeconds | livenessProbe周期 | 10 |
readinessProbe.initialDelaySeconds | readinessProbe初始延迟 | 5 |
readinessProbe.periodSeconds | readinessProbe周期 | 10 |
resources | 资源限制 | {} |
nodeSelector | 用于pod分配的节点标签 | {} |
tolerations | 用于pod分配的容忍标签 | [] |
affinity | 用于pod分配的节点亲和性 | {} |
在Artifact Hub上查看更多信息
每个发布版本(可在GitHub的Releases页面找到)包含手动部署文件(reflector.yaml):
shellsession$ kubectl -n kube-system apply -f [***]
secret或configmapreflector.v1.k8s.emberstack.com/reflection-allowed: "true",以允许向镜像资源反射。reflector.v1.k8s.emberstack.com/reflection-allowed-namespaces: "<列表>",以仅允许从逗号分隔的命名空间列表或正则表达式中进行反射。注意:若省略此注解或为空,则允许所有命名空间。Reflector可自动在其他命名空间中创建同名镜像资源,以下注解控制创建行为:
reflector.v1.k8s.emberstack.com/reflection-auto-enabled: "true"以自动创建镜像(需reflection-allowed为true)。reflector.v1.k8s.emberstack.com/reflection-auto-namespaces: "<列表>"以指定自动创建镜像的命名空间(若省略或为空,允许所有命名空间,且需通过reflection-allowed-namespaces检查)。重要提示:删除源资源时自动镜像会被删除;关闭反射/自动镜像功能或命名空间不再匹配时,自动镜像也会被删除。 重要提示:创建自动镜像时会跳过冲突资源,若目标命名空间已存在同名资源,将跳过并记录警告。
源secret示例:
yamlapiVersion: v1 kind: Secret metadata: name: source-secret annotations: reflector.v1.k8s.emberstack.com/reflection-allowed: "true" reflector.v1.k8s.emberstack.com/reflection-allowed-namespaces: "namespace-1,namespace-2,namespace-[0-9]*" data: ...
源configmap示例:
yamlapiVersion: v1 kind: ConfigMap metadata: name: source-config-map annotations: reflector.v1.k8s.emberstack.com/reflection-allowed: "true" reflector.v1.k8s.emberstack.com/reflection-allowed-namespaces: "namespace-1,namespace-2,namespace-[0-9]*" data: ...
secret或configmap向镜像对象添加reflector.v1.k8s.emberstack.com/reflects: "<源命名空间>/<源名称>"注解,值为源对象的命名空间/名称格式全名。
注意:手动修改镜像时(如通过
helm部署),添加reflector.v1.k8s.emberstack.com/reflected-version: ""可重置反射版本。
镜像secret示例:
yamlapiVersion: v1 kind: Secret metadata: name: mirror-secret annotations: reflector.v1.k8s.emberstack.com/reflects: "default/source-secret" data: ...
镜像configmap示例:
yamlapiVersion: v1 kind: ConfigMap metadata: name: mirror-config-map annotations: reflector.v1.k8s.emberstack.com/reflects: "default/source-config-map" data: ...
Reflector将监控源对象变化并复制以下字段:
data字段data和binaryData字段cert-manager支持自cert-manager 1.5版本起,可通过secretTemplate为证书创建的secrets添加注解实现镜像(参见[***]
yamlapiVersion: cert-manager.io/v1 kind: Certificate ... spec: secretTemplate: annotations: reflector.v1.k8s.emberstack.com/reflection-allowed: "true" reflector.v1.k8s.emberstack.com/reflection-allowed-namespaces: "" ...


manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务