Open Source Code Hosting

If you want to get your hands dirty in coding, you’ll need a place online to store and share your code. And there’s no shortage of options for this, especially if you want free hosting. So let’s talk about the best open source code hosting services as I go through a broad overview of available options today.

1. GitLab

gitlab.jpg

GitLab

(Seth Kenlon, CC BY-SA 4.0)

GitLab is more than just a GitHub alternative; it’s more like a complete DevOps platform. GitLab is nearly all the infrastructure a software development house requires, as it provides code and project management tools, issue reporting, continuous delivery, and monitoring. You can use GitLab on GitLab.com, or you can download the codebase and run it locally with or without paid support. GitLab has a web interface, but all Git-specific commands work as expected.More Great Content

GitLab is committed to open source, both in its code and the organization behind it, and to Git itself. The organization publishes much of its business documentation, including how employees are onboarded, their marketing policies, and much more. As a site, GitLab is ardent in promoting Git. When you use a site-specific feature (such as a merge request), GitLab’s interface explains how to resolve the request in pure Git, should you prefer to work in the terminal.

2. Gitolite

Gitolite is quite probably the minimal amount of code required to provide a server administrator a frontend for Git repository management. Unlike GitHub, it has no web interface, no desktop client, and adds nothing to Git from the user perspective. In fact, your users don’t really use Gitolite directly. They just use Git, as usual, whether they’re used to Git in a terminal or Git in a frontend client like Git Cola.

From the server administrator’s perspective, though, Gitolite solves all the permission and access problems you’d have to manage manually if you ran a plain Git server. With Gitolite, you create only one user (for instance, a user called git) on your server. You allow your users to use this single login identity to access your Git server, but when they log in, they must deal with your Git server through Gitolite. It’s Gitolite that verifies users’ access permissions, manages their SSH keys, verifies their privilege level when accessing specific repositories, and more. Instead of creating and managing countless Unix user accounts, all the administrator has to do is list users (identified by their SSH public keys) to the repositories they are allowed to access. Gitolite takes care of everything else.

Gitolite is nearly invisible to users, and it makes Git management nearly invisible to the server admin. As long as you don’t require a web interface, Gitolite is a net win for everyone involved.

3. Gitea and Gogs

gitea.jpg

Gitea

(Seth Kenlon, CC BY-SA 4.0)

The Gogs project is an MIT-Licensed Git server framework and web user interface. In 2016, some Gogs users felt development was hindered because only its initial developer had write access to its development repository, so they forked the code to Gitea. Today, both projects co-exist independently of one another, and from a user’s perspective, they are basically the same experience. Ironically, both projects are hosted on GitHub.

With Gitea and Gogs, you download the source code and run it as a service on your server. This provides a website for users, where they can create an account, log in, create their own repositories, upload code, navigate through code, file issues and bug reports, request code merges, manage SSH keys, and so on. The interface is similar in look and feel to GitLab, GitHub, or Bitbucket, so if users have any experience with an online-code management system, they’re already essentially familiar with Gitea and Gogs.

Gitea or Gogs can be installed as a package on any Linux server, including a Raspberry Pi, as a container, on BSD, macOS, or Windows, or compiled from source code. They’re both cross-platform, so they can be run on anything that runs Go. Read Ricardo Gerardi’s article about setting up a Gogs container using Podman for more information.

4. Independent communities

notabug.jpg

Notabug

(Seth Kenlon, CC BY-SA 4.0)

If you’re not up for self-hosting, you can cheat a little by using a self-hosted option on somebody else’s server. There are many independent sites out there, such as Codeberg, Nixnet, Tinfoil-hat, and Notabug.org. Some run Gitea and others run Gogs, but the result is the same: free code hosting to help you keep your work safe and public. These solutions may not be as complex as something like GitLab or GitHub, they may not offer on-demand Jenkins pipelines and continuous integration/continuous development (CI/CD) solutions, but they’re great mirrors for your work.

There are purpose-specific providers, too: a Gitea instance for FSFE supporters, a Gitlab instance for Freedesktop projects, and another for GNOME projects.

Because these independent servers are smaller communities, you might also find that the “social” aspect of social coding is more significant. I’ve made several online friends through an independent Git provider, while GitHub has proven to be, at least socially, underwhelming.

The message is clear: there’s no requirement or advantage for there to be a centralized, dominant, non-free Git software hosting service.

5. Git

It might surprise you to know that Git is surprisingly self-reliant as a server. While it lacks user management and permission settings, Git integrates with SSH and ships with a special git-shell application designed specifically to serve as a limited environment for using Git commands. By setting users’ default shell to git-shell, you can limit what actions are available to them when they interact with your server.

What Git alone does not offer is repository permission tools to help you manage what each user has access to. For this, you’ll have to fall back on the operating system’s user and access control list (ACL) controls, which can become tedious should you have more than just a handful of users. For small projects or projects just starting, running Git on a Linux server is an easy and immediate solution to the need for a collaborative space. 

Conclusion

Now you know where you can host your source code online. Choose the right provider and you’ll find that it is both affordable and secure. It will also never let you down, no matter how large or complex your code may be. Hosting with one of the popular providers ensures that your code will always be available and reliable to your audience. They are trusted names in the industry that have proven themselves over the years.

0 Comments

No Comment.