Git repository and CI/CD integrations: comparisons

The most popular integrations for Snyk implementation are Git Repository and CI/CD pipeline.
Snyk Integrations
  • Git repository: Improve application security in your Git repository, preventing vulnerable code from entering your codebase, and getting quick visibility of your vulnerabilities.
  • CI/CD: Keep your applications secure by preventing deployment of vulnerable applications or components (registries), adding Snyk in the build as a step of the pipeline.

Which integrations to choose?

You can decide to implement either Git repository, or CI/CD, or both. Both have advantages and disadvantages, and your choice will depend on your team flows and organizational processes.
The following considerations explain the benefits of each type of integration.

Git repository

Use Git repository integrations to Improve security of your code and deployed applications.


  • Easier to setup and maintain.
  • Allows scanning and visibility earlier in the software development lifecycle, through:
    • Automatic daily rescanning of all imported Projects.
    • Checking all submitted PRs for security issues.
    • Generating dependency upgrade PRs to deal with technical debt.
    • Generating fix PRs for existing vulnerabilities that have not been addressed
  • More friendly experience for developers.
  • Does not take resources from your CI/CD pipeline.


Use CI/CD integrations to keep your code and deployed applications secure, and give visibility on components that are pushed to production, by either breaking builds and reporting to Snyk, or only reporting to Snyk.


  • Some package managers require local context and are better run within your environment (including Scala, Gradle, Go modules, Artifactory, and Nexus).
  • More granular options to block.
  • Strong gatekeeper.
  • Best practice for container and Infrastructure as Code scans (for IaC, get more accurate results by scanning a Terraform plan file, rather than the untemplated IaC declarations).
© 2022 Snyk Limited