This topic applies to: ✓ .NET Core 1.x ✓ .NET Core 2.x
dotnet run - Runs source code without any explicit compile or launch commands.
dotnet run [-c|--configuration] [-f|--framework] [--force] [--launch-profile] [--no-build] [--no-dependencies] [--no-launch-profile] [--no-restore] [-p|--project] [--runtime] [[--] [application arguments]] dotnet run [-h|--help]
dotnet run command provides a convenient option to run your application from the source code with one command. It's useful for fast iterative development from the command line. The command depends on the
dotnet build command to build the code. Any requirements for the build, such as that the project must be restored first, apply to
dotnet run as well.
Output files are written into the default location, which is
bin/<configuration>/<target>. For example if you have a
netcoreapp1.0 application and you run
dotnet run, the output is placed in
bin/Debug/netcoreapp1.0. Files are overwritten as needed. Temporary files are placed in the
If the project specifies multiple frameworks, executing
dotnet run results in an error unless the
-f|--framework <FRAMEWORK> option is used to specify the framework.
dotnet run command is used in the context of projects, not built assemblies. If you're trying to run a framework-dependent application DLL instead, you must use dotnet without a command. For example, to run
For more information on the
dotnet driver, see the .NET Core Command Line Tools (CLI) topic.
In order to run the application, the
dotnet run command resolves the dependencies of the application that are outside of the shared runtime from the NuGet cache. Because it uses cached dependencies, it's not recommended to use
dotnet run to run applications in production. Instead, create a deployment using the
dotnet publish command and deploy the published output.
Delimits arguments to
dotnet run from arguments for the application being run. All arguments after this one are passed to the application run.
Defines the build configuration. The default value is
Builds and runs the app using the specified framework. The framework must be specified in the project file.
Prints out a short help for the command.
The name of the launch profile (if any) to use when launching the application. Launch profiles are defined in the launchSettings.json file and are typically called
Production. For more information, see Working with multiple environments.
Doesn't build the project before running.
Doesn't attempt to use launchSettings.json to configure the application.
Doesn't perform an implicit restore when running the command.
Specifies the path of the project file to run (folder name or full path). It defaults to the current directory if not specified.
Specifies the target runtime to restore packages for. For a list of Runtime Identifiers (RIDs), see the RID catalog.
Run the project in the current directory:
Run the specified project:
dotnet run --project /projects/proj1/proj1.csproj
Run the project in the current directory (the
--help argument in this example is passed to the application, since the
-- argument is used):
dotnet run --configuration Release -- --help