本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com

Reflector是一个Kubernetes插件,旨在监控secrets和configmaps资源的变化,并将这些变化反映到同一或其他命名空间的镜像资源中。支持amd64、arm和arm64架构。
如果需要帮助或发现bug,请在GitHub上提交Issue([***]
Reflector可通过手动方式或使用Helm(推荐)进行部署。
使用Helm安装最新发布的chart:
$ 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):
$ 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示例:
apiVersion: 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示例:
apiVersion: 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示例:
apiVersion: v1 kind: Secret metadata: name: mirror-secret annotations: reflector.v1.k8s.emberstack.com/reflects: "default/source-secret" data: ...
镜像configmap示例:
apiVersion: 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添加注解实现镜像(参见[***]
apiVersion: 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: "" ...
免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录方式配置轩辕镜像加速服务,包含7个详细步骤
在 Linux 系统上配置轩辕镜像源,支持主流发行版
在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统
在 Docker Compose 中使用轩辕镜像加速,支持容器编排
在 k8s 中配置 containerd 使用轩辕镜像加速
在宝塔面板中配置轩辕镜像加速,提升服务器管理效率
在 Synology 群晖NAS系统中配置轩辕镜像加速
在飞牛fnOS系统中配置轩辕镜像加速
在极空间NAS中配置轩辕镜像加速
在爱快ikuai系统中配置轩辕镜像加速
在绿联NAS系统中配置轩辕镜像加速
在威联通NAS系统中配置轩辕镜像加速
在 Podman 中配置轩辕镜像加速,支持多系统
配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤
无需登录即可使用轩辕镜像加速服务,更加便捷高效
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429