Bitbucket vs GitHub vs GitLab

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

Bitbucket

40.3K
32.6K
+ 1
2.8K
GitHub

283.5K
247.6K
+ 1
10.3K
GitLab

61.4K
52.6K
+ 1
2.5K

GitHub vs. Bitbucket vs. GitLab - Help me decide


At some point in any software project, you will need to share your code with other developers. If you’re using Git for source control, there are three primary options: Github, Bitbucket, or Gitlab. Understanding the differences and tradeoffs between these three repository management platforms is vital to choosing the best option for your team.

Pull (or Merge) Request Process

One of the core features in any team-based version control platform is the pull request process. This typically happens when a team member completes a new feature and wants to get their code merged into the development or production branch of the codebase.

github_vs_bitbucket_gitlab-pull-request.jpg

The feature to be merged will typically be reviewed by another developer during a code review process, and they may want to use the pull request (called “merge request” in Gitlab) feature included in the repository management platform. Let’s take a look at the differences between Github, Bitbucket, and Gitlab in this area.

1. Github’s Pull Request Feature

The pull request process in Github is designed with team-based projects in mind. In order to facilitate that workflow, Github provides some interesting features:

  • Assign pull requests to teammates
  • Attach milestones, projects, and labels to provide context
  • Subscribe to be notified when the pull request changes
  • Diff of changes between source and base branch
  • One-click merge and delete source branch
  • Integration with external continuous integration tools
  • Pull request templates to ensure contributing guidelines are being followed
  • Conversations around parts of the code that require resolution
  • Required reviews to ensure that every pull request is signed off by someone before the merge

2. Bitbucket’s Pull Request Feature

Bitbucket's pull requests are similar, although they do not offer quite as many features. Bitbucket does offer everything you need though:

  • Assign pull requests to teammates
  • Advanced text editor for comments and descriptions
  • Subscribe to be notified when the pull request changes
  • Diff of changes between source and base branch
  • One-click merge and delete source branch
  • Integration with external continuous integration tools
  • Option to require reviewer approval before merge

3. Gitlab’s Merge Request Feature

While named differently, Gitlab merge requests work pretty much the same way as pull requests. You get most of the same core features:

  • Assign merge requests to teammates
  • WIP (Work In Progress) indicator to open merge requests before they're ready to be merged
  • Integration with milestones/labels for merge request context
  • Team members can subscribe to be notified when the request is merged
  • Diff of changes between source and base branch
  • Integration with external continuous integration tools
  • One-click merge and delete source branch

One usablity difference in Gitlab is that you have to make a couple clicks to get to the diff of changes - they aren't shown by default.

While Github's pull request process has the most unique features, it may be distracting if your team doesn't need all of them. Creating a sustainable, repeatable workflow is often better than trying to do everything.

Integrations

Another common use case for repository hosting platforms is to trigger continuous integration, or continuous deployment. Typically teams will use other services to manage these tasks, so the ability to link their source control repository with third party services is another core feature of Github, Bitbucket, and Gitlab.

Github’s marketplace recently underwent an overhaul, so they now have two places for integrations with third party tools: the Github Marketplace and Works with Github. Marketplace is smaller, but it allows third party applications to actually sell services through Github. Works with Github boasts several hundred integrations with other existing services. Github also has a robust REST API if you need to create your own custom integrations.

Bitbucket is owned by Atlassian so if you use Jira or Bamboo you may appreciate Bitbucket’s built-in integrations. Bitbucket also has a robust app marketplace, and an API that allows you to build your own integrations. It's also worth noting that Bitbucket has its own Pipelines tool that can do your continuous integration and delivery for you.

While Gitlab has fewer built-in integrations (20 are listed in the admin documentation) than either Github or Bitbucket, it is open source, meaning that any part of the code can be customized. This is rarely a necessity though as they also provide a robust plugin system and REST API. You can even customize the login page and user interface to project your team’s personality or company’s brand. Gitlab also offers its own continuous integration tool built into the platform.

Visibility for Open Source Projects

