This topic applies to: ✓ .NET Core SDK 1.x ✓ .NET Core SDK 2.x
dotnet restore - Restores the dependencies and tools of a project.
dotnet restore [<ROOT>] [--configfile] [--disable-parallel] [--force] [--ignore-failed-sources] [--no-cache] [--no-dependencies] [--packages] [-r|--runtime] [-s|--source] [-v|--verbosity] dotnet restore [-h|--help]
dotnet restore command uses NuGet to restore dependencies as well as project-specific tools that are specified in the project file. By default, the restoration of dependencies and tools are performed in parallel.
Starting with .NET Core 2.0, you don't have to run
dotnet restore because it's run implicitly by all commands, such as
dotnet build and
dotnet run, that require a restore to occur. It's still a valid command in certain scenarios where doing an explicit restore makes sense, such as continuous integration builds in Visual Studio Team Services or in build systems that need to explicitly control the time at which the restore occurs.
In order to restore the dependencies, NuGet needs the feeds where the packages are located. Feeds are usually provided via the NuGet.config configuration file. A default configuration file is provided when the CLI tools are installed. You specify additional feeds by creating your own NuGet.config file in the project directory. You also specify additional feeds per invocation at a command prompt.
For dependencies, you specify where the restored packages are placed during the restore operation using the
--packages argument. If not specified, the default NuGet package cache is used, which is found in the
.nuget/packages directory in the user's home directory on all operating systems (for example, /home/user1 on Linux or C:\Users\user1 on Windows).
For project-specific tooling,
dotnet restore first restores the package in which the tool is packed, and then proceeds to restore the tool's dependencies as specified in its project file.
The behavior of the
dotnet restore command is affected by some of the settings in the Nuget.Config file, if present. For example, setting the
globalPackagesFolder in NuGet.Config places the restored NuGet packages in the specified folder. This is an alternative to specifying the
--packages option on the
dotnet restore command. For more information, see the NuGet.Config reference.
Starting with .NET Core 2.0,
dotnet restore is run implicitly if necessary when you issue the following commands:
In most cases, you no longer need to explicitly use the
dotnet restore command.
In some cases, it is inconvenient for
dotnet restore to run implicitly. For example, some automated systems, such as build systems, need to call
dotnet restore explicitly to control when the restore occurs so that they can control network usage. To prevent
dotnet restore from running implicitly, you can use the
--no-restore switch with any of these commands to disable implicit restore.
Optional path to the project file to restore.
The NuGet configuration file (NuGet.config) to use for the restore operation.
Disables restoring multiple projects in parallel.
Forces all dependencies to be resolved even if the last restore was successful. This is equivalent to deleting the project.assets.json file.
Prints out a short help for the command.
Only warn about failed sources if there are packages meeting the version requirement.
Specifies to not cache packages and HTTP requests.
When restoring a project with project-to-project (P2P) references, restores the root project and not the references.
Specifies the directory for restored packages.
Specifies a runtime for the package restore. This is used to restore packages for runtimes not explicitly listed in the
<RuntimeIdentifiers> tag in the .csproj file. For a list of Runtime Identifiers (RIDs), see the RID catalog. Provide multiple RIDs by specifying this option multiple times.
Specifies a NuGet package source to use during the restore operation. This overrides all of the sources specified in the NuGet.config file(s). Multiple sources can be provided by specifying this option multiple times.
Sets the verbosity level of the command. Allowed values are