Book Image

Network Automation Cookbook

By : Karim Okasha
Book Image

Network Automation Cookbook

By: Karim Okasha

Overview of this book

Network Automation Cookbook is designed to help system administrators, network engineers, and infrastructure automation engineers to centrally manage switches, routers, and other devices in their organization's network. This book will help you gain hands-on experience in automating enterprise networks and take you through core network automation techniques using the latest version of Ansible and Python. With the help of practical recipes, you'll learn how to build a network infrastructure that can be easily managed and updated as it scales through a large number of devices. You'll also cover topics related to security automation and get to grips with essential techniques to maintain network robustness. As you make progress, the book will show you how to automate networks on public cloud providers such as AWS, Google Cloud Platform, and Azure. Finally, you will get up and running with Ansible 2.9 and discover troubleshooting techniques and network automation best practices. By the end of this book, you'll be able to use Ansible to automate modern network devices and integrate third-party tools such as NAPALM, NetBox, and Batfish easily to build robust network automation solutions.
Table of Contents (15 chapters)

Building an Ansible inventory

In this recipe, we will outline how to build an Ansible inventory to describe the infrastructure network setup that we will build across the AWS public cloud. This is a mandatory step in order to define all of our VPCs across all the regions where we will deploy our infrastructure.

How to do it...

  1. Create a new ch7_aws folder and create a hosts file inside it, as shown here:
$ cat hosts

[us]
us_prod_vpc

[eu]
eu_prod_vpc

[prod_vpcs]
us_prod_vpc
eu_prod_vpc
  1. Create the ansible.cfg file inside ch7_aws with the contents shown here:
$ cat ansible.cfg

[defaults]
inventory=hosts
vault_password_file=~/.ansible_vault_passwd
gathering=explicit
transport=local
retry_files_enabled=False
action_warnings=False...