Github is the most popular source control management tool for open source projects because it’s also great for visibility. Projects hosted on Github can have their own public-facing issues, projects, teams, and pull requests. They’re also searchable, and may be featured in Github’s daily or weekly newsletter. Github includes a free hosting solution for static sites, so open source projects can serve up their documentation or landing pages for free on the platform.

Gitlab offers a most starred list, search feature, and free static site hosting, but they do not offer quite as many features for user profiles. For example, you cannot follow users on Gitlab like you can on Github.

Finally, Bitbucket has the option to create public repositories, but they do not currently offer a search feature. Bitbucket’s user profiles are also anaemic, and their static site hosting doesn’t allow custom domain names.

Sometimes public visibility isn’t a feature you want though. For example, some teams want source control to be completely locked down to a private network. In this case, you should consider whether or not your repository hosting platform can be self-hosted. In this case, Github, Gitlab, and Bitbucket all offer self-hosted versions of their product, but the pricing varies quite a bit.

Pricing

Pricing for all three of these repository management platforms is available in two flavors: cloud-hosted and self-hosted.

Cloud-Hosted Pricing Comparison

If your organization is able to use the lowest-tier cloud-hosted version of each platform, your costs will typically grow as a function of team size and whether or not the code you’re hosting is open source.

github_vs_bitbucket_gitlab-pricing.png

*Note: Github also includes a $7/month plan for individuals who want private repositories.

Each platform offers slightly different offerings at higher price points. For example, Github offers a 99.95% uptime SLA and 24/5 tech support starting at $21 per user per month, Bitbucket offers security features like IP whitelisting and required two-step verification starting at $5 per user per month, and Gitlab will give you more CI build minutes and a host of project management features for $19 per user per month. Bitbucket and Gitlab offer free trials if you think you might need some of these premium features.

Once your needs get more complex, I’d recommend checking out each provider’s hosting page to do your own comparison:

Self-Hosted Pricing Comparison

All three of these services also offers a self-hosted option - typically for enterprise customers or users with special security requirements.

github_vs_bitbucket_gitlab-self-hosted-pricing.png

While Github and Bitbucket offer self-hosting, only Gitlab is open source, which allows its self-hosted option to be the cheapest. That said, you may want additional support support,, so be sure to check out the pricing pages above to make sure you’re getting the best plan for your needs.

Bitbucket vs GitHub vs GitLab: What are the differences?

When it comes to version control and hosting repositories, three popular platforms stand out: Bitbucket, GitHub, and GitLab. Each of these platforms offers a range of features and capabilities, but they also have some key differences that set them apart from each other.

  1. Development Focus: Bitbucket is primarily focused on providing a collaborative environment for teams, especially those using the Atlassian suite of tools. GitHub, on the other hand, is widely used by individual developers and open-source projects, offering a more community-driven approach. GitLab aims to provide a holistic platform for the entire software development lifecycle, including issue tracking, continuous integration, and deployment.

  2. Pricing Models: Bitbucket offers free unlimited private repositories for small teams, while GitHub only provides free public repositories. However, GitHub's pricing is more flexible and competitive for larger teams, offering more features at lower costs. GitLab, on the other hand, offers a free self-hosted option, giving users complete control over their repositories.

  3. Integration with Tools: Bitbucket seamlessly integrates with other Atlassian products like Jira, allowing for smooth project management. GitHub has a vast ecosystem of third-party integrations and offers easy integrations with popular tools like Slack and Trello. GitLab, being an open-source platform, allows for extensive customization and integration possibilities.

  4. Continuous Integration/Continuous Deployment (CI/CD): Bitbucket offers built-in CI/CD capabilities using their pipelines feature, providing an integrated workflow for developers. GitHub offers GitHub Actions, a powerful CI/CD platform, enabling developers to automate their workflows easily. GitLab, being a comprehensive platform, offers extensive CI/CD capabilities with GitLab CI/CD pipelines, allowing for efficient deployment and testing.

  5. Enterprise Support: Bitbucket offers enterprise-grade support for larger organizations as part of the Atlassian product suite. GitHub has a strong focus on open-source projects but also provides enterprise-level support through their GitHub Enterprise offering. GitLab, being open-source and self-hosted, offers complete control and customization options for larger enterprises.

  6. Hosted vs Self-Hosted: Bitbucket is a hosted solution, meaning all the infrastructure and maintenance are managed by Atlassian. GitHub also offers a hosted option, but they also provide an on-premise solution through GitHub Enterprise. GitLab, however, can be self-hosted, giving users complete control and ownership over their repositories.

