Need advice about which tool to choose?Ask the StackShare community!
Concourse vs Jenkins X: What are the differences?
Introduction
Concourse and Jenkins X are both popular continuous integration and delivery (CI/CD) tools used to automate the software development and deployment process. However, there are key differences between them that make each tool unique and suited for different use cases.
Architecture: Concourse is designed around the concept of resources and tasks, where resources are inputs or outputs of a task. It follows a declarative approach, where pipeline configuration is defined in a YAML file. On the other hand, Jenkins X is built on top of Jenkins and Kubernetes. It utilizes GitOps principles, where all the configuration is stored in version control, and Jenkins X automatically deploys and manages the Jenkins infrastructure on Kubernetes.
Scalability and Extensibility: Concourse is designed to be highly scalable and can handle large pipelines and complex workflows. It allows you to easily define and manage resources, making it suitable for large enterprises. Jenkins X, on the other hand, leverages the scalability and extensibility of Kubernetes. It provides automatic scaling of build agents and can seamlessly integrate with third-party plugins from the Jenkins ecosystem.
Native Kubernetes Support: Jenkins X is specifically built for the Kubernetes ecosystem. It leverages Kubernetes pods and containers for running builds and deployments, providing native support for cloud-native applications. Concourse also has support for Kubernetes, but it treats Kubernetes as just another resource and does not have the same level of integration and automation as Jenkins X.
GitOps Workflow: Jenkins X follows a GitOps workflow, where all the configuration and changes are managed through Git repositories. This allows for easy collaboration, versioning, and rollback of changes. Concourse also supports version control systems, but it does not enforce the GitOps workflow as strictly as Jenkins X.
Community and Ecosystem: Jenkins X has a large and active community, with a wide range of plugins and extensions available from the Jenkins ecosystem. This makes it easier to integrate with other tools and services commonly used in the DevOps landscape. Concourse also has a community and ecosystem, but it may not have the same breadth and depth as Jenkins X.
User Interface and User Experience: Concourse has a clean and intuitive web interface for monitoring and managing pipelines. It provides detailed logs and visualizations for better visibility into the pipeline execution. Jenkins X also has a web interface, but it is built on top of Jenkins and follows a more traditional Jenkins UI, which may be more familiar to users already familiar with Jenkins.
In Summary, Concourse and Jenkins X have different architectural approaches, with Concourse focusing on declarative pipelines and resources, while Jenkins X leverages Kubernetes and follows a GitOps workflow.
I'm planning to setup complete CD-CD setup for spark and python application which we are going to deploy in aws lambda and EMR Cluster. Which tool would be best one to choose. Since my company is trying to adopt to concourse i would like to understand what are the lack of capabilities concourse have . Thanks in advance !
I would definetly recommend Concourse to you, as it is one of the most advanced modern methods of making CI/CD while Jenkins is an old monolithic dinosaur. Concourse itself is cloudnative and containerbased which helps you to build simple, high-performance and scalable CI/CD pipelines. In my opinion, the only lack of skills you have with Concourse is your own knowledge of how to build pipelines and automate things. Technincally there is no lack, i would even say you can extend it way more easily. But as a Con it is more easy to interact with Jenkins if you are only used to UIs. Concourse needs someone which is capable of using CLIs.
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
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.
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.
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
Pros of Concourse
- Real pipelines16
- Containerised builds10
- Flexible engine9
- Fast6
- Open source4
- No Snowflakes3
- Simple configuration management3
- You have to do everything2
- Fancy Visualization1
Pros of Jenkins X
- Kubernetes integration7
- Scripted Pipelines5
- GitOps4
Sign up to add or upvote prosMake informed product decisions
Cons of Concourse
- Fail forward instead of rollback pattern2
Cons of Jenkins X
- Complexity1