
github/super-linterGitHub Super-Linter 是一个基于 Docker 的多语言代码检查工具,集成了超过 20 种主流代码检查器(linter)和格式化工具。其核心用途是通过统一的接口对多语言项目进行自动化代码质量检查,确保代码符合团队或项目的编码规范,减少语法错误、风格不一致等问题。
.eslintrc、.pylintrc)。.gitignore 及 linter 原生忽略机制)。bashdocker 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),需确保配置文件挂载到容器内代码目录:
bashdocker 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 文件,定义服务及配置:
yamlversion: '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
启动服务:
bashdocker-compose run super-linter
在项目 .github/workflows/ 目录下创建 super-linter.yml 工作流文件:
yamlname: 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 检查:
bash-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)。

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