Overview
In order to manage large-scale infrastructure, DevOps teams need to manage how servers are deployed in a repeatable and reliable fashion. Deploying servers at scale can be complex, time-consuming, and when things go wrong, the costs could be huge in losses of both customer revenue and customer trust.
This hands-on, lab-based, instructor-led course teaches exactly how to create and use an end-to-end CI/CD pipeline geared specifically for server and application deployment.
We’ll teach you Terraform from the ground up so you can define in code how to create cloud networking components and launch VM's in the cloud. Then we’ll teach you how to configure those servers using Ansible provisioners. Next, we’ll integrate Terraform and Ansible with Docker containerization, allowing the blistering fast launch of applications on your server infrastructure.
If you decide to hold a private team session of this course, an additional day can be added to teach you how to orchestrate and manage your entire containerized infrastructure with Kubernetes.
GSA: $2750 USD
Next Upcoming Course
Train up your teams with private group training
Have a group of 5 or more students? Cprime also provides specialist private training with exclusive discounts for tailored, high-impact learning.
Deploying and Automating Infrastructure at Scale Schedule
Full Course Details
Part 1 – Infrastructure Platform: AWS Cloud
- Installing and using the AWS CLI (Command Line Interface)
- AWS Networking
- VPC's (Virtual Private Clouds)
- Subnets
- Internet Gateways
- Route Tables
- Route Table Associations
- Creating AWS Networking Components
- Launching VMs in AWS Cloud
Part 2 – Git: Source Control Management: GitHub
- This course doesn't teach the basics of git. Git experience is assumed (see the 'DevOps Pipeline' course if your team needs basic git knowledge)
Part 3 – Infrastructure Deployment: Terraform
- Intro to Terraform
- Creating cloud buckets for storage
- Separating code: Multiple Terraform configuration files
- Storing state remotely
- Git branching
- Displaying resource outputs
- Creating cloud networking components with Terraform
- Configuring cloud Security groups
- Using SSH Public/Private Keys with Terraform
- Launching and Destroying cloud VM instances with Terraform
- Creating reusable code with modules
- Using Terraform variables
Part 4 – Configuration Management: Terraform with Ansible
- Ansible Provisioners in Terraform
- Integrating Terraform-managed instances with Ansible Control Nodes
- Launching multi-tiered architectures (web servers and load balancers) with Terraform and Ansible
Part 5 – Notifications: Slack
- Integrating CI/CD with Slack
- Using Slack for CI/CD approvals and notifications
Part 6 – Containerization: Docker
- Purpose and use case for Docker
- Docker Hub
- Basic Docker commands
- Docker Networking
- Launching and debugging NGINX containers
- Mounting Volumes to containers
- Docker mount points: Multiple containers, one shared code location
- Launching Docker hosts and Docker containers automatically
- Port mapping with containers
- Launching multi-tiered architectures (web servers and load balancers): an automated approach
- Customizing containers with Docker Hub and Dockerfiles
- Reducing infrastructure bloat: Buster-Slim Docker containers
Part 7 – Managed OS: Linux Only
- Management of Linux Servers only
Part 8 – Container Management: Kubernetes (Optional)
- Kubernetes (K8S) overview and use case
- K8S architecture
- Installation and configuration
- Master and node server components
- Creating K8S load-balanced clusters
- Deploying Apps with K8S
- Scaling Apps
- K8S monitoring and App repair
- Updating Apps with K8S
Required Prerequisites:
- Students should have experience with Ansible configuration management and Jenkins CI/CD, either from the Implementing a CI/CD Pipeline course or relevant work experience.
- Familiar with scripting of any kind
- Experience working at command line of Unix, Linux, or PowerShell
- Experience with a text editor of any kind
Job Titles that may find this course useful include:
- DevOps Engineers
- System Operations
- Code Developers
- Software Developers
- Quality Assurance Professionals
- Software Testers
- Product Owners
- Infrastructure Engineers
- Development Team Members
- Operations Team Members
- Project Managers
- Technical Product Managers
- Define types of networking components and types of virtual machines best for your solutions
- Use Terraform to build everything needed for an enterprise-class server architecture
- Relaunch your entire infrastructure in a different cloud region with minimum downtime
- Turn basic virtual machines launched by Terraform into web or database servers using Ansible
- Create Docker hosts
- Launch Docker containers on virtual machines using Ansible
- Build and launch container images
- Mount volumes and deploy applications using containers
- Test for reliable code before deployment
- Deploy approved code using Jenkins to a remote location such as AWS S3 or JFrog Artifactory