Book Image

Windows Subsystem for Linux 2 (WSL 2) Tips, Tricks, and Techniques

By : Stuart Leeks
Book Image

Windows Subsystem for Linux 2 (WSL 2) Tips, Tricks, and Techniques

By: Stuart Leeks

Overview of this book

Windows Subsystem for Linux (WSL) allows you to run native Linux tools alongside traditional Windows applications. Whether you’re developing applications across multiple operating systems or looking to add more tools to your Windows environment, WSL offers endless possibilities. You’ll start by understanding what WSL is and learn how to install and configure WSL along with different Linux distros. Next, you'll learn techniques that allow you to work across both Windows and Linux environments. You’ll discover how to install and customize the new Windows Terminal. We'll also show you how to work with code in WSL using Visual Studio Code (VS Code). In addition to this, you’ll explore how to work with containers with Docker and Kubernetes, and how to containerize a development environment using VS Code. While Microsoft has announced support for GPU and GUI applications in an upcoming release of WSL, at the time of writing these features are either not available or only in early preview releases. This book focuses on the stable, released features of WSL and giving you a solid understanding of the amazing techniques that you can use with WSL today. By the end of this book, you’ll be able to configure WSL and Windows Terminal to suit your preferences, and productively use Visual Studio Code for developing applications with WSL.
Table of Contents (16 chapters)
1
Section 1: Introduction, Installation, and Configuration
5
Section 2:Windows and Linux – A Winning Combination
11
Section 3: Developing with the Windows Subsystem for Linux

Introducing orchestrators

In the previous section, we saw how we can use the capabilities of Docker to easily package our application as a container image and run it. If we push our image to a Docker registry, then it becomes simple to pull and run that application from any machine with Docker installed. Larger systems, however, are made up of many such components and we will likely want to distribute these across a number of Docker hosts. This allows us to adapt to a changing load on the system by increasing or decreasing the number of instances of a component container that are running. The way to get these features with a containerized system is to use an orchestrator. Orchestrators provide other features, such as automatically restarting failed containers, running containers on a different host if a host fails, and a stable way to communicate with containers as they potentially restart and move between hosts.

There are a number of container orchestrators, such as Kubernetes...