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

GitHub Super-Linter 是一个基于 Docker 的多语言代码检查工具,集成了超过 20 种主流代码检查器(linter)和格式化工具。其核心用途是通过统一的接口对多语言项目进行自动化代码质量检查,确保代码符合团队或项目的编码规范,减少语法错误、风格不一致等问题。
.eslintrc、.pylintrc)。.gitignore 及 linter 原生忽略机制)。docker run --rm \ -v /path/to/local/code:/app \ # 挂载本地代码目录到容器内 /app -e VALIDATE_ALL_CODEBASE=true \ # 检查整个代码库(默认仅检查变更文件) -e DEFAULT_BRANCH=main \ # 基准分支(用于增量检查) -e LOG_LEVEL=info \ # 日志级别(debug/info/warn/error) -e VALIDATE_JAVASCRIPT=true \ # 启用 JavaScript 检查 -e VALIDATE_PYTHON=true \ # 启用 Python 检查 ghcr.io/github/super-linter:latest
若项目使用本地 linter 配置文件(如 .eslintrc.js),需确保配置文件挂载到容器内代码目录:
docker run --rm \ -v /path/to/local/code:/app \ # 代码目录(含配置文件) -e VALIDATE_JAVASCRIPT=true \ -e LINTER_RULES_PATH=/app/.github/linters \ # 自定义规则文件路径(可选) ghcr.io/github/super-linter:latest
创建 docker-compose.yml 文件,定义服务及配置:
version: '3' services: super-linter: image: ghcr.io/github/super-linter:latest volumes: - /path/to/local/code:/app # 挂载本地代码目录 - /path/to/custom-rules:/app/.github/linters # (可选)挂载自定义规则目录 environment: - VALIDATE_ALL_CODEBASE=true # 检查整个代码库 - DEFAULT_BRANCH=main # 基准分支 - LOG_LEVEL=info # 日志级别 # 启用特定语言检查 - VALIDATE_JAVASCRIPT=true - VALIDATE_PYTHON=true - VALIDATE_YAML=true # 忽略文件(可选,格式为逗号分隔的路径) - IGNORE_FILES=.github/**/*.md,docs/**/*.md
启动服务:
docker-compose run super-linter
在项目 .github/workflows/ 目录下创建 super-linter.yml 工作流文件:
name: Code Quality Check on: push: branches: [main] pull_request: branches: [main] jobs: super-linter: runs-on: ubuntu-latest steps: - name: Checkout code uses: actions/checkout@v4 with: fetch-depth: 0 # 需获取完整历史以支持增量检查 - name: Run Super-Linter uses: github/super-linter@v5 # 使用官方 GitHub Action(基于 Docker 镜像) env: VALIDATE_ALL_CODEBASE: ${{ github.event_name == 'push' }} # push 时全量检查,PR 时增量检查 DEFAULT_BRANCH: main GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # 用于获取 PR 变更信息 # 启用语言检查 VALIDATE_JAVASCRIPT: true VALIDATE_PYTHON: true VALIDATE_YAML: true # 日志级别 LOG_LEVEL: info
| 变量名 | 说明 | 默认值 |
|---|---|---|
VALIDATE_ALL_CODEBASE | 是否检查整个代码库(true)或仅变更文件(false) | false |
DEFAULT_BRANCH | 基准分支(用于对比变更文件,如 main 或 master) | main |
LOG_LEVEL | 日志级别:debug(详细)、info(默认)、warn、error | info |
GITHUB_TOKEN | GitHub 令牌(用于获取 PR 信息,仅在 GitHub Actions 中需配置) | - |
IGNORE_FILES | 忽略的文件/目录(逗号分隔,支持通配符,如 docs/**/*.md) | - |
REPORT_OUTPUT_FOLDER | 检查报告输出目录(容器内路径,需挂载到本地以持久化) | /tmp/lint |
通过 VALIDATE_<LANGUAGE> 环境变量启用特定语言检查,常用选项:
| 变量名 | 对应语言/格式 |
|---|---|
VALIDATE_JAVASCRIPT | JavaScript/TypeScript |
VALIDATE_PYTHON | Python |
VALIDATE_JAVA | Java |
VALIDATE_GO | Go |
VALIDATE_RUBY | Ruby |
VALIDATE_PHP | PHP |
VALIDATE_HTML | HTML |
VALIDATE_CSS | CSS/SCSS |
VALIDATE_DOCKERFILE | Dockerfile |
VALIDATE_MARKDOWN | Markdown |
VALIDATE_YAML | YAML |
VALIDATE_JSON | JSON |
示例:启用 JavaScript 和 Python 检查:
-e VALIDATE_JAVASCRIPT=true -e VALIDATE_PYTHON=true
挂载项目本地 linter 配置文件(如 .eslintrc.js、.pylintrc)到代码目录(/app),Super-Linter 会优先使用本地配置。
VALIDATE_ALL_CODEBASE=false,默认),仅检查变更文件。IGNORE_FILES 环境变量指定(如 IGNORE_FILES=vendor/**/*)。.eslintignore、.pylintignore)。免费版仅支持 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