In summary, Bitbucket is a great choice for teams using the Atlassian suite and looking for seamless integration and collaboration. GitHub is widely popular among individual developers and open-source projects, offering a vast ecosystem of integrations. GitLab provides a comprehensive platform for the entire software development lifecycle, with extensive customization options and self-hosting capabilities.

Advice on Bitbucket, GitHub, and GitLab
Needs advice
on
GitGitGitHubGitHub
and
GitLabGitLab

Which one of these should I install? I am a beginner and starting to learn to code. I have Anaconda, Visual Studio Code ( vscode recommended me to install Git) and I am learning Python, JavaScript, and MySQL for educational purposes. Also if you have any other pro-tips or advice for me please share.

Yours thankfully, Darkhiem

See more
Replies (5)
Christopher Wray
Web Developer at Soltech LLC · | 18 upvotes · 236.3K views
Recommends
on
GitGitGitHubGitHub

Hey there, Definitely install Git. Git is the open source version control system that both GitHub and GitLab interface with. Git is extremely important as a new developer to learn, and once you do, you will be so thankful you are tracking your projects in it. Git makes it super easy to track changes you make in your code, and even rollback, edit, view, or delete changes you made months before. In software development, it is a crucial skill to learn.

GitHub and GitLab are online cloud Git repositories. They are for backing up your repos in the cloud, and working with other developers, or even working with yourself via other devices. I would recommend starting with GitHub since you are a new developer. Companies will want to see your GitHub when you start applying to jobs, and having one will be a great plus going for you. It also is the most widely used by developers and most open source projects are hosted on GitHub.

Here is a course on Codecademy to start learning: https://www.codecademy.com/learn/learn-git

Hope this helps! Good luck!

See more
Recommends
on
GitHubGitHub

I think Github is the most important thing, so take good care of it, and share your most important programs on it with others, this helps to raise your efficiency through the feedback of others. with my Greetings.

See more
Pat Fitzner
Recommends
on
GitGit

Hey! Regardless of your choice of platform, you will need to install and learn Git. So start there! The differences between GitHub and GitLab are not relevant to you at this stage.

See more
Recommends
on
GitHubGitHub

I use GitHub by few years. For now, I think this is the best way to work on another computers or to work with other people. I tested GitLab and Git, but for me GitHub is easier and most friendly for another developers who are worked with me.

See more
Joon Poore
Full Stack Web Dev. at Quary.dk · | 1 upvotes · 157.1K views

For python, Pycharm is a very nice and beginner friendly IDE. I am using it myself, use the free community edition, it also comes with a lot of great tools.

See more
Matanel Crown
Software Developer at BBT.live · | 7 upvotes · 310.5K views

Hi all,

I would like some information regarding the benefits an aspiring start-up company may have, while using GitHub Enterprise vs the regular GitHub package. On a separate issue, I'd like to understand whether GitLab may have some DevOps-related advantages GitHub does not.

Thank you in advance, Matt

See more
Replies (5)
Luke Carr
Founder & CEO at Moducate · | 7 upvotes · 252.6K views

I'd lean towards GitHub (either billing plan) for one key reason that is often overlooked (we certainly did!).

If you're planning on creating OSS repositories under your start-up's name/brand, people will naturally expect to find the public repositories on GitHub. Not on GitLab, or Bitbucket, or a self-hosted Gitea, but on GitHub.

Personally, I find it simpler to have all of the repositories (public and private) under one organisation and on one platform, so for this reason, I think that GitHub is the best choice.

