Chef Infrastructure Automation Cookbook - Second Edition
()
About this ebook
- Automate error-prone and tedious manual tasks and manage your servers on-site or in the cloud
- Equip yourself with Chef components such as Chef client and solo, and learn how to create simple Chef cookbooks and various other artifacts for managing systems with Chef when live
- Packed with working code and easy-to-follow, step-by-step instructions to configure, deploy, and scale your applications
This book is for system engineers and administrators who have a fundamental understanding of information management systems and infrastructure. It helps if you've already played around with Chef; however, this book covers all the important topics you will need to know. If you don't want to dig through a whole book before you can get started, this book is for you, as it features a set of independent recipes you can try out immediately.
Related to Chef Infrastructure Automation Cookbook - Second Edition
Related ebooks
Alfresco 3 Cookbook Rating: 0 out of 5 stars0 ratingsOpenShift Cookbook Rating: 0 out of 5 stars0 ratingsOracle Service Bus 11g Development Cookbook Rating: 0 out of 5 stars0 ratingsElasticsearch 5.x Cookbook - Third Edition Rating: 0 out of 5 stars0 ratingsPostgreSQL 9 Administration Cookbook - Second Edition Rating: 0 out of 5 stars0 ratingsWildFly Cookbook Rating: 0 out of 5 stars0 ratingsAngularJS Web Application Development Cookbook Rating: 0 out of 5 stars0 ratingsSoftware-Defined Networking SDN production A Complete Guide - 2019 Edition Rating: 0 out of 5 stars0 ratingsKubernetes Secrets Management Rating: 0 out of 5 stars0 ratingsSOA Governance in Action: REST and WS-* Architectures Rating: 0 out of 5 stars0 ratingsSonar Code Quality Testing Essentials Rating: 0 out of 5 stars0 ratingsSoftware architecture A Complete Guide - 2019 Edition Rating: 0 out of 5 stars0 ratingsChaos Engineering A Clear and Concise Reference Rating: 0 out of 5 stars0 ratingsScrum Release Management: Successful Combination of Scrum, Lean Startup, and User Story Mapping Rating: 0 out of 5 stars0 ratingsCassandra High Availability Rating: 5 out of 5 stars5/5Making Sense of Agile Project Management: Balancing Control and Agility Rating: 0 out of 5 stars0 ratingsDevOps Tools Standard Requirements Rating: 0 out of 5 stars0 ratingsRestlet in Action: Developing RESTful web APIs in Java Rating: 0 out of 5 stars0 ratingsPractical OneOps Rating: 0 out of 5 stars0 ratingsMastering Cloud-Native Microservices: Designing and implementing Cloud-Native Microservices for Next-Gen Apps (English Edition) Rating: 0 out of 5 stars0 ratingsGetting Started with Hazelcast - Second Edition Rating: 0 out of 5 stars0 ratingsDeveloping Web Services with Java APIs for XML Using WSDP Rating: 0 out of 5 stars0 ratingsPodman in Action: Secure, rootless containers for Kubernetes, microservices, and more Rating: 0 out of 5 stars0 ratingsDatabase Security A Complete Guide - 2020 Edition Rating: 0 out of 5 stars0 ratingsOpenID Connect A Clear and Concise Reference Rating: 0 out of 5 stars0 ratingsKubernetes A Complete Guide Rating: 0 out of 5 stars0 ratingsSOA-Based Enterprise Integration: A Step-by-Step Guide to Services-based Application Rating: 0 out of 5 stars0 ratingsSOA Governance A Complete Guide - 2019 Edition Rating: 0 out of 5 stars0 ratingsMicroservices Architectures A Complete Guide - 2019 Edition Rating: 0 out of 5 stars0 ratings
Networking For You
Mike Meyers' CompTIA Network+ Certification Passport, Sixth Edition (Exam N10-007) Rating: 1 out of 5 stars1/5Networking All-in-One For Dummies Rating: 5 out of 5 stars5/5Linux Bible Rating: 0 out of 5 stars0 ratingsNetworking For Dummies Rating: 5 out of 5 stars5/5Practical Ethical Hacking from Scratch Rating: 5 out of 5 stars5/5SharePoint For Dummies Rating: 0 out of 5 stars0 ratingsAWS Certified Cloud Practitioner Study Guide: CLF-C01 Exam Rating: 5 out of 5 stars5/5Network+ Study Guide & Practice Exams Rating: 4 out of 5 stars4/5CompTIA Network+ Certification Guide (Exam N10-008): Unleash your full potential as a Network Administrator (English Edition) Rating: 0 out of 5 stars0 ratingsQuantum Computing For Dummies Rating: 0 out of 5 stars0 ratingsHacking Android Rating: 4 out of 5 stars4/5CompTIA Network+ Practice Tests: Exam N10-008 Rating: 0 out of 5 stars0 ratingsThe Compete Ccna 200-301 Study Guide: Network Engineering Edition Rating: 5 out of 5 stars5/5Windows Command Line Administration Instant Reference Rating: 0 out of 5 stars0 ratingsCCNA Certification Study Guide, Volume 2: Exam 200-301 Rating: 0 out of 5 stars0 ratingsCompTIA Network+ Certification Study Guide: Exam N10-004: Exam N10-004 2E Rating: 4 out of 5 stars4/5Cybersecurity: The Beginner's Guide: A comprehensive guide to getting started in cybersecurity Rating: 5 out of 5 stars5/5Earning Money through Crypto Currency Airdrops, Faucets, Cloud Mining, Online Trading and Online Advertisements Rating: 0 out of 5 stars0 ratingsUnlock Any Roku Device: Watch Shows, TV, & Download Apps Rating: 0 out of 5 stars0 ratingsCisco Networking All-in-One For Dummies Rating: 4 out of 5 stars4/5Applied Network Security Monitoring: Collection, Detection, and Analysis Rating: 3 out of 5 stars3/5Raspberry Pi Electronics Projects for the Evil Genius Rating: 3 out of 5 stars3/5Cisco Packet Tracer for Beginners Rating: 5 out of 5 stars5/5The Windows Command Line Beginner's Guide: Second Edition Rating: 4 out of 5 stars4/5MCA Microsoft Certified Associate Azure Administrator Study Guide: Exam AZ-104 Rating: 0 out of 5 stars0 ratingsAmazon Web Services (AWS) Interview Questions and Answers Rating: 5 out of 5 stars5/5Programming Arduino: Getting Started with Sketches Rating: 4 out of 5 stars4/5Home Networking Do-It-Yourself For Dummies Rating: 4 out of 5 stars4/5
Reviews for Chef Infrastructure Automation Cookbook - Second Edition
0 ratings0 reviews
Book preview
Chef Infrastructure Automation Cookbook - Second Edition - Matthias Marschall
Table of Contents
Chef Infrastructure Automation Cookbook Second Edition
Credits
About the Author
About the Reviewers
www.PacktPub.com
Support files, eBooks, discount offers, and more
Why subscribe?
Free access for Packt account holders
Preface
What this book covers
What you need for this book
Who this book is for
Sections
Getting ready
How to do it…
How it works…
There's more…
See also
Conventions
Reader feedback
Customer support
Errata
Piracy
Questions
1. Chef Infrastructure
Introduction
Using version control
Getting ready
How to do it...
How it works...
There's more...
See also
Installing the Chef development kit on your workstation
How to do it...
How it works...
See also
Using the hosted Chef platform
Getting ready
How to do it...
How it works...
There's more...
See also
Managing virtual machines with Vagrant
Getting ready
How to do it...
How it works...
There's more...
See also
Creating and using cookbooks
Getting ready
How to do it...
How it works...
See also
Inspecting files on your Chef server with knife
Getting ready
How to do it...
How it works...
There's more...
See also
Defining cookbook dependencies
Getting ready
How to do it...
How it works...
There's more...
See also
Managing cookbook dependencies with Berkshelf
Getting ready
How to do it...
How it works...
There's more...
See also
Downloading and integrating cookbooks as vendor branches into your Git repository
Getting ready
How to do it...
How it works...
There's more...
See also
Using custom knife plugins
Getting ready
How to do it...
How it works...
There's more...
See also
Deleting a node from the Chef server
Getting ready
How to do it...
How it works...
There's more...
See also
Developing recipes with local mode
Getting ready
How to do it...
How it works...
There's more...
Running knife in local mode
Moving to hosted Chef or your own Chef server
See also
Using roles
Getting ready
How to do it...
How it works...
See also
Using environments
Getting ready
How to do it...
How it works...
There's more...
See also
Freezing cookbooks
Getting ready
How to do it...
How it works...
There's more...
See also
Running Chef client as a daemon
Getting ready
How to do it...
How it works...
There's more...
Using chef-shell
How to do it...
How it works...
There's more...
See also
2. Evaluating and Troubleshooting Cookbooks and Chef Runs
Introduction
Testing your Chef cookbooks
Getting ready
How to do it...
How it works...
There's more...
See also
Flagging problems in your Chef cookbooks
Getting ready
How to do it...
How it works...
There's more...
See also
Test-driven development for cookbooks using ChefSpec
Getting ready
How to do it...
How it works...
There's more...
See also
Integration testing your Chef cookbooks with Test Kitchen
Getting ready
How to do it...
How it works...
There's more...
See also
Showing affected nodes before uploading cookbooks
Getting ready
How to do it...
How it works...
See also
Overriding a node's run list to execute a single recipe
Getting ready
How to do it...
How it works...
See also
Using why-run mode to find out what a recipe might do
Getting ready
How to do it...
How it works...
See also
Debugging Chef client runs
Getting ready
How to do it...
How it works...
There's more...
See also
Inspecting the results of your last Chef run
Getting ready
How to do it...
How it works...
See also
Raising and logging exceptions in recipes
Getting ready
How to do it...
How it works...
There's more...
See also
Diff-ing cookbooks with knife
Getting ready
How to do it...
How it works...
There's more...
See also
Using community exception and report handlers
Getting ready
How to do it...
How it works...
There's more...
See also
Creating custom handlers
Getting ready...
How to do it...
How it works...
There's more...
See also
3. Chef Language and Style
Introduction
Using community Chef style
Getting ready
How to do it...
How it works...
There's more...
See also
Using attributes to dynamically configure recipes
Getting ready
How to do it...
How it works...
There's more...
Calculating values in the attribute files
See also
Using templates
Getting ready
How to do it...
How it works...
There's more...
See also
Mixing plain Ruby with Chef DSL
Getting ready
How to do it...
How it works...
There's more...
See also
Installing Ruby gems and using them in recipes
Getting ready
How to do it...
How it works...
See also
Using libraries
Getting ready
How to do it...
How it works...
There's more...
See also
Using definitions
Getting ready
How to do it...
How it works...
There's more...
See also
Creating your own Lightweight Resource Providers (LWRP)
Getting ready
How to do it...
How it works...
There's more...
See also
Extending community cookbooks by using application wrapper cookbooks
Getting ready
How to do it...
How it works...
There's more...
See also
Creating custom Ohai plugins
Getting ready
How to do it...
How it works...
There's more...
See also
Creating custom knife plugins
Getting ready
How to do it...
How it works...
There's more...
See also
4. Writing Better Cookbooks
Introduction
Setting the environment variables
Getting ready
How to do it...
How it works...
There's more...
See also
Passing arguments to shell commands
Getting ready
How to do it...
How it works...
There's more...
See also
Overriding attributes
Getting ready
How to do it...
How it works...
There's more...
See also
Using search to find nodes
Getting ready
How to do it...
How it works...
There's more...
Using knife to search for nodes
Searching for arbitrary node attributes
Using Boolean operators in search
See also
Using data bags
Getting ready
How to do it...
How it works...
See also
Using search to find data bag items
Getting ready
How to do it...
How it works...
There's more...
See also
Using encrypted data bag items
Getting ready
How to do it...
How it works...
There's more...
Using a private key file
See also
Accessing data bag values from external scripts
Getting ready
How to do it...
How it works...
There's more...
See also
Getting information about the environment
Getting ready
How to do it...
How it works...
There's more...
See also
Writing cross-platform cookbooks
Getting ready
How to do it...
How it works...
There's more...
Avoiding case statements to set values based on the platform
Declaring support for specific operating systems in your cookbook's metadata
See also
Finding the complete list of operating systems you can use in cookbooks
How to do it...
How it works...
There's more...
See also
Making recipes idempotent by using conditional execution
Getting ready
How to do it...
How it works...
There's more...
See also
5. Working with Files and Packages
Introduction
Creating configuration files using templates
Getting ready
How to do it...
How it works...
There's more...
See also
Using pure Ruby in templates for conditionals and iterations
Getting ready
How to do it...
How it works...
There's more...
See also
Installing packages from a third-party repository
Getting ready
How to do it...
How it works...
See also
Installing software from source
Getting ready
How to do it...
How it works...
There's more...
See also
Running a command when a file is updated
Getting ready
How to do it...
How it works...
There's more...
See also
Distributing directory trees
Getting ready
How to do it...
How it works...
There's more...
See also
Cleaning up old files
Getting ready
How to do it...
How it works...
There's more...
See also
Distributing different files based on the target platform
Getting ready
How to do it...
How it works...
See also
6. Users and Applications
Introduction
Creating users from data bags
Getting ready
How to do it...
How it works...
There's more...
See also
Securing the Secure Shell Daemon (SSHD)
Getting ready
How to do it...
How it works...
There's more...
See also
Enabling passwordless sudo
Getting ready
How to do it...
How it works...
There's more...
See also
Managing NTP
Getting ready
How to do it...
How it works...
There's more...
See also
Managing nginx
Getting ready
How to do it...
How it works...
There's more...
See also
Creating nginx virtual hosts
Getting ready
How to do it...
How it works...
There's more...
See also
Creating MySQL databases and users
Getting ready
How to do it...
How it works...
There's more...
See also
Managing WordPress sites
Getting ready
How to do it...
How it works...
There's more...
See also
Managing Ruby on Rails applications
Getting ready
How to do it...
How it works...
There's more...
See also
Managing Varnish
Getting ready
How to do it...
How it works...
There's more...
See also
Managing your local workstation
Getting ready
How to do it...
How it works...
There's more...
See also
7. Servers and Cloud Infrastructure
Introduction
Creating your infrastructure using Chef Provisioning
Getting ready
How to do it...
How it works...
There's more...
See also
Creating cookbooks from a running system with Blueprint
Getting ready
How to do it...
How it works...
There's more...
See also
Running the same command on many machines at once
How to do it...
How it works...
There's more...
See also
Setting up SNMP for external monitoring services
Getting ready
How to do it...
How it works...
There's more...
See also
Deploying a Nagios monitoring server
Getting ready
How to do it...
How it works...
There's more...
See also
Building high-availability services using heartbeat
Getting ready
How to do it...
How it works...
There's more...
See also
Using HAProxy to load-balance multiple web servers
Getting ready
How to do it...
How it works...
See also
Using custom bootstrap scripts
Getting ready
How to do it...
How it works...
There's more...
See also
Managing firewalls with iptables
Getting ready
How to do it...
How it works...
See also
Managing fail2ban to ban malicious IP addresses
Getting ready
How to do it...
How it works...
There's more...
See also
Managing Amazon EC2 instances
Getting ready
How to do it...
How it works...
There's more...
See also
Loading your Chef infrastructure from a file with spiceweasel and knife
Getting ready
How to do it...
How it works...
There's more...
See also
Index
Chef Infrastructure Automation Cookbook Second Edition
Chef Infrastructure Automation Cookbook Second Edition
Copyright © 2015 Packt Publishing
All rights reserved. No part of this book may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, without the prior written permission of the publisher, except in the case of brief quotations embedded in critical articles or reviews.
Every effort has been made in the preparation of this book to ensure the accuracy of the information presented. However, the information contained in this book is sold without warranty, either express or implied. Neither the author nor Packt Publishing, and its dealers and distributors will be held liable for any damages caused or alleged to be caused directly or indirectly by this book.
Packt Publishing has endeavored to provide trademark information about all of the companies and products mentioned in this book by the appropriate use of capitals. However, Packt Publishing cannot guarantee the accuracy of this information.
First published: August 2013
Second edition: May 2015
Production reference: 1260515
Published by Packt Publishing Ltd.
Livery Place
35 Livery Street
Birmingham B3 2PB, UK.
ISBN 978-1-78528-794-7
www.packtpub.com
Credits
Author
Matthias Marschall
Reviewers
Robert Curth
Kristian Hoffmann
Max Manders
Greg Swallow
Earl Waud
Commissioning Editor
Ashwin Nair
Acquisition Editor
Vinay Argekar
Content Development Editor
Rohit Kumar Singh
Technical Editor
Naveenkumar Jain
Copy Editor
Adithi Shetty
Project Coordinator
Izzat Contractor
Proofreaders
Stephen Copestake
Safis Editing
Indexer
Priya Sane
Production Coordinator
Komal Ramchandani
Cover Work
Komal Ramchandani
About the Author
Matthias Marschall is a software engineer Made in Germany
and the author of the Chef Infrastructure Automation Cookbook by Packt Publishing. His four children make sure that he feels comfortable and stays in control of chaotic situations. A lean and Agile engineering lead, he's passionate about continuous delivery, infrastructure automation, and all things DevOps.
In recent years, Matthias has helped build several web-based businesses, first with Java and then with Ruby on Rails. He quickly moved into system administration, writing his own configuration management tool before moving his whole infrastructure to Chef in its early days.
In 2008, he started a blog (http://www.agileweboperations.com) with Dan Ackerson. There, they shared their ideas about DevOps since the early days of the continually emerging movement. You can find him on Twitter at @mmarschall.
Matthias is the CTO of www.gutefrage.net GmbH that helps run Germany's biggest Q&A site among other high traffic sites. He holds a master's degree in computer science [Dipl.-Inf. (FH)] and teaches courses on Agile software development at the University of Augsburg.
When not writing or coding, Matthias enjoys drawing cartoons and playing Go. He lives near Munich, Germany.
Thanks go to my colleagues at gutefrage.net for all those valuable discussions.
I would also like to thank Adam Jacob, Joshua Timberman, and all the other great people at Chef, Inc. for your help with this book.
Special thanks go to my reviewers, Earl Waud, Greg Swallow, Max Manders, and Robert Curth, who made this book so much better.
About the Reviewers
Robert Curth is an engineer at gutefrage gruppe. In his current project, HELPSTER, Chef is used to automate the server setup. When Robert is not programming, he organizes company events and talks about how to live a good life on his blog at http://rocu.de.
I want to thank all the amazing authors of Chef cookbooks and tools. Chef has come a long way since the first edition of this book!
Thanks, Matthias, for updating this book. I love how elegant many of these recipes are. I hope you, dear reader, enjoy them as much as I did!
Kristian Hoffmann is the sort of twisted individual who likes hacking code (in Perl, if possible) and cars (the smaller and faster, the better) and solving problems that would lead other people to throw their hands up in despair. After some early experimentation with Linux (circa Slackware 3.0), his tech career started as a lowly tech at a local ISP. He went on to complete his bachelor's in computer science, marry a fellow technophile, and rise to the ranks of the president/CTO in his adolescent ISP hacking grounds. He now enjoys the most significant challenge of raising two hopelessly tech-bound children.
Max Manders is a recovering PHP developer and former sysadmin, who currently works as a systems developer and ops engineer helping to run the Operations Centre for Cloudreach, an Amazon Web Services Premier Consulting Partner. Max has put his past experiences and skills to good use to evangelize all things DevOps, working to master Ruby and advocating infrastructure-as-code as a Chef practitioner.
Max is a cofounder and organizer of Whisky Web, a Scottish conference for the web development and ops community. When he's not writing code or tinkering with the latest and greatest monitoring and operations tools, Max enjoys the odd whisky and playing jazz and funk trombone. He lives in Edinburgh with his wife, Jo, and their cats, Ziggy and Maggie.
It's been an absolute pleasure to have the opportunity to provide a technical review of this book. I hope you enjoy reading it as much as I did! Thank you, Jo, for putting up with my mutterings and ignorance while I tinkered with the code in this book. And thank you, Shona, for sharing the load at work, affording me time to get this done!
Greg Swallow has been wrangling with all sorts of computers in the Indianapolis area for 20 years now, for folks like IN.gov, Expedient Data Centers, Salesforce, and Indigo BioAutomation. When he's not playing digital plumber, you can catch him on the roads and trails of Indiana, either on his bike or in his running shoes.
He has also reviewed VMware vSphere 5.x Datacenter Design Cookbook by Hersey Cartwright, Packt Publishing.
I would also like to thank Packt Publishing for offering me the opportunity to review this and other books. It's been fun!
Earl Waud is a Virtualization Development Professional with more than 9 years of focused industry experience creating innovative solutions for hypervisor provisioning, management, and automation. He is an expert in aligning engineering strategy with organizational vision and goals and delivering highly scalable and user-friendly virtualization environments.
With more than 20 years of experience developing customer-facing and corporate IT software solutions, Earl has a proven track record of delivering high-caliber and on-time technology solutions that significantly impact business results.
Earl lives in San Diego, California. He is blessed with a beautiful wife, Patti, and three amazing daughters, Madison, Daniella, and Alexis.
Thank you, my wonderful family, for allowing me to spend some of our precious family time to review this book. I love you and appreciate you, and I know I am truly blessed that you are my family.
Currently, Earl is a senior systems engineer with Intuit Inc., a company that creates business and financial management solutions that simplify the business of life for small businesses, consumers, and accounting professionals.
Earl can be reached online at http://sandiegoearl.com.
www.PacktPub.com
Support files, eBooks, discount offers, and more
For support files and downloads related to your book, please visit www.PacktPub.com.
Did you know that Packt offers eBook versions of every book published, with PDF and ePub files available? You can upgrade to the eBook version at www.PacktPub.com and as a print book customer, you are entitled to a discount on the eBook copy. Get in touch with us at
At www.PacktPub.com, you can also read a collection of free technical articles, sign up for a range of free newsletters and receive exclusive discounts and offers on Packt books and eBooks.
https://www2.packtpub.com/books/subscription/packtlib
Do you need instant solutions to your IT questions?