Need advice about which tool to choose?Ask the StackShare community!

GitLab

60.5K
51.8K
+ 1
2.5K
GitLab CI

2.3K
1.6K
+ 1
75
Add tool

GitLab vs GitLab CI: What are the differences?

GitLab vs GitLab CI

GitLab is a web-based platform that provides a Git repository manager allowing developers to easily collaborate and manage their codebase. On the other hand, GitLab CI is a continuous integration and continuous deployment platform integrated within GitLab. Below are the key differences between GitLab and GitLab CI:

  1. Built-in Version Control vs Continuous Integration: GitLab provides traditional version control functionality, allowing developers to manage and track changes in their codebase. GitLab CI, on the other hand, focuses on automating and streamlining the software development process by providing continuous integration and continuous deployment capabilities.

  2. Collaboration and Repository Management vs Automated Testing and Deployment: GitLab primarily focuses on collaboration and repository management, providing features such as code reviews, issue tracking, and project management tools. GitLab CI, on the other hand, focuses on automating various stages of the software development lifecycle, such as building, testing, and deploying code.

  3. Code Hosting and Repository Features vs CI/CD Pipelines: GitLab provides a robust code hosting platform, offering features like branch management, merge requests, and access controls. GitLab CI, however, focuses on setting up and managing CI/CD pipelines, allowing developers to automate the testing and deployment of their codebases.

  4. Code Versioning and History Tracking vs Pipeline Configuration: GitLab allows developers to track and manage code versions, providing a detailed history of changes made to the repository. GitLab CI, on the other hand, focuses on configuring and managing the CI/CD pipelines, defining the build, test, and deployment steps for the codebase.

  5. Branching and Merging vs Testing and Job Execution: GitLab provides comprehensive branching and merging capabilities, allowing developers to work on different features or bug fixes simultaneously. GitLab CI, on the other hand, is designed for running tests and executing jobs within the defined CI/CD pipeline, ensuring code quality and facilitating automated deployments.

  6. Project Management and Issue Tracking vs Continuous Integration Monitoring: GitLab offers a range of project management and issue tracking features, enabling teams to plan, organize, and track progress on their projects. GitLab CI, however, focuses on monitoring the continuous integration process, providing real-time feedback on the status of the CI/CD pipelines, test results, and deployment statuses.

In summary, GitLab serves as a collaborative repository management platform, while GitLab CI focuses on automating the continuous integration and deployment processes within GitLab.

Advice on GitLab and GitLab CI
Needs advice
on
CircleCICircleCIGitLab CIGitLab CI
and
Jenkins XJenkins X

We are a mid-size startup running Scala apps. Moving from Jenkins/EC2 to Spinnaker/EKS and looking for a tool to cover our CI/CD needs. Our code lives on GitHub, artifacts in nexus, images in ECR.

Drone is out, GitHub actions are being considered along with Circle CI and GitLab CI.

We primarily need:

  • Fast SBT builds (caching)
  • Low maintenance overhead (ideally serverless)
  • Everything as code
  • Ease of use
See more
Replies (3)
Glenn Gillen
Recommends
on
BuildkiteBuildkite

I think I've tried most of the CI tools out there at some point. It took me a while to get around to Buildkite because at first I didn't see much point given it seemed like you had to run the agent yourself. Eventually it dawned on me why this approach was more ingenious than I realised:

Running my app in a production (or production-like) environment was already a solved problem, because everything was already in some form of "everything as code". Having a test environment where the only difference was adding the Buildkite agent was a trivial addition.

It means that dev/test/prod parity is simple to achieve and maintain. It's also proven to be much easier to support than trying to deal with the problems that come with trying to force an app to fit into the nuances and constraints that are imposed by the containers/runtime of a CI service. When you completely control all of the environment the tests are running in you define those constraints too. It's been a great balance between a managed service and the flexibility of running it yourself.