On the DevOps side, GitLab is far superior to GitHub (from my experience using both GitHub Enterprise and GitLab Ultimate), but for the one aforementioned, we're using GitHub at Moducate.

See more
Recommends
on
GitLabGitLab

Advantages for Github Enterprise is that you get more storage, CI minutes, advanced security features, and premium support. If you don't really need any of those, you can stick with Github Team. Though if you're going to use Gitlab CI, I suggest going with Gitlab instead of Github so you won't have to maintain 2 repositories.

Regarding the advantages that Gitlab CI has over Github, there's a detailed explanation here: https://about.gitlab.com/devops-tools/github-vs-gitlab/ci-missing-github-capabilities/

If you need more minutes for Gitlab CI, you can always use your own Gitlab CI runners instead of the shared runners: https://docs.gitlab.com/runner/register/

See more
Brandon Miller
Recommends
on
GitHub EnterpriseGitHub Enterprise

With the advent of Gitlab actions/workflows, it's hard to not choose Github anymore. I say that with all love for Gitlab, as it's been my personal tool of choice for a long time because of it's inbuilt CI/CD solutions. Github is just all around more adopted by the community so you'll always find more support; and if you go with enterprise you will get 50k build minutes a month as well as a ton of extra tools that will definitely help a startup out from the get-go. That being said, it's priced at $21 per user, per month so if you cannot afford that, I say go with Github.

See more
Evgeny Rahman
Full Stack Solution Architect · | 3 upvotes · 217.6K views
Recommends

GitHub Enterprise comes with included SAML SSO support, and a huge free tier for Actions and Packages, which gives your team everything they need to get off to a great start and scale up without hitting any roadblocks along the way. An important point to consider is that GitHub Enterprise comes in both self-hosted and cloud-hosted variations, so you don't need to manage your own infrastructure for it unless you would prefer to.

With GitHub Enterprise, you also plug in to the largest development community in the world, and can collaborate directly on the open source projects that are probably already part of your stack. You can also access the latest and greatest in development tools such as GitHub Codespaces, GitHub Co-Pilot, and much much more, with great new features being shipped every day.

See more
Recommends
on
GitLabGitLab

GitHub is trying to catch up with GitLab. GitLab was built from the ground up with DevOps tooling. GitHub is years away on features.

See more
Eric Seibert
DevOps at Children's Hospital of Philadelphia · | 6 upvotes · 504.2K views
Needs advice
on
BitbucketBitbucket
and
GitHub EnterpriseGitHub Enterprise

We are using a Bitbucket server, and due to migration efforts and new Atlassian community license changes, we need to move to a new self-hosted solution. The new data-center license for Atlassian, available in February, will be community provisioned (free). Along with that community license, other technologies will be coming with it (Crucible, Confluence, and Jira). Is there value in a paid-for license to get the GitHub Enterprise? Are the tools that come with it worth the cost?

I know it is about $20 per 10 seats, and we have about 300 users. Have other convertees to Microsoft's tools found it easy to do a migration? Is the toolset that much more beneficial to the free suite that one can get from Atlassian?

So far, free seems to be the winner, and the familiarization with Atlassian implementation and maintenance is understood. Going to GitHub, are there any distinct challenges to be found or any perks to be attained?

See more
Replies (1)

These are pretty competitive, and to recommend one over the other would require understanding your usage. Also, what other tools you use: for instance, what do you use for Issue-tracking, or for build pipelines. In your case, since you are already using Bitbucket, the question would be: do you have any current pain-points? And, on the other hand, do you already use Atlassian's JIRA, where you'd benefit from the tight integration? So, though I would not recommend one over the other just in general,. But, if Bitbucket fulfills your current use-cases, then there seems to be little motivation to move.

See more

Hi, I need advice. In my project, we are using Bitbucket hosted on-prem, Jenkins, and Jira. Also, we have restrictions not to use any plugins for code review, code quality, code security, etc., with bitbucket. Now we want to migrate to AWS CodeCommit, which would mean that we can use, let's say, Amazon CodeGuru for code reviews and move to AWS CodeBuild and AWS CodePipeline for build automation in the future rather than using Jenkins.

