I heard so many people, read so many blog-posts on Jenkins, it's integration with many tools with it's plugin architecture, but also about TravisCI and how much it helped the OS community to build quality software for free, but I'm curious about other solutions and how well they work.<p>What are you using? What criterias did drive this choice? Would you do it differently?
I'm using GitLab CI. I use GitLab.com for the free private git project hosting. GitLab.com has free CI servers available (even for private projects) that work well if you don't need to run builds all the time. A lot of people use their shared CI runners, so your jobs/builds might take several minutes before they start running. If you have a larger need, you can always host your own runners (software is FOSS).<p>GitLab's CI has a pipeline design, so (like Jenkins) you can have some jobs wait for other jobs to complete and use their build artifacts (e.g. have a single build job that downloads deps and compiles everything so later jobs don't need duplicate that work), and you can have jobs only be triggered manually instead of on every push.<p>It's not perfect, though. For instance, unlike TravisCI, you don't have a build matrix, but you can use YAML tricks to define template jobs (see GitLab's own CI file [0] and a resulting pipeline [1]). If you use GitLab.com, you should be aware that they have downtime a few times each month, both planned and unplanned. For their planned downtime, it is often during the work day in the US timezones, and usually lasts between 10-30 minutes (though it has been longer before). GitLab.com is also used as a "testing in production" environment for their monthly releases, so you will occasionally run into bugs (usually nothing showstopping though; mostly minor annoyances).<p>I think that what you choose greatly depends on what you need. GitLab CI is a little opinionated, but it is still pretty flexible and usable for a large number of work cases. If you need a ton of customizability, Jenkins could be a better option (with plugins). GitLab CI is a lot easier to setup, however.<p>GitLab CI also has CD features that you can look into (I don't use them myself). They are also constantly (i.e. every 22nd of the month) releasing new versions, and most of their features are open source.<p>[0]: <a href="https://gitlab.com/gitlab-org/gitlab-ce/blob/master/.gitlab-ci.yml" rel="nofollow">https://gitlab.com/gitlab-org/gitlab-ce/blob/master/.gitlab-...</a><p>[1]: <a href="https://gitlab.com/gitlab-org/gitlab-ce/pipelines/6014043" rel="nofollow">https://gitlab.com/gitlab-org/gitlab-ce/pipelines/6014043</a>
Codepen recently published podcast episode [0], where they tell why they spitched from GitHub to GitLab. Built in CI solution was one of the reasons.
If you don't want to listen the whole thing, there's also a transcript: [1]<p>[0]: <a href="https://blog.codepen.io/2017/01/24/114-gitlab/" rel="nofollow">https://blog.codepen.io/2017/01/24/114-gitlab/</a><p>[1]: <a href="http://gitlabfan.com/ce4d016e0eec" rel="nofollow">http://gitlabfan.com/ce4d016e0eec</a>
I use Codeship [1] for personal (private) project and Travis CI [2] for open source ones. I had also use AppVeyor [3] for one of my Windows web app project.<p>I chose Codeship since it was the only one (at the time) that had BitBucket integration. The free tier (100 builds / mo) was more than enough for my side projects. In addition, it supports a lot of deployment targets (e.g. ElasticBeanstalk and Heroku).<p>I use Travis CI for open source projects initially since it is what everyone uses :) However, one feature that I find really useful is the test matrix. I used it to test my project against different Java version and Cassandra distribution versions [4].<p>I use AppVeyor on one of my side project (which lies dormant now) since needing to test against both *nix and Windows build (a .NET / Mono web application).<p>[1] - <a href="https://codeship.com/" rel="nofollow">https://codeship.com/</a><p>[2] - <a href="https://travis-ci.org/" rel="nofollow">https://travis-ci.org/</a><p>[3] - <a href="https://www.appveyor.com/" rel="nofollow">https://www.appveyor.com/</a><p>[4] - <a href="https://github.com/builtamont-oss/cassandra-migration" rel="nofollow">https://github.com/builtamont-oss/cassandra-migration</a>
After being a Jenkins person for years I recently started playing around with Visual Studio Team Services, Microsoft's hosted TFS product: <a href="https://www.visualstudio.com/team-services/" rel="nofollow">https://www.visualstudio.com/team-services/</a>.<p>You don't have to use TFS as the backend as git is supported and all of your build and release stuff is under the same roof. They have added a lot of "tasks" for most of the popular languages but worst case is you can always run shell commands to do stuff.<p>The UI leaves a bit to be desired (I think) but for the most part I can live with it.<p>Full disclosure, I work at MSFT but have been a Linux/Open Source/non-ms person for most of my career.<p>EDIT: With all of that being said I do like Gitlab because it offers many of the same features (code repo, builds, etc) and am using Gitea/Gogs on my own VM for repo mirroring from Github.
Some guys in our workplace have been investigating Concourse CI and like it over Bamboo which we currently use.<p><a href="https://concourse.ci/" rel="nofollow">https://concourse.ci/</a>
We use Jenkins, hosted on Amazon. We're .NET stack, so some of the other options didn't work.<p>Biggest lesson for us: Avoid putting all your logic into Jenkins templates. You're not capturing your CI/deployment logic in version control, and this can cause problems down the road (we backed up Jenkins regularly, but versioning was a weak point).<p>Instead, do as much as you can in scripts, and use Jenkins as a glorified crontab (+webhooks).
I use GitLab not only because it's built in but because I've also had a really smooth experience with them.<p>They might be slower than others, but imo all development is made locally so I don't mind if sometimes it takes more than 5 minutes (used to take longer but they have improved a lot!).<p>I've only waited for like 30 minutes once. I would definitely recommend it.
I've used various CI/CD server/services in the past. As with so many tooling questions this is one of those 'depends' situations.<p>Jenkins is okay but you have to really stay on top of the build environment (not just a specified in Jenkins itself but also the OS and tooling on the Jenkins server and build machines).<p>I'm in the process of building a new CI/CD pipeline and this time I'm using Concourse. This is a good fit because the target system is largely containerised (not that Concourse can't be used elsewhere, it can, but it's just a coincidental fit). Additionally, Concourse addresses the problem identified by Cpoll as, unlike Jenkins et al, Concourse pipeline, build plans, and tasks are 100% available for version control.<p>That all said, I can't comment on Concourse's foibles as I've not used it long enough to uncover them :)
We were locked into an Atlassian stack when they discontinued Bamboo and Pipelines wasn't ready for production (nor a good fit for us).<p>We ended up going with a service called Buildkite, which is almost a drop-in replacement. They even had docs specifically about migrating from Bamboo, and in general their documentation has been excellent.<p>We really like having full control over the test execution environment despite not being ready to start using Docker, and we've been pretty happy with the service itself as well as the tech support we've received. I might choose something else for a different company, but this is a very good fit for us.
Nice to see GitLab CI getting some love on this thread.<p>I have to polish it yet but my notes for teaching GitLab CI (one-day course on the basics of it) are available at <a href="https://gitlab.com/atsaloli/gitlab-ci-tutorial" rel="nofollow">https://gitlab.com/atsaloli/gitlab-ci-tutorial</a> and may help one get started with it.
I've been using GoCD for the past couple of months and I'm really liking it so far. Its very flexible and relatively straight-forward to setup on your own VM. The plugins work similar to the way Jenkin's does it. Also the UI is very clean.
I've used Jenkins in the past and Bamboo right now without any issues for CI and a little bit of CD through custom scripts. Granted this has worked well for under 30 engineers, so i'm not sure how bigger teams do things.
Semaphore [0] is great. It was the only place where I could get selenium tests to work reliably.<p>[0]: <a href="https://semaphoreci.com/" rel="nofollow">https://semaphoreci.com/</a>