How to Install and Use the Node Package Manager (NPM) on Linux

Create a Linode account to try this guide with a $ credit.

The Node Package Manager (NPM) is the most widely-used package manager for JavaScript projects and includes Node.js by default. This guide walks you through installing NPM and getting started using it on your Linux system.

What is NPM?

NPM is the default package manager for Node.js projects. NPM includes a command-line tool (CLI) that give you access to the NPM package registry. The registry stores the numerous JavaScript packages made available through the NPM CLI, along with their metadata. The NPM website gives you an easy way to search for JavaScript packages and read information about them. The package.json file that is generated by the NPM CLI helps you manage project dependencies. It also ensures consistent project installations across environments.

NPM vs Yarn

The Yarn package manager has become a popular alternative to NPM. Both NPM and Yarn use the NPM registry to get packages and package information, and the commands in each tool are pretty similar.

One advantage to NPM is that it is the default package manager for Node.js. If you have Node.js installed on your system, you automatically have access to NPM. This means that once you have Node.js installed, you immediately have access to all the functionality available through the NPM package registry.

NPM is also the most popular Node.js package manager. With that popularity comes a wide range of coverage. You are more likely to find Node.js projects and examples that use NPM than you are to find ones using Yarn.

Yarn was originally designed to address performance and security concerns in NPM. And while Yarn still outshines NPM in terms of speed, NPM has made vast security improvements that put it about even with Yarn.

Note

You can learn more about Yarn in our How to Install and Use the Yarn Package Manager guide.

To learn how to install Node.js, jump to the How to Install NPM section of this guide.

How to Install or Update NPM

The steps in this section show you how to install NPM along with Node.js. It also gives you methods for updating your NPM installation.

How to Install NPM

Since NPM is packaged with Node.js, you just need to install Node.js. The installation path recommended by NPM is using a the Node Version Manager (nvm). This version manager helps you avoid permissions issues and version conflicts with NPM packages. To install nvm follow the steps in our How to Install and Use the Node Version Manager NVM guide.

Using nvm, you can install the current stable version of Node.js, and its accompanying version of NPM using the following command:

nvm install node

To verify your NPM installation, check for the installed npm version.

npm -v
7.20.3

How to Update NPM

When working with nvm to manage your Node.js versions, updating your NPM version requires that you update your Node.js version. To make sure you are on the latest version of NPM, use NVM’s install command to install the current stable Node.js version.

nvm install node

Then, tell NVM to use the latest version.

nvm use node

If you want to update NPM, without updating Node.js, use nvm’s dedicated command.

nvm install-latest-npm

How to Install Packages with NPM

The sections that follow show you how to install and use NPM packages.

Most often, you install NPM packages for a specific project. Use commands below to create an example NPM project to follow along with this guide.

Create a new directory for the example project and move into the new directory.

mkdir ~/example-app
cd ~/example-app

Initialize the new NPM project.

npm init

NPM prompts you for information about your project. Use the defaults for this example. The result is an initial package.json file representing your project.

Install Packages to a Project

NPM provides two main ways for installing specific packages to your project.

  • You can install a specific package with NPM’s install command. In the example below, NPM installs the latest stable version of the package. The example installs the Express web application framework.

    npm install express
    
  • Alternatively, you can explicitly specify the package version you want installed on your system.

    npm install express@4.17.1
    

    You can even specify a version range for the package you want to be installed. Place the version expression between quotes, and precede the version number with the comparison operator you want to use. You can use multiple version constraints, separating them with spaces.

    npm install express@">=4.1.0 <4.17.1"
    

    The above command installs the latest available version of the Express JS package that is equal to or greater than 4.1.0 and less than 4.17.1.

Package.json

The npm init command creates a package.json file in the project’s base directory. Any packages installed in the project are reflected in this file. The package.json is a reflection of your project’s dependency structure.

The file below is an example package.json that results from the basic npm install express command (from the above section).

File: package.json
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
{
  "name": "example-app",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC",
  "dependencies": {
    "express": "^4.17.1"
  }
}

Notice that the express package is listed under dependencies. The ^ indicates that a package version compatible with version 4.17.1 must be installed for this project.

Take a look at NPM’s package.json documentation, specifically the dependencies section for more information about the syntax used for parsing package versions. The same syntax can be used when specifying a version, or a version range, for the install command.

Install Dependencies for an Existing Project

You may come across an existing project, with its own package.json, that you want to get up and running. Typically, you first need to install the project’s dependencies. You can do this by running the install command from that base directory without specifying a package. For example:

npm install

NPM uses the project’s package.json to determine which packages are needed and which versions of those packages are compatible with the project. If the project has a package-lock.json, NPM also uses that to further ensure compatibility with the dependencies that get installed.

Install Packages Globally

You may want to install some packages globally. Packages installed in this way are available anywhere on the system, not just within a particular project.

You can accomplish this with NPM’s global (-g) flag, as shown below:

npm install -g express

You can also use the -g option with the commands in the next two sections. This option allows you to uninstall and update global packages.

How to Remove Packages with NPM

You can uninstall an NPM package with the uninstall command.

npm uninstall express

The uninstall command updates the package.json to reflect that the project no longer depends on the uninstalled package.

File: package.json
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
{
  "name": "example-app",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC"
}

How to Update Packages with NPM

You can use the command below to update all of a project’s packages to their latest compatible versions.

npm update

NPM references the version constraints given in the project’s package.json file to ensure that updates do not contradict your project’s specified version.

More Information

You may wish to consult the following resources for additional information on this topic. While these are provided in the hope that they will be useful, please note that we cannot vouch for the accuracy or timeliness of externally hosted materials.

This page was originally published on


Your Feedback Is Important

Let us know if this guide was helpful to you.


Join the conversation.
Read other comments or post your own below. Comments must be respectful, constructive, and relevant to the topic of the guide. Do not post external links or advertisements. Before posting, consider if your comment would be better addressed by contacting our Support team or asking on our Community Site.