
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
本镜像包含ShiftLeft CLI(简称sl),用于代码安全工具。ShiftLeft CLI提供SAST(静态应用安全测试)、秘密检测、安全洞察、SCA(软件成分分析)和安全培训等功能接口。
更多关于ShiftLeft CLI的信息,请参阅其官方文档。
本镜像每周自动更新,由ReDemoNBR和rdnxk维护**(非ShiftLeft官方维护)**。与官方镜像(如https://hub.docker.com/r/shiftleft/scan%EF%BC%89%E7%9B%B8%E6%AF%94%EF%BC%8C%E6%9C%AC%E9%95%9C%E5%83%8F%E5%85%B7%E6%9C%89%E4%BB%A5%E4%B8%8B%E4%BC%98%E5%8A%BF%EF%BC%9A%E5%AE%98%E6%96%B9%E9%95%9C%E5%83%8F%E5%9F%BA%E4%BA%8E%60ubuntu:focal%60%E6%9E%84%E5%BB%BA%EF%BC%8C%E4%BD%93%E7%A7%AF%E8%BE%83%E5%A4%A7%EF%BC%88%E7%BA%A6800MB%EF%BC%89%EF%BC%8C%E8%80%8C%E6%9C%AC%E9%95%9C%E5%83%8F%E6%8F%90%E4%BE%9BDebian%EF%BC%88%E7%BA%A6200MB%EF%BC%89%E5%92%8CAlpine%EF%BC%88%E7%BA%A683MB%EF%BC%89%E4%B8%A4%E7%A7%8D%E8%BD%BB%E9%87%8F%E7%BA%A7%E5%8F%98%E4%BD%93%EF%BC%9B%E6%AD%A4%E5%A4%96%EF%BC%8C%E5%AE%98%E6%96%B9%E9%95%9C%E5%83%8F%E5%9C%A8Docker Hub上缺乏文档,且其教程中下载的包装脚本未验证校验和,可能存在注入风险。
本镜像专为CI/CD管道设计。
标签格式为<version>-<variant>或<version>(后者默认使用https://hub.docker.com/_/debian%E4%BD%9C%E4%B8%BA%E5%9F%BA%E7%A1%80%E9%95%9C%E5%83%8F%EF%BC%89%E3%80%82
所有镜像均包含可直接使用的sl可执行文件,并别名化为shiftleft-cli,以避免与https://github.com/mtoyoda/sl%E6%B7%B7%E6%B7%86%E3%80%82
redemonbr/shiftleft-cli:<version> | redemonbr/shiftleft-cli:<version>-bullseye
默认镜像,基于Debian最新稳定版"bullseye"构建,可从https://hub.docker.com/_/debian%E8%8E%B7%E5%8F%96%E3%80%82
redemonbr/shiftleft-cli:<version>-alpine
基于Alpine Linux最新稳定版构建,可从https://hub.docker.com/_/alpine%E8%8E%B7%E5%8F%96%E3%80%82
此变体适用于对最终镜像体积有严格要求的场景。需注意的是,Alpine使用musl libc而非glibc,部分软件可能因libc依赖差异出现兼容性问题。
关于ShiftLeft CLI的具体选项和参数,请参阅其官方CLI文档。本文档仅介绍Docker镜像的使用方式。
基础--help使用
bash$ docker run redemonbr/shiftleft-cli:latest sl --help
挂载应用卷并分析
bash$ docker run \ --rm \ --name shiftleft \ --volume /path/to/my/application/:/mnt/my-app/ \ --env SHIFTLEFT_APP=my-app \ --env SHIFTLEFT_CPG=true \ --env SHIFTLEFT_NO_DIAGNOSTIC=true \ --env SHIFTLEFT_ACCESS_TOKEN=<access_token> \ --env SHIFTLEFT_LANG_JAVA=true \ --env SHIFTLEFT_JAVA_OPTS=-Xmx10g \ redemonbr/shiftleft-cli:bullseye \ /bin/bash root@942b0046a022:/# sl auth root@942b0046a022:/# sl analyze my-app.jar --dep dependency-1.jar --dep dependency-2.jar
挂载应用卷并执行多命令
shell$ docker run \ -it \ --rm \ --name shiftleft \ --volume /path/to/my/application/:mnt/my-app/ \ --env SHIFTLEFT_APP=my-app \ --env SHIFTLEFT_CPG=true \ --env SHIFTLEFT_NO_DIAGNOSTIC=true \ --env SHIFTLEFT_ACCESS_TOKEN=<access_token> \ --env SHIFTLEFT_LANG_JAVA=true \ --env SHIFTLEFT_JAVA_OPTS=-Xmx10g \ redemonbr/shiftleft-cli:alpine \ /bin/sh / # shiftleft-cli auth / # shiftleft-cli analyze my-app.jar --dep dependency-1.jar --dep dependency-2.jar --tag branch=my-tag / # shiftleft-cli check-analysis --branch "my-tag" --report --report-file "./shiftleft.md"
NodeJS项目在GitLab-CI中的使用示例:
ymlaudit:sast-scan: stage: test image: redemonbr/shiftleft-cli:alpine variables: SHIFTLEFT_APP: my-great-app SHIFTLEFT_CPG: true SHIFTLEFT_LANG_JS: true SHIFTLEFT_NO_DIAGNOSTIC: true SHIFTLEFT_WAIT: true ## 替换为您的配置,建议存储在CI/CD密钥中 SHIFTLEFT_ACCESS_TOKEN: <token_here> SHIFTLEFT_ORG: <org_id_here> before_script: - npm install - shiftleft-cli auth --org "$SHIFTLEFT_ORG" script: - shiftleft-cli analyze --tag "branch=$CI_COMMIT_REF_NAME" ./ -- --no-babel --exclude "node_modules/,test/,.git/,.cache/" # 创建报告目录 - mkdir .reports/ - shiftleft-cli check-analysis --branch "$CI_COMMIT_REF_NAME" --report --report-file "./.reports/shiftleft.md" after_script: # 复制报告到指定目录 - cp .reports/shiftleft.md ./shiftleft.md artifacts: name: shiftleft-$CI_COMMIT_SHORT_SHA paths: - shiftleft.md expire_in: 7 days public: false
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务