How To Create Development Environments With Nix-shell In Linux
Nix-shell: Streamline Your Development Workflow with Isolated Environments
Tired of juggling conflicting software versions across different projects? Nix-shell offers a powerful solution! This tool lets you create isolated development environments, each tailored to a specific project's needs, ensuring a smooth and conflict-free workflow.
These isolated environments prevent interference between projects, eliminating the frustrating "dependency hell" often encountered when software versions clash. Nix-shell simplifies environment creation and switching, ensuring consistent setups across various machines and boosting team collaboration efficiency.
This guide provides a step-by-step walkthrough of creating and managing isolated development environments using Nix-shell on Linux.
Table of Contents
- Benefits of Using Nix-shell
- Creating and Managing Development Environments with Nix-shell
- Defining Dependencies with a Nix Expression
- Quick, Ad-hoc Environments
- Accessing the Nix Shell
- Working within the Nix Shell
- Exiting the Nix Shell
- Defining Dependencies with a Nix Expression
- Frequently Asked Questions (FAQ)
- Conclusion
What is Nix-shell?
Nix is a robust package manager and build system employing a functional and declarative approach to dependency management. It treats packages as values within a functional programming paradigm.
Nix-shell, a command-line tool bundled with the Nix package manager, leverages Nix expressions to generate isolated development environments. These environments encapsulate all necessary tools, libraries, and dependencies for a given project.
By independently building each dependency and preventing interference, Nix-shell eradicates "dependency hell" and provides granular control over dependencies in both development and production settings. This isolation and reproducibility guarantee consistent setups across different systems and facilitate seamless developer collaboration.
Benefits of Using Nix-shell
- Isolation: Each Nix-shell environment is isolated from your system and other environments, preventing dependency conflicts.
- Reproducibility: Environments are defined in code, ensuring consistent reproduction on any system running Nix.
- Atomic Upgrades and Rollbacks: Nix supports atomic upgrades and rollbacks, enabling safe experimentation with dependencies.
- Testing without Installation: Test packages without local installation, ideal for temporary application use.
Creating and Managing Development Environments with Nix-shell
Nix-shell creates separate, reproducible environments to manage project dependencies, preventing conflicts.
Defining Dependencies with a Nix Expression
First, create a Nix expression defining your project's dependencies. This is typically a file named default.nix or shell.nix in your project's root directory.
Let's create a sample project, myproject:
$ mkdir myproject $ cd myproject $ nano shell.nix
Add the following to shell.nix:
{ pkgs ? import <nixpkgs> {} }:
pkgs.mkShell {
buildInputs = [
pkgs.python38
pkgs.nodejs
pkgs.ruby
];
}</nixpkgs>
This defines an environment with Python 3.8, Node.js, and Ruby. Running nix-shell in this directory will install these in isolation.
A more concise version:
{ pkgs ? import <nixpkgs> {} }: pkgs.mkShell { buildInputs = with pkgs.buildPackages; [ python38 nodejs ruby ]; }</nixpkgs>
Save and close the file.
Quick, Ad-hoc Environments
For temporary environments, use
nix-shell -p package1 package2 .... For example:nix-shell -p python39Packages.numpy python39Packages.scipy
Accessing the Nix Shell
Enter the isolated environment using:
$ nix-shell
or
$ nix-shell shell.nix
For maximum isolation, use --pure:
$ nix-shell --pure shell.nix
This creates a shell session with the specified dependencies.
Working within the Nix Shell
Within the Nix-shell environment, use your development tools as usual. The isolated environment ensures consistent dependencies regardless of the host system.
Verify the installed versions:
[nix-shell:~/myproject]$ python -V [nix-shell:~/myproject]$ node -v [nix-shell:~/myproject]$ ruby -v

