In our tech world, every day new tools and framework emerge to help us in our live.One of them is Puppet.A Configuration Management tool. This blog will be for who are trying to explore any configuration management tool or someone who is hearing a name puppet for the first time.Lets us explore what Puppet is actually. Why we need it, and how it works.
What is Configuration Management Tool?
Configuration management (CM) is a systems engineering process for establishing and maintaining consistency of a product’s performance, functional, and physical attributes with its requirements, design, and operational information throughout its life.
In simple term, if you have 100s of the production server and you have to upgrade the OS version in all the server or you have to install new software on all systems.Any configuration change required. Basically, your system admin helps you with this.
For more on CM click here.
Puppet is a pioneering configuration automation and deployment orchestration solution for distributed apps and infrastructure.
This open source configuration management solution is built with Ruby and offers custom Domain Specific Language (DSL) and Embedded Ruby (ERB) templates to create custom Puppet language files and offers a declarative paradigm programming approach. Puppet uses an agent/master architecture—Agents manage nodes and request relevant info from masters that control configuration info.
The Puppet Enterprise product offers the following capabilities:
- Automated provisioning
- Configuration Automation
- Visualization and reporting
- Code management
- Node management
- Role-based access control
- Strong compliance automation and reporting tools.
- Active community support around development tools and cookbooks.
- Intuitive web UI to take care of many tasks, including reporting and real-time node management.
- Robust, native capability to work with shell-level constructs.
- Initial setup is smooth and supports a variety of OSs.
- Particularly useful, stable and mature solution for large enterprises with adequate DevOps skill resources to manage a heterogeneous infrastructure.
- Can be difficult for new users who must learn Puppet DSL or Ruby, as advanced tasks usually require input from CLI.
- Installation process lacks adequate error reporting capabilities.
- Not the best solution available to scale deployments. The DSL code can grow large and complicated at a higher scale.
- Using multiple masters complicates the management process. Remote execution can become challenging.
- Support is more focused toward Puppet DSL over pure Ruby versions.
- Lacks push system, so no immediate action on changes. The pulling process follows a specified schedule for tasks.
How Puppet Works
Puppet works on the master-slave relationship. There will be master which handle all the changes and logging.Every client/machine have the puppet agent which are slaves.
In general, there is two type of master-slave relationship.Pull based and push-based architecture.Below are the images which will explain this architecture.
In Push configuration, the centralized server will push the changes or any action to all the nodes, but in pull based configuration node will as for new changes, and then get the changes from the centralized server.
Puppet is written in Ruby. It is available in enterprise version also.From version 2.0 it is available under Apache License.
Master server contains the manifest file, where with the Puppet declarative language/Ruby DSL we have to write the task we have have to perform.
There are resources[services, packages etc] in Puppet, we have to define these resources in the manifest .Group of the resource is called as the class to logically combined the resources.
We often have multiple modules to logically group the manifest file.
Puppet has multiple masters to handle the failure conditions.All the agents have to sign the certificate and all change of information is over SSH , so every exchange is fully protected and authenticated.
Below is the video from Edureka , which explain and demonstrate how it works.
Alternatives of Puppet