DevOps
Toolchain
1 @UpGuard | UpGuard.com
Table of Contents
Introduction 3
The DevOps Toolchain 5
Conclusion 9
The DevOps Checklist 10
2 @UpGuard | UpGuard.com
Introduction
DevOps may need little introduction these days, but
many are still at a loss to explain precisely what the
movement entails. Some emphasize the portmanteau
of the two terms, stating that the heart of DevOps is
the collaboration between developers and operations
staff. Others choose to focus on the tools and the
problems they solve, singing the praises of DevOps
for fixing their respective infrastructure woes. Tools--
though crucial enablers of the movement-- only
form part of the equation. DevOps encompasses
cultural innovation, a breaking down of walls and silos
between software development, operations, and QA/
testing-- in addition to the tools and methodologies
enabling this transformation.
Ultimately, the definition of DevOps varies per
organization. Since its meaning depends heavily
on the audience and context in question, general
discussions around the true definition of DevOps are
for the most part inconsequential. If you is specifically
concerned about what is/not DeVops, check out our
ebook “DevOps for Cynics” and our blog post “Defining
DevOps.” If you want to know about tools that can
make your life easier, what makes each one unique,
and how they fit together, read on.
3 @UpGuard | UpGuard.com
Introduction (continued)
Hybridization of Roles Agile Roots
A discussion regarding tools and DevOps should At first glance, DevOps may seem like an evolution
therefore begin by considering the individuals who or extension of Agile and Lean methodologies
will be utilizing the tools. The rise of so-called that have gained prominence in the last decade.
“polyglot programmers” and systems administrators While this is certainly true in many respects, an
with coding proficiency reflects a general trend in important distinction lies in scope: while Agile deals
IT towards despecialization. Developers these days primarily on the development side of affairs, DevOps
are adept in a number of languages and approaches, stresses a unified approach that covers the entire
applying each accordingly based on the problem scope of software delivery. So as Agile stresses
at hand. Similarly, most systems administrators cross-functional collaboration to aid incremental,
possess competent programming abilities for continuous development of quality software, DevOps
traversing the stack-- on top of the requisite skills expands this ideal to include development, IT
for managing IT operations. The industry has been operations, and QA/Testing teams as interdependent
quick in attaching new labels to these emerging cogs of the same software delivery mechanism.
hybrid roles: DevOps Engineer and DevOps Specialist Indeed, many of the Agile tools and methodologies
being the most common. Notwithstanding, the key find their way into the DevOps toolchain and
takeaway is that no single IT skill is more important workflow, as the two promote the same style of
or valuable than another; subsequently, many collaboration. Furthermore, as software development
different tools are required to do the job effectively. ultimately depends on operations for deployment,
So as DevOps is comprised of a group of concepts a closer integration of the two groups will naturally
clustered around the premise of continuous software boost quality and efficiency.
delivery, these concepts in turn encompass a range
of associated tools for fulfilling particular functions.
Infrastructure-as-Code
With Agile software teams becoming commonplace,
All in all, these complementary tools fill out the
IT operations needs a way to keep up infrastructure
DevOps toolchain, unifying the best elements from
with this rapid pace of development. Furthermore, as
development and operations. Keep in mind that both
virtualized environments and cloud infrastructures
tools and cultural innovation are required for DevOps;
become more commonplace, the operations
adopting a popular solution on its own as a magic on-
side needs a more dynamic, flexible approach to
ramp to DevOps is a quick path to disillusioned, as
managing systems. Borrowing from their software
there are no “DevOps” tools, per se. The combination
development counterparts, systems administrators
of cultural changes, information de-siloing, and
can now manage their infrastructures as code--
tooling implemented along way is what enables an
automating and tracking configurations like source
organization to recognize ROI from DevOps. In a
code. This enables the ability for version control,
sentence, it’s not just about the tools, but the people
rolling back of changes, as well as integrated testing
as well.
and deployment to production of necessary software
and server components. This unification of all sides
of the software delivery puzzle is also referred to
as “programmable infrastructure,” and is central to
practicing DevOps.
4 @UpGuard | UpGuard.com
The DevOps Toolchain
Many of the tools that are essential to DevOps practitioners are also familiar Agile tools. Similarly, as
configuration management (CM) is a central premise to DevOps, many of the tools mentioned below are
popular CM and automation tools. Again, they fulfill the specific area of DevOps that they are good at.
Versioning and Source Control
Tracking code level changes is a common
and necessary activity of today’s
software developers. Doing so enables CI/
concurrent development, merging, and Orchestration
rollback capabilities for applications/
software. Source Control Management
(SCM) tools are popular options for APM
keeping track of software code; many
DevOps practitioners also track versions
Continuous
of their systems configuration with
System of Security Testing and
these tools, essentially managing
Record Testing and Validation Containerization
their infrastructure “as code.” For
Monitoring
example, it’s a common practice for
systems administrators to store and
manage their Puppet Manifests or Chef Versioning/
Cookbooks in GitHub. Source Control
Version/Source Control Tools: Git/
GitHub, Mercurial/BitBucket, Subversion
CM
Continuous Integration
and Orchestration
Continuous integration (CI) and
orchestration tools enable the integration of development code into the overall software product frequently
and early in order to mitigate potential conflicts down the line. Typically, these tools are employed to
automate software builds and testing, and are crucial for applying quality control on a continual basis (as
opposed to after the software has been developed and released). These tools can also be used to track and
manage changes for CM-- for example, Chef Cookbooks can also be stored in version control with Github. The
appropriate CI tool can then be used to test cookbooks for bugs and errors, and set up to automatically to do
so every time infrastructure changes are committed and merged.
Continuous Integration/Orchestration Tools: Travis, TeamCity, CircleCI, Drone.io
5 @UpGuard | UpGuard.com
Toolchain (continued)
Testing and Validation
Tools and frameworks for testing and validation are important for ensuring quality at all phases of development.
In many cases, unique solutions are applied to a specific aspect of testing-- for example, one tool may be
used for unit testing while another is used for integration testing. Solutions like UpGuard provide crucial
functionality for testing/validating environments, and are indispensable for troubleshooting and debugging
software applications. The platform allows one to anticipate changes and pre-validate every environment
before deployment; by generating tests directly from development and running them against the target
environment, DevOps practitioners can confidently release quality, error-free software. Combined, these
testing and validation solutions provide a consistent mechanism and format for testing application features
and behavior on both a micro and macro-level.
Testing/Validation Tools: Cucumber, Rspec, Selenium, Capybara, Coverity, UpGuard
Configuration Management (CM)
CM tools allow one to define the desired state of a system and/or environment in regards to configuration
files, software installed, users, groups and many other resource types. They also provide functionality to
automatically push changes onto specific machines, also known as automation and orchestration. Tools like
UpGuard can provide initial discovery and visibility into an infrastructure, create “golden images” for automation
tools like Puppet and Chef, and validate that results are in line with expectations, post-automation.
CM Tools: Puppet, Chef, Ansible, SaltStack, UpGuard
Containerization
Containerization essentially allows one to package up or “containerize” an application in its own environment,
making software easier to deploy and move. Such tools may often take radically different approaches to meet
this end, but achieve similar results: developers are free from infrastructure-related concerns, and operations
staff similarly need not worry about the applications being run inside the containers-- they just work. As a
lightweight alternative to virtual machines, containerization tools have gained immense popularity as of late
for testing software applications.
For example, Vagrant is a popular tool for automatically creating and configuring lightweight, reproducible,
and portable development environments. Vagrant can coordinate with a configuration management (CM)
solution to continue the process of installation where the operating system’s installer finishes, otherwise
known as provisioning. Technologies such as Docker accomplish similar functionality as Vagrant, but uses a
different approach to containerization. Tools like UpGuard can natively output to Vagrant and Docker for easy
provisioning of containers.
Containerization Tools: Docker, Vagrant, Rocker
6 @UpGuard | UpGuard.com
Toolchain (continued)
Application Performance System of Record
The cross-functional collaboration and information
Management (APM) “un-siloing” promoted by DevOps is deceptively
In contrast to testing and validation on the code level,
straightforward in theory but can be quite
APM solutions allow one to test and troubleshoot a
challenging in practice. Much of this is due to the
software application’s performance under various
sheer volume of disparate moving parts required to
conditions. For example, SaaS applications are
make the DevOps machinery operate: developers
commonly tested and monitored with APM tools
checking in/out and merging application code,
to ensure high availability, low response time, and
operations staff bringing up/down and patching
quality of service. By gauging how efficiently an
systems, and any number of continuous integration
application is utilizing system resources, developers
activities. These factors-- along with the natural
can more easily identify and resolve performance
tendency for system configurations to drift over
bottlenecks-- the net result being superior service
time-- make a single system of record for DevOps
delivery of one’s software applications.
crucial for a myriad of critical functions. This
mechanism ensures the validity and consistency of
APM Tools: New Relic, Ruxit, AppDynamics, Stackify
environment-wide configuration information, and
provides a common datasource for CM activities,
Continuous Security Testing and automation, and continuous security monitoring,
among others.
Monitoring
The importance of continually testing and monitoring
Consider activities instrumental to CM and
one’s infrastructure for vulnerabilities, configuration
automation like baselining or “golden image”
changes, and drift cannot be stressed enough.
creation: to attain a specified desired state, one
Developers may be savvy enough to avoid code-level
must have a correct reference model to work from.
security issues in an application, but ultimately the
This can be for any number of purposes: to harden
software is as vulnerable as its underlying systems
one’s infrastructure security posture, replicate
and infrastructure. Detecting and remediating
environments for testing, or to confidently automate
security flaws at all levels of the application and
provisioning; referencing a common datasource for
technology stack is therefore crucial to bolstering
systems information is necessary in these and many
a software application against security threats
other scenarios. Having a single system of record
and potential compromise. Implemented as part
enables proper visibility and validation for consistent
of the continuous integration process in ongoing
delivery of quality software and services.
software iterations, continuous security testing and
monitoring help to maintain a strong security posture
As mentioned previously, UpGuard performs a critical
throughout all phases of development. UpGuard
role in capturing desired system and environment
provides comprehensive vulnerability scanning and
states. In this capacity, it serves as the single source
monitoring to ensure that one’s infrastructure and
of record for CM, testing, and other constituent
systems are optimally poised against an evolving
components of the DevOps toolchain. UpGuard
threat landscape.
closes the feedback loop to ensure that developers
begin from the same state as production, post-
Continuous Security Testing/Monitoring Tools:
automation states are in line with expectations, and
UpGuard
infrastructures are monitored against an up-to-date,
secure “golden image.”
Tools for Establishing a System of Record : UpGuard
7 @UpGuard | UpGuard.com
Toolchain (continued)
Infrastructure changes are tracked as tickets in Examples:
Project
UpGuard and sent to your project management Jira, Asana, Pivotal
Management
tool of choice.
The requirements of current a pplications Examples:
Requirements
are available in UpGuard’s system state Word, Wikis, Spreadsheets
Gathering
documentation.
Artifacts Code and UpGuard policies are Examples:
Versioning versioned and checked in to be used in the Git, SVN
build and deployment process.
Continuous integration and d eployment tools Examples:
Continuous
use UpGuard p olicies to validate environments Jenkins, Team City, Travis,
Integration
before and after deployment. CircleCI, Drone.io
UpGuard generates manifests forconfiguration Examples:
Configuration
management tools like Puppet, Chef, Puppet, Chef, Ansible
Management
Powershell DSC, Ansible, Salt, and more.
Configuration state is continuously checked for Examples:
Monitoring deviations from baseline, much like you would Shell Scripts
with performance m onitoring.
Complete c onfiguration state is documented Examples:
Discovery and accessible for anomaly analysis and CMDBs
troubleshooting.
After confirming the system state’s health, Examples:
New Baseline UpGuard documents the new baseline for None
development.
UpGuard p rovides the f eedback mechanism Examples:
Standardize from the end of one d evelopment cycle to the None
beginning of the next.
8 @UpGuard | UpGuard.com
Conclusion
A typical DevOps toolchain might consist of the
following: UpGuard to discover and track what you have
and to determine what your environment should look
like. The platform can then output to a tool like Chef,
Puppet, or Ansible for provisioning and automation--
or directly to Docker for creating containers or Vagrant
for creating development and test environments.
Once systems changes and applications have been
deployed to production, UpGuard can validate that the
changes have indeed been rolled out successfully, as
well as provide further validation that any deployed
applications and systems are free of vulnerabilities
through comprehensive vulnerability scanning.
In the context of DevOps, the whole is truly greater
than the sum of its parts. One must be equipped
with the proper range of tools to address the unique,
ongoing challenges of continuous integration and
software delivery, and no one tool can do the job alone.
DevOps is about delivering higher quality applications
quicker and with less errors; this is accomplished
by breaking down silos between development and
operations and creating a smoother path towards
software delivery. DevOps and its underlying concepts
provide undisputed benefits to any forward-thinking
organization, and the DevOps toolchain provides
mechanisms to realize these benefits.
9 @UpGuard | UpGuard.com
The DevOps Checklist
Project Management
Requirements Gathering
Versioning
Continuous Integration
Configuration Management
APM
Log Monitoring
Discovery
New Baseline
Standardize
10 @UpGuard | UpGuard.com
Appendix
http://www.agilealliance.org/blog/2012/08/02/the-agile-root-of-devops
http://www.networkcomputing.com/networking/achieving-infrastructure-as-code/a/d-id/1318498
http://www.webopedia.com/TERM/C/containerization.html
http://www.centurylinklabs.com/what-is-docker-and-when-to-use-it/
http://www.drdobbs.com/architecture-and-design/containers-for-development/240168801
http://devops.com/blogs/automated-security-testing-continuous-delivery-pipeline/
http://devops.com/blogs/devops-critical-systems-record-systems-engagement/
11 @UpGuard | UpGuard.com