# Installing Node.js with nvm to Linux & macOS A quick guide on how to setup Node.js development environment. Previous versions of these install instructions had been tested with: - [Ubuntu on WSL (Windows Subsystem for Linux)](https://docs.microsoft.com/en-us/windows/wsl/about) - [Ubuntu 18.04 LTS (Bionic Beaver)](http://releases.ubuntu.com/bionic/) - [Ubuntu 17.04 (Zesty Zapus)](http://releases.ubuntu.com/xenial/) - [Ubuntu 16.04 LTS (Xenial Xerus)](http://releases.ubuntu.com/xenial/) - [Ubuntu 14.04.3 LTS (Trusty)](http://releases.ubuntu.com/trusty/) - [macOS 10.12.6 (Sierra)](http://apple.wikia.com/wiki/MacOS_10.12.6) - [OS X 10.11.6 (El Capitan)](http://apple.wikia.com/wiki/OS_X_10.11.6) ## Install nvm for managing Node.js versions The reason for using [nvm](https://github.com/nvm-sh/nvm) instead of other install types is mainly in how easy it is to have multiple versions of Node.js (if needed) without too much of extra complexity. Sometimes applications might require a certain version of Node.js to work, so having the flexibility of using specific versions can save a lot of time from you. 1. Open new Terminal window. 2. Run [nvm](https://github.com/nvm-sh/nvm) installer - ...with _either_ curl *or* wget. - `curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.34.0/install.sh | bash` - `wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.34.0/install.sh | bash` - The script clones the nvm repository to `~/.nvm` and adds the source line to your profile (`~/.bash_profile`, `~/.zshrc,` `~/.profile,` or `~/.bashrc`). (You might want/need to add the source loading line by yourself, if the automated install tool does not add it for you.) ```sh export NVM_DIR="${XDG_CONFIG_HOME/:-$HOME/.}nvm" [ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm [ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion ``` 3. If everything went well, you should now be able to reload the shell by running - `source ~/.bashrc` - (Another option is to open a new Terminal window/tab.) 4. Verify installation - To verify that nvm has been installed, do: `command -v nvm` 5. List what versions of Node are currently installed (probably none). - `nvm ls` 6. Install latest [Node.js](https://nodejs.org/en/) LTS release (recommended for production usage). - `nvm install v10.15.3` 7. Install Current [Node.js](https://nodejs.org/en/) Current release with latest features (for testing new feature improvements). - `nvm install v12.1.0` 8. If you want to change the default Node version later, you can run a command to adjust it. - `nvm alias default v10.15.3` (when you work with production quality projects) [changelog](https://github.com/nodejs/node/blob/master/doc/changelogs/CHANGELOG_V10.md#10.15.3) - `nvm alias default v12.1.0` (when you want to test the latest features of Node.js) [changelog](https://github.com/nodejs/node/blob/master/doc/changelogs/CHANGELOG_V12.md#12.1.0) It is also possible to select what Node.js version is used per project basis, by running `nvm use v10.15.3` (or another version number) on the directory where the individual project is located. One way to do that is to create small Bash shell script for enabling the right environment when needed, so you would not have to remember what exact version was needed. You can find a lot of packages from the [npm](https://www.npmjs.com/) website. Have a good time with the tools. ## Upgrading from previous version of Node.js If you already have previous version of Node.js installed with nvm, you can upgrade to a different version with these steps. - Open new Terminal window (to make sure you have latest Node.js version active in your command line environment). - Linking global packages from previous version: - `nvm reinstall-packages v12.0.0` ### Updating outdated packages #### List what (top level) packages are installed globally ```sh npm ls -g --depth=0. ``` #### List what packages are outdated ```sh npm outdated -g --depth=0. ``` #### Update outdated globally installed npm packages ```sh npm update -g ``` #### Fixing old package versions After installation of Node v10.x (or similar), it can be a good idea to recompile old packages (that have compiled native extensions) to make sure that they work with the new version of Node. That can be done easily by going to a project’s root directory, and running `npm rebuild`: ```sh cd PROJECT_NAME npm rebuild ``` ## Deleting old Node.js versions - Look what versions are installed: - `nvm ls` - Delete an older version (if it is no longer used in some of your projects): - `nvm uninstall v10.14.1`