WSL: Difference between revisions
imported>Tetov m Clarification on task scheduling and corrected language parameters for pre/file |
imported>Tetov m Fix header hierarchy |
||
Line 27: | Line 27: | ||
== Tips and tricks == | == Tips and tricks == | ||
== Run container on startup == | === Run container on startup === | ||
To run the distro <code>NixOS</code> on Windows startup or user login in the background, proceed with following commands in PowerShell | To run the distro <code>NixOS</code> on Windows startup or user login in the background, proceed with following commands in PowerShell |
Revision as of 12:00, 11 March 2024
Notes on running NixOS on the Windows Subsystem for Linux (WSL, WSL2)
Setup
Ensure that WSL is installed and up to date
wsl --update
NixOS is not yet packaged as a official WSL distribution or on the Microsoft store. Download the latest release of nixos-wsl.tar.gz
from the NixOS-WSL Github page.
Import the WSL container using PowerShell
wsl --import NixOS .\NixOS\ nixos-wsl.tar.gz --version 2
Usage
Start it with PowerShell
wsl -d NixOS
Tips and tricks
Run container on startup
To run the distro NixOS
on Windows startup or user login in the background, proceed with following commands in PowerShell
echo "" > $HOME\run_wsl2_at_startup.vbs
notepad $HOME\run_wsl2_at_startup.vbs
Inside the script we define NixOS
as the distribution name, as imported in the setup step above
$HOME\run_wsl2_at_startup.vbs
set object = createobject("wscript.shell")
object.run "wsl.exe --distribution NixOS", 0
Execute following command to open the task planer
taskschd.msc
Click on Create task
on the right pane, set name to WSL
. On the tab "Triggers" click on "New ..." and select run task on user login in the dropdown menu. On the tab "Action" click on "New ..." and insert as command: %USERPROFILE%\run_wsl2_at_startup.vbs