Exiting the Nix Shell
Exit using exit or CTRL D. Exiting removes the temporary environment, reverting shell settings to their previous state without affecting your system. Project files remain unchanged. Unused packages in the Nix store can be removed via garbage collection (nix-collect-garbage -d).
Frequently Asked Questions (FAQ)
Q: What is nix-shell? A: A command-line tool creating temporary, isolated shell environments with specific software packages.
Q: How do I install it? A: It's part of the Nix package manager; install Nix first.
Q: How do I create an isolated environment? A: Use a shell.nix file specifying dependencies, or use nix-shell -p ... for ad-hoc environments.
Q: What OSes does it support? A: Most Unix-like systems (Linux, macOS); Windows users can use WSL.
Q: What happens on exit? A: The environment is removed; shell settings revert; project files remain.
Q: How does it avoid "dependency hell"? A: Nix's functional approach ensures isolated package builds, preventing conflicts.
Q: Can I save the environment state? A: The shell.nix file is reproducible; for more complex scenarios, explore Nix's package and configuration capabilities.
Q: How do I add/remove packages? A: Modify the shell.nix file's buildInputs list or adjust the -p flags.
Q: How do I perform garbage collection? A: Use nix-collect-garbage -d.
Conclusion
Nix-shell streamlines development by providing isolated project workspaces. This prevents conflicts and ensures consistent environments across machines, allowing you to focus on coding rather than dependency management.
Resources:
- Nix-shell Official Documentation
Related Articles:
- Create NodeJS Virtual Environments Using Conda In Linux
- Create Rust Virtual Environments Using Conda In Linux
- Create Golang Virtual Environments Using Conda In Linux
- How To Manage Python Packages Using PIP
- Pipx – Install And Run Python Applications In Isolated Environments
- Pipenv – The Officially Recommended Python Packaging Tool
The above is the detailed content of How To Create Development Environments With Nix-shell In Linux. For more information, please follow other related articles on the PHP Chinese website!
Hot AI Tools
Undress AI Tool
Undress images for free
Undresser.AI Undress
AI-powered app for creating realistic nude photos
AI Clothes Remover
Online AI tool for removing clothes from photos.
Clothoff.io
AI clothes remover
Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!
Hot Article
Hot Tools
Notepad++7.3.1
Easy-to-use and free code editor
SublimeText3 Chinese version
Chinese version, very easy to use
Zend Studio 13.0.1
Powerful PHP integrated development environment
Dreamweaver CS6
Visual web development tools
SublimeText3 Mac version
God-level code editing software (SublimeText3)
Understanding RAID Configurations on a Linux Server
Aug 05, 2025 am 11:50 AM
RAIDimprovesstorageperformanceandreliabilityonLinuxserversthroughvariousconfigurations;RAID0offersspeedbutnoredundancy;RAID1providesmirroringforcriticaldatawith50�pacityloss;RAID5supportssingle-drivefailuretoleranceusingparityandrequiresatleastthre
Linux how to enable and disable services at boot
Aug 08, 2025 am 10:23 AM
To manage the startup of Linux services, use the systemctl command. 1. Check the service status: systemctlstatus can check whether the service is running, enabled or disabled. 2. Enable the service startup: sudosystemctlenable, such as sudosystemctlenablenginx. If it is started at the same time, use sudosystemctlenable--nownginx. 3. Disable the service startup: sudosystemctldisable, such as sudosystemctldisablecups. If it is stopped at the same time, use sudosystemctldisabl
How to set up a firewall in Linux
Aug 22, 2025 pm 04:41 PM
UsefirewalldoriptablestosecureLinux;firewalldisuser-friendlywithzonesandservices,idealforCentOS/RHEL/Fedora,whileiptablesoffersgranularcontrolforDebian/Ubuntu.Enablefirewalld:sudosystemctlstartfirewalld,allowserviceslikeSSHwith--add-service=ssh,orope
Linux how to list all running processes
Aug 08, 2025 am 06:42 AM
Usepsauxforacompletesnapshotofallrunningprocesses,showingdetailedinformationlikeUSER,PID,CPU,andmemoryusage.2.Usetoporhtopforreal-timemonitoringofprocesseswithdynamicupdates,wherehtopoffersamoreintuitiveinterface.3.UsepgreporpidoftoquicklyfindthePIDs
How to clean up your Linux system
Aug 22, 2025 am 07:42 AM
Removeunusedpackagesanddependencieswithsudoaptautoremove,cleanpackagecacheusingsudoaptcleanorautoclean,andremoveoldkernelsviasudoaptautoremove--purge.2.Clearsystemlogswithsudojournalctl--vacuum-time=7d,deletearchivedlogsin/var/log,andempty/tmpand/var
Linux how to view the contents of a file
Aug 19, 2025 pm 06:44 PM
ToviewfilecontentsinLinux,usedifferentcommandsbasedonyourneeds:1.Forsmallfiles,usecattodisplaytheentirecontentatonce,withcat-ntoshowlinenumbers.2.Forlargefiles,uselesstoscrollpagebypageorlinebyline,searchwith/search_term,andquitwithq.3.Usemoreforbasi
how to create an alias in linux
Aug 19, 2025 pm 08:13 PM
The steps to set up alias in Linux are as follows: 1. Temporarily set the use of the alias command such as aliasll='ls-la'; 2. Permanently set the shell configuration file, such as ~/.bashrc, and then execute the source to take effect; 3. Be careful to avoid overwriting the original command and the different shell configurations are independent. Alias can simplify complex commands and improve efficiency, but only after the current shell environment takes effect and closes the terminal, it needs to be reasonably defined and regularly checked for configuration.
Understanding the Linux Filesystem Hierarchy Standard (FHS)
Aug 06, 2025 pm 04:23 PM
/bin and /sbin store basic commands and system management commands; 2./usr stores user programs and related resources; 3./etc is the configuration file directory; 4./var stores variable data such as logs and caches; 5./home and /root are the home directories of ordinary users and root users; 6./tmp and /run are used for temporary files and runtime data; 7./dev, /proc, /sys provides device and system information interfaces; 8./lib and /lib64 contain library files required for system startup; 9./opt and /srv are used for third-party software and service data respectively; FHS improves system management efficiency through standardized directory structure, making the layout of Linux files clear and consistent, making it easy to maintain and


