pegasystems/detemplatize本镜像为发布detemplatize类型镜像的必要工具,旨在标准化和自动化detemplatize镜像的发布流程。通过提供模板解析、配置注入及发布前预处理能力,简化从模板文件到可发布镜像的转换过程,适用于需要动态处理模板内容以生成目标镜像的场景。
bashdocker run --rm \ -v /path/to/local/templates:/templates \ -v /path/to/output:/output \ -e TEMPLATE_ENGINE=go \ -e TARGET_REGISTRY=my-registry.example.com \ detemplatize-publish-tool:latest
| 环境变量名 | 描述 | 可选值 | 默认值 |
|---|---|---|---|
TEMPLATE_ENGINE | 指定模板引擎类型 | go, jinja2, none | go |
TEMPLATE_PATH | 模板文件在容器内的路径 | 绝对路径 | /templates |
OUTPUT_DIR | 处理后文件的输出目录 | 绝对路径 | /output |
TARGET_REGISTRY | 目标镜像仓库地址 | 有效的Registry URL | docker.io |
DEBUG | 是否开启调试模式 | true, false | false |
可通过命令行参数覆盖默认配置,格式为 --<参数名> <值>,例如:
bashdocker run --rm detemplatize-publish-tool:latest --template-engine jinja2 --output-dir /custom-output
支持的命令行参数与环境变量对应,参数名与环境变量名小写并以 - 连接(如 template-engine 对应 TEMPLATE_ENGINE)。
支持通过挂载配置文件(默认路径 /config/config.yaml)进行批量配置,示例配置文件:
yamltemplate: engine: jinja2 path: /templates/app output: dir: /output/app registry: url: my-registry.example.com username: ${REGISTRY_USER} # 支持引用环境变量 password: ${REGISTRY_PWD}
使用配置文件的启动命令:
bashdocker run --rm \ -v /local/templates:/templates \ -v /local/output:/output \ -v /local/config.yaml:/config/config.yaml \ -e REGISTRY_USER=myuser \ -e REGISTRY_PWD=mypwd \ detemplatize-publish-tool:latest
TEMPLATE_PATH 目录,或通过 --template-path 参数指定正确路径DEBUG=true),工具会输出详细处理日志至标准输出,便于问题排查manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务