And while none of my needs have hit the scale of Shopify (I saw one of their engineers speak about it at a conference once, I can't find the video now though 😞) it's good to know I can scale out my worker nodes to hundreds of thousands of workers to reduce the time it takes for my tests to run.

See more
Recommends
on
jFrogjFrog

I would recommend you to consider the JFrog Platform that includes JFrog Pipelines - it will allow you to manage the full artifact life cycle for your sbt, docker and other technologies, and automate all of your CI and CD using cloud native declarative yaml pipelines. Will integrate smoothly with all your other toolset.

See more
Estu Fardani
Recommends
on
GitLab CIGitLab CI

more configurable to setup ci/cd: * It can provide caching when build sbt, just add this section to yml file * Easy to use, many documentation

Weakness: * Need use gitlab as repository to bring more powerful configuration

See more
Decisions about GitLab and GitLab CI
Weverton Timoteo

Do you review your Pull/Merge Request before assigning Reviewers?

If you work in a team opening a Pull Request (or Merge Request) looks appropriate. However, have you ever thought about opening a Pull/Merge Request when working by yourself? Here's a checklist of things you can review in your own:

  • Pick the correct target branch
  • Make Drafts explicit
  • Name things properly
  • Ask help for tools
  • Remove the noise
  • Fetch necessary data
  • Understand Mergeability
  • Pass the message
  • Add screenshots
  • Be found in the future
  • Comment inline in your changes

Read the blog post for more detailed explanation for each item :D

What else do you review before asking for code review?

See more
Weverton Timoteo

Using an inclusive language is crucial for fostering a diverse culture. Git has changed the naming conventions to be more language-inclusive, and so you should change. Our development tools, like GitHub and GitLab, already supports the change.

SourceLevel deals very nicely with repositories that changed the master branch to a more appropriate word. Besides, you can use the grep linter the look for exclusive terms contained in the source code.

As the inclusive language gap may happen in other aspects of our lives, have you already thought about them?

See more
Weverton Timoteo

One of the magic tricks git performs is the ability to rewrite log history. You can do it in many ways, but git rebase -i is the one I most use. With this command, It’s possible to switch commits order, remove a commit, squash two or more commits, or edit, for instance.

It’s particularly useful to run it before opening a pull request. It allows developers to “clean up” the mess and organize commits before submitting to review. If you follow the practice 3 and 4, then the list of commits should look very similar to a task list. It should reveal the rationale you had, telling the story of how you end up with that final code.

See more
Kamaleshwar BN
Senior Software Engineer at Pulley · | 8 upvotes · 656.7K views

Out of most of the VCS solutions out there, we found Gitlab was the most feature complete with a free community edition. Their DevSecops offering is also a very robust solution. Gitlab CI/CD was quite easy to setup and the direct integration with your VCS + CI/CD is also a bonus. Out of the box integration with major cloud providers, alerting through instant messages etc. are all extremely convenient. We push our CI/CD updates to MS Teams.

See more

Gitlab as A LOT of features that GitHub and Azure DevOps are missing. Even if both GH and Azure are backed by Microsoft, GitLab being open source has a faster upgrade rate and the hosted by gitlab.com solution seems more appealing than anything else! Quick win: the UI is way better and the Pipeline is way easier to setup on GitLab!

See more

Buddy is one of the most easy-to-use tools for CI I ever met. When I needed to set up the pipeline I was really impressed with how easy it is to create it with Buddy with only a few moments. It's literally like: 1. Add repo 2. Click - Click - Click 3. You're done and your app is on prod :D The top feature that I've found is a simple integration with different notification channels - not only Slack (which is the one by default), but Telegram and Discord. The support is also neat - guys respond pretty quickly on even a small issue.

See more
Nazar Atamaniuk
Shared insights
on
DeployPlaceDeployPlaceGitHubGitHubGitLabGitLab

At DeployPlace we use self-hosted GitLab, we have chosen GitLab as most of us are familiar with it. We are happy with all features GitLab provides, I can’t imagine our life without integrated GitLab CI. Another important feature for us is integrated code review tool, we use it every day, we use merge requests, code reviews, branching. To be honest, most of us have GitHub accounts as well, we like to contribute in open source, and we want to be a part of the tech community, but lack of solutions from GitHub in the area of CI doesn’t let us chose it for our projects.

See more
Get Advice from developers at your company using StackShare Enterprise. Sign up for StackShare Enterprise.
Learn More
Pros of GitLab
Pros of GitLab CI
  • 508
    Self hosted
  • 430
    Free
  • 339
    Has community edition
  • 242
    Easy setup
  • 240
    Familiar interface
  • 137
    Includes many features, including ci
  • 113
    Nice UI
  • 84
    Good integration with gitlabci
  • 57
    Simple setup
  • 34
    Free private repository
  • 34
    Has an official mobile app
  • 31
    Continuous Integration
  • 22
    Open source, great ui (like github)
  • 18
    Slack Integration
  • 14
    Full CI flow
  • 11
    Free and unlimited private git repos
  • 10
    User, group, and project access management is simple
  • 9
    All in one (Git, CI, Agile..)
  • 8
    Built-in CI
  • 8
    Intuitive UI
  • 6
    Both public and private Repositories
  • 6
    Full DevOps suite with Git
  • 5
    Build/pipeline definition alongside code
  • 5
    CI
  • 5
    So easy to use
  • 5
    Integrated Docker Registry
  • 5
    It's powerful source code management tool
  • 4
    Issue system
  • 4
    Dockerized
  • 4
    Unlimited free repos & collaborators
  • 4
    Security and Stable
  • 4
    On-premises
  • 4
    It's fully integrated
  • 4
    Mattermost Chat client
  • 4
    Excellent
  • 3
    Great for team collaboration
  • 3
    Built-in Docker Registry
  • 3
    Low maintenance cost due omnibus-deployment
  • 3
    I like the its runners and executors feature
  • 3
    Free private repos
  • 3
    Because is the best remote host for git repositories
  • 3
    Not Microsoft Owned
  • 3
    Opensource
  • 2
    Groups of groups
  • 2
    Powerful software planning and maintaining tools
  • 2
    Review Apps feature
  • 2
    Kubernetes integration with GitLab CI
  • 2
    It includes everything I need, all packaged with docker
  • 2
    Multilingual interface
  • 2
    HipChat intergration
  • 2
    Powerful Continuous Integration System
  • 2
    One-click install through DigitalOcean
  • 2
    The dashboard with deployed environments
  • 2
    Native CI
  • 2
    Many private repo
  • 2
    Kubernetes Integration
  • 2
    Published IP list for whitelisting (gl-infra#434)
  • 2
    Wounderful
  • 2
    Beautiful
  • 1
    Supports Radius/Ldap & Browser Code Edits
  • 22
    Robust CI with awesome Docker support
  • 13
    Simple configuration
  • 9
    All in one solution
  • 7
    Source Control and CI in one place
  • 5
    Integrated with VCS on commit
  • 5
    Free and open source
  • 5
    Easy to configure own build server i.e. GitLab-Runner
  • 2
    Hosted internally
  • 1
    Built-in Docker Registry
  • 1
    Built-in support of Review Apps
  • 1
    Pipeline could be started manually
  • 1
    Enable or disable pipeline by using env variables
  • 1
    Gitlab templates could be shared across logical group
  • 1
    Easy to setup the dedicated runner to particular job
  • 1
    Built-in support of Kubernetes

Sign up to add or upvote prosMake informed product decisions

Cons of GitLab
Cons of GitLab CI
  • 28
    Slow ui performance
  • 8
    Introduce breaking bugs every release
  • 6
    Insecure (no published IP list for whitelisting)
  • 2
    Built-in Docker Registry
  • 1
    Review Apps feature
  • 2
    Works best with GitLab repositories

Sign up to add or upvote consMake informed product decisions

What is GitLab?

GitLab offers git repository management, code reviews, issue tracking, activity feeds and wikis. Enterprises install GitLab on-premise and connect it with LDAP and Active Directory servers for secure authentication and authorization. A single GitLab server can handle more than 25,000 users but it is also possible to create a high availability setup with multiple active servers.

What is GitLab CI?

GitLab offers a continuous integration service. If you add a .gitlab-ci.yml file to the root directory of your repository, and configure your GitLab project to use a Runner, then each merge request or push triggers your CI pipeline.

Need advice about which tool to choose?Ask the StackShare community!

What companies use GitLab?
What companies use GitLab CI?
See which teams inside your own company are using GitLab or GitLab CI.
Sign up for StackShare EnterpriseLearn More

Sign up to get full access to all the companiesMake informed product decisions

What tools integrate with GitLab?
What tools integrate with GitLab CI?

Sign up to get full access to all the tool integrationsMake informed product decisions

Blog Posts

What are some alternatives to GitLab and GitLab CI?
GitHub
GitHub is the best place to share code with friends, co-workers, classmates, and complete strangers. Over three million people use GitHub to build amazing things together.
Bitbucket
Bitbucket gives teams one place to plan projects, collaborate on code, test and deploy, all with free private Git repositories. Teams choose Bitbucket because it has a superior Jira integration, built-in CI/CD, & is free for up to 5 users.
Jenkins
In a nutshell Jenkins CI is the leading open-source continuous integration server. Built with Java, it provides over 300 plugins to support building and testing virtually any project.
Gogs
The goal of this project is to make the easiest, fastest and most painless way to set up a self-hosted Git service. With Go, this can be done in independent binary distribution across ALL platforms that Go supports, including Linux, Mac OS X, and Windows.
Git
Git is a free and open source distributed version control system designed to handle everything from small to very large projects with speed and efficiency.
See all alternatives