release/2024-10-18: Fixes from Docker meeting
Signed-off-by: Dave Richer <dave@imexsystems.ca>
This commit is contained in:
@@ -4,139 +4,16 @@ This guide will walk you through the steps to configure your WSL2 (Windows Subsy
|
|||||||
|
|
||||||
## Prerequisites
|
## Prerequisites
|
||||||
|
|
||||||
1. **Windows 10/11** with **WSL2** installed.
|
1. **Windows 11**
|
||||||
2. **Hyper-V** enabled on your system. If not, follow these steps to enable it:
|
2. **Docker Desktop For Windows (Latest Version)
|
||||||
- Open PowerShell as Administrator and run:
|
|
||||||
```powershell
|
|
||||||
dism.exe /Online /Enable-Feature /All /FeatureName:Microsoft-Hyper-V
|
|
||||||
```
|
|
||||||
- Restart your computer.
|
|
||||||
|
|
||||||
3. A basic understanding of networking and WSL2 configuration.
|
# Docker Setup
|
||||||
|
Inside the root of the project exists the `docker-compose.yaml` file, you can simply run
|
||||||
|
`docker-compose up` to launch the backend.
|
||||||
|
|
||||||
---
|
Things to note:
|
||||||
|
- When installing NPM packages, you will need to rebuild the `node-app` container
|
||||||
## Step 1: Create an External Hyper-V Switch
|
- Making changes to the server files will restart the `node-app`
|
||||||
|
|
||||||
1. **Open Hyper-V Manager**:
|
|
||||||
- Press `Windows Key + X`, select `Hyper-V Manager`.
|
|
||||||
|
|
||||||
2. **Create a Virtual Switch**:
|
|
||||||
- In the right-hand pane, click `Virtual Switch Manager`.
|
|
||||||
- Choose `External` and click `Create Virtual Switch`.
|
|
||||||
- Select your external network adapter (this is usually your Ethernet or Wi-Fi adapter).
|
|
||||||
- Give the switch a name (e.g., `WSL External Switch`), then click `Apply` and `OK`.
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
## Step 2: Configure WSL2 to Use the External Hyper-V Switch
|
|
||||||
|
|
||||||
Now that you've created the external virtual switch, follow these steps to configure your WSL2 instance to use this switch.
|
|
||||||
|
|
||||||
1. **Set WSL2 to Use the External Switch**:
|
|
||||||
- By default, WSL2 uses NAT to connect to your local network. You need to configure WSL2 to use the external Hyper-V switch instead.
|
|
||||||
|
|
||||||
2. **Check WSL2 Networking**:
|
|
||||||
- Inside WSL, run:
|
|
||||||
```bash
|
|
||||||
ip a
|
|
||||||
```
|
|
||||||
- You should see an IP address in the range of your local network (e.g., `192.168.x.x`).
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
## Step 3: Configure a Static IP Address for WSL2
|
|
||||||
|
|
||||||
Once WSL2 is connected to the external network, you can assign a static IP address to your WSL2 instance.
|
|
||||||
|
|
||||||
1. **Open WSL2** and Edit the Network Configuration:
|
|
||||||
- Depending on your Linux distribution, the file paths may vary, but typically for Ubuntu-based systems:
|
|
||||||
```bash
|
|
||||||
sudo nano /etc/netplan/01-netcfg.yaml
|
|
||||||
```
|
|
||||||
- If this file doesn’t exist, create a new file or use the correct configuration file path.
|
|
||||||
|
|
||||||
2. **Configure Static IP**:
|
|
||||||
- Add or update the following configuration:
|
|
||||||
```yaml
|
|
||||||
network:
|
|
||||||
version: 2
|
|
||||||
renderer: networkd
|
|
||||||
ethernets:
|
|
||||||
eth0:
|
|
||||||
dhcp4: no
|
|
||||||
addresses:
|
|
||||||
- 192.168.1.100/24 # Choose an IP address in your network range
|
|
||||||
gateway4: 192.168.1.1 # Your router's IP address
|
|
||||||
nameservers:
|
|
||||||
addresses:
|
|
||||||
- 8.8.8.8
|
|
||||||
- 8.8.4.4
|
|
||||||
```
|
|
||||||
- Adjust the values according to your local network settings:
|
|
||||||
- `addresses`: This is the static IP you want to assign.
|
|
||||||
- `gateway4`: This should be the IP address of your router.
|
|
||||||
- `nameservers`: These are DNS servers, you can use Google's public DNS or any other DNS provider.
|
|
||||||
|
|
||||||
3. **Apply the Changes**:
|
|
||||||
- Run the following command to apply the network configuration:
|
|
||||||
```bash
|
|
||||||
sudo netplan apply
|
|
||||||
```
|
|
||||||
|
|
||||||
4. **Verify the Static IP**:
|
|
||||||
- Check if the static IP is correctly set by running:
|
|
||||||
```bash
|
|
||||||
ip a
|
|
||||||
```
|
|
||||||
- You should see the static IP you configured (e.g., `192.168.1.100`) on the appropriate network interface (usually `eth0`).
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
## Step 4: Restart WSL2 to Apply Changes
|
|
||||||
|
|
||||||
To ensure the changes are fully applied, restart WSL2:
|
|
||||||
|
|
||||||
1. Open PowerShell or Command Prompt and run:
|
|
||||||
```powershell
|
|
||||||
wsl --shutdown
|
|
||||||
2. Then, start your WSL2 instance again.
|
|
||||||
|
|
||||||
## Step 5: Verify Connectivity
|
|
||||||
|
|
||||||
1. Check Internet and Local Network Connectivity:
|
|
||||||
- Run a ping command from within WSL to verify that it can reach the internet: ```ping 8.8.8.8```
|
|
||||||
2. Test Access from other Devices:
|
|
||||||
- If you're running services inside WSL (e.g., a web server), ensure they are accessible from other devices on your local network using the static IP address you configured (e.g., `http://192.168.1.100:4000`).
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Configuring `vm.overcommit_memory` in sysctl for WSL2
|
|
||||||
|
|
||||||
To prevent memory overcommitment issues and optimize performance, you can configure the `vm.overcommit_memory` setting in WSL2. This is particularly useful when running Redis or other memory-intensive services inside WSL2, as it helps control how the Linux kernel handles memory allocation.
|
|
||||||
|
|
||||||
### 1. **Open the sysctl Configuration File**:
|
|
||||||
To set the `vm.overcommit_memory` value, you'll need to edit the sysctl configuration file. Inside your WSL2 instance, run the following command to open the `sysctl.conf` file for editing:
|
|
||||||
```bash
|
|
||||||
sudo nano /etc/sysctl.conf
|
|
||||||
```
|
|
||||||
### 2. Add the Overcommit Memory Setting:
|
|
||||||
Add the following line at the end of the file to allow memory overcommitment:
|
|
||||||
```bash
|
|
||||||
vm.overcommit_memory = 1
|
|
||||||
```
|
|
||||||
|
|
||||||
This setting tells the Linux kernel to always allow memory allocation, regardless of how much memory is available, which can prevent out-of-memory errors when running certain applications.
|
|
||||||
|
|
||||||
### 3. Apply the Changes:
|
|
||||||
After editing the file, save it and then apply the new sysctl configuration by running:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo sysctl -p
|
|
||||||
```
|
|
||||||
|
|
||||||
# Install Docker and Docker Compose in WSL2
|
|
||||||
- https://docs.docker.com/desktop/wsl/
|
|
||||||
|
|
||||||
# Local Stack
|
# Local Stack
|
||||||
- LocalStack Front end (Optional) - https://apps.microsoft.com/detail/9ntrnft9zws2?hl=en-us&gl=US
|
- LocalStack Front end (Optional) - https://apps.microsoft.com/detail/9ntrnft9zws2?hl=en-us&gl=US
|
||||||
|
|||||||
Reference in New Issue
Block a user