Now I want advice on below.

  1. Is it a good idea to migrate from Bitbucket to AWS Codecommit?
  2. If we want to integrate Jira with AWS Codecommit, then how can we do this? If a developer makes any changes in Jira, then a build should be triggered automatically in AWS and create a Jira ticket if the build fails. So, how can we achieve this?
See more
Replies (1)
Sinisha Mihajlovski
Design Lead | Senior Software Developer · | 1 upvotes · 351.8K views
Recommends

Hi Kavita. It would be useful to explain in a bit more detail the integration to Jira you would like to achieve. Some of the Jira plugins will work with any git repository, regardless if its github/bitbucket/gitlab.

See more
Decisions about Bitbucket, GitHub, and GitLab
Benjamin Stirrup

We chose github + github actions in order to manage the code versioning and the CI on the same software. Furthermore, while it is not that much, I believe that for a large team it is considerably cheaper to have one github subscription instead of a git subscription and a CI/CD software subscription.

See more
Hendrik Halkow

GitHub provides great user experience ans most developers are familiar with it. There is also an attractive pricing model for those who already have a Visual Studio subscription.

We also don't like the "everything in one tool" approach from GitHub as there are better tools for build system, package registries, etc. on the market.

See more

We chose GitHub for version control hosting because of its high-quality and performant pull request user interface, as well as GitHub Actions.

We also selected GitHub as our first OAuth2 authorization provider because of its large community, high-quality documentation, and sophisticated App framework for granular permission management and event notifications.

See more
Steve Barnes
Lead Software Tools Engineer at Leonardo UK · | 7 upvotes · 235.9K views

The company needed to move from hosting all of our repositories, tickets & releases from a GForge instance hosted by our former parent company. The decision was made to move to GitHub Enterprise but the developers were not told until there was 1 month left to go. So needed something that could pull all of our information out and push it to the new hosts and it needed to be done ASAP.

See more
Eduardo Fernandez
Software Engineer at Parrot Software, Inc. · | 8 upvotes · 273.6K views

Do you have a K8s cluster and you want to deploy some services to it? Gitlab Auto Devops is key to achieve this without breaking a sweat.

We deploy Go services to our K8S clusters with warp speed thanks to Gitlab and it's Auto Devops pipeline.

I haven't seen tooling like this in any other git cloud provider.

See more
Phillip Manwaring
Developer at Coach Align · | 17 upvotes · 380.4K views

Both of us are far more familiar with GitHub than Gitlab, and so for our first big project together decided to go with what we know here instead of figuring out something new (there are so many new things we need to figure out, might as well reduce the number of optionally new things, lol). We aren't currently taking advantage of GitHub Actions or very many other built-in features (besides Dependabot) but luckily it integrates very well with the other services we're using.

See more
Elmar Wouters
CEO, Managing Director at Wouters Media · | 7 upvotes · 545.9K views

I first used BitBucket because it had private repo's, and it didn't disappoint me. Also with the smooth integration of Jira, the decision to use BitBucket as a full application maintenance service was as easy as 1, 2, 3.

I honestly love BitBucket, by the looks, by the UI, and the smooth integration with Tower.

See more
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
Manage your open source components, licenses, and vulnerabilities
Learn More
What are some alternatives to Bitbucket, GitHub, and GitLab?
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.
Atlassian Stash
It is a centralized solution to manage Git repositories behind the firewall. Streamlined for small agile teams, powerful enough for large organizations.
Crucible
It is a Web-based application primarily aimed at enterprise, and certain features that enable peer review of a code base may be considered enterprise social software.
JavaScript
JavaScript is most known as the scripting language for Web pages, but used in many non-browser environments as well such as node.js or Apache CouchDB. It is a prototype-based, multi-paradigm scripting language that is dynamic,and supports object-oriented, imperative, and functional programming styles.
Python
Python is a general purpose programming language created by Guido Van Rossum. Python is most praised for its elegant syntax and readable code, if you are just beginning your programming career python suits you best.
See all alternatives