There are two primary functions. The first function is a Git-compliant source code repository, and the second function is a full-fledged CI/CD platform.
The CI/CD functionality as a whole is pretty helpful and nice to have. Their CI/CD engine is very mature. It's very comprehensive and flexible, and compared to other projects, I believe that GitLab is number one right now from that perspective.
They have had a Kubernetes integration built in, but they recently announced that in Version 16 they're going to strip out the legacy Kubernetes integration, and then introduce a new way of doing the integration. I don't really like the new way because it is pretty focused on the on-premise environment, but we're in a hybrid environment. The integration they're offering is not really a good fit for hybrid infrastructure and I was disappointed with that new feature.
I work for a government-based institution in the US and government-based institutions are very strict about compliance and security. The new model GitLab is offering implies the connectivity will be initiated from the server side to the clients, meaning from Kubernetes back to GitLab, and that's not going to work in our space. We cannot allow traffic back from the cloud to on-prem, so that's going to be a compliance violation. I understand why they want to implement the feature, maybe it's going to be more solid, but it looks like they aren't taking into consideration hybrid environments and the security and compliance aspects. We will find a workaround, but we're still kind of disappointed. It'll generate a lot of additional work.
One feature that has been requested by our development team is a multi-level review of the pool request. When you maintain code and you've got a lot of contributors, a contributor can submit a change in the form of a pool request. There is a feature called merge request in GitLab for when you have a team of people who are supposed to approve a change, but Atlassian BitBucket has a more complete version of the same feature, which includes a multi-approval mechanism. For instance, if you have three people, you can create a rule for how changes should be approved. Maybe they should be approved by you and me and the third guy is not really important, or it could be approved by only you or me, or all three of us together. BitBucket has that flexibility and there is no such flexibility in GitLab.
I've been using GitLab for approximately four years.
Overall, it's pretty stable.
Scalability is not directly a feature of GitLab because GitLab is about storing your source code. Your storage can be organized in a way that makes it very scalable. For instance, we use the NetApp Store and we are not limited at all, so whenever we hit a disk space problem, we can simply extend the storage and give it more IOPs. However, the way you organize your storage is not GitLab's responsibility.
There are about 100 people currently involved with this solution at my company.
Their customer service is very helpful. They're really good. I communicate with tons of different support clients and GitLab's support is one of the best. A lot of people don't like calling support because it's often useless or annoying, but I would rate GitLab's support as a ten out of ten. I haven't had any complications.
The initial setup is pretty straightforward. I don't remember having any issues related to the setup.
There is an open-source edition and a commercial version. I've used both, but mostly I've used the commercial one. However, the open-source version is also very, very good. The commercial version is reasonably priced. It's about 20k annually.
Checkmarx is a static analysis tool. GitLab offers, in turn, their own solution. They offer static analysis, dynamic analysis, and a lot of integration. They also offer integration with Checkmarx. There are a lot of features, actually, and plenty of tools. For the price, I think it's very comprehensive.
Compared to other products, for instance, Nessus, they're approximately at the same price level. I would put them all on the same level with approximately the same functionality, but GitLab is one of the best.
I would give this solution a ten out of ten. There are a couple of caveats, but compared to other products, GitLab is certainly the leading solution in the market right now.
I was looking for a free alternative to GitHub for my hacking projects. I tried GitHub, BitBucket, GitLab, and a few others and settled on GitLab. It's free, easy to use, and has a lot of great features.
I will say that the UI is a bit confusing at first, but it is very easy to figure out. For the most part, you will just be adding and removing repos. You can also view and edit issues and merge.