dotnet-builddotnet-build

Dieses Thema gilt für: ✓ .NET Core SDK 1.x .NET Core SDK 2.xThis topic applies to: ✓ .NET Core SDK 1.x .NET Core SDK 2.x

NameName

dotnet build: Erstellt ein Projekt und alle seine Abhängigkeitendotnet build - Builds a project and all of its dependencies.

ÜbersichtSynopsis

dotnet build [<PROJECT>] [-c|--configuration] [-f|--framework] [--force] [--no-dependencies] [--no-incremental] [--no-restore] [-o|--output] [-r|--runtime] [-v|--verbosity] [--version-suffix]
dotnet build [-h|--help]

BeschreibungDescription

Der dotnet build-Befehl erstellt das Projekt und die zugehörigen Abhängigkeiten in einen Satz von Binärdateien.The dotnet build command builds the project and its dependencies into a set of binaries. Die Binärdateien enthalten den Projektcode in Intermediate Language-Dateien (IL) mit einer .dll-Erweiterung und Symboldateien, die zum Debuggen mit einer .pdb-Erweiterung verwendet werden.The binaries include the project's code in Intermediate Language (IL) files with a .dll extension and symbol files used for debugging with a .pdb extension. Eine JSON-Datei für Abhängigkeiten (*.deps.json) wird erstellt, die Abhängigkeiten der Anwendung aufführt.A dependencies JSON file (*.deps.json) is produced that lists the dependencies of the application. Eine *.runtimeconfig.json-Datei wird erstellt, die die gemeinsam genutzte Laufzeit und deren Version für die Anwendung anzeigt.A *.runtimeconfig.json file is produced, which specifies the shared runtime and its version for the application.

Verfügt das Projekt über Abhängigkeiten von Drittanbietern, z.B. Bibliotheken von NuGet, werden diese aus dem NuGet-Cache aufgelöst und sind nicht mit der Buildausgabe des Projekts verfügbar.If the project has third-party dependencies, such as libraries from NuGet, they're resolved from the NuGet cache and aren't available with the project's built output. Bedenken Sie, dass das Produkt von dotnet build nicht auf einen anderen Computer zur Ausführung übertragen werden kann.With that in mind, the product of dotnet build isn't ready to be transferred to another machine to run. Dies unterscheidet sich zum Verhalten des .NET Framework, bei dem die Erstellung eines ausführbaren Projekts (eine Anwendung) eine Ausgabe erzeugt, die auf jedem Computer ausgeführt werden kann, auf dem .NET Framework installiert ist.This is in contrast to the behavior of the .NET Framework in which building an executable project (an application) produces output that's runnable on any machine where the .NET Framework is installed. Um ein ähnliches Verhalten mit .NET Core zu erhalten, müssen Sie den Befehl dotnet publish verwenden.To have a similar experience with .NET Core, you need to use the dotnet publish command. Weitere Informationen finden Sie unter .NET Core Anwendungsbereitstellung.For more information, see .NET Core Application Deployment.

Das Erstellen erfordert die project.assets.json-Datei, die die Abhängigkeiten Ihrer Anwendung aufführt.Building requires the project.assets.json file, which lists the dependencies of your application. Die Datei wird erstellt, wenn dotnet restore ausgeführt wird.The file is created when dotnet restore is executed. Ohne die vorhandenen Ressourcendateien kann das Tool die Verweisassemblys nicht auflösen, was zu Fehlern führt.Without the assets file in place, the tooling cannot resolve reference assemblies, which results in errors. Mit dem .NET Core 1.x SDK müssen Sie dotnet restore explizit ausführen, bevor Sie dotnet build ausführen.With .NET Core 1.x SDK, you needed to explicitily run the dotnet restore before running dotnet build. Ab dem .NET Core 2.0 SDK wird dotnet restore implizit ausgeführt, wenn Sie dotnet build ausführen.Starting with .NET Core 2.0 SDK, dotnet restore runs implicitily when you run dotnet build. Wenn Sie das implizite Wiederherstellen deaktivieren möchten, wenn Sie den Buildbefehl ausführen, können Sie die --no-restore-Option übergeben.If you want to disable implicit restore when running the build command, you can pass the --no-restore option.

Hinweis

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.

dotnet build verwendet MSBuild, um das Projekt zu erstellen und unterstützt daher parallele und inkrementelle Builds.dotnet build uses MSBuild to build the project; thus, it supports both parallel and incremental builds. Weitere Informationen finden Sie unter Inkrementelle Builds.Refer to Incremental Builds for more information.

Zusätzlich zu diesen Optionen akzeptiert der dotnet build-Befehl MSBuild-Optionen, wie z.B. /p zum Festlegen von Eigenschaften oder /l zum Definieren eines Protokolls.In addition to its options, the dotnet build command accepts MSBuild options, such as /p for setting properties or /l to define a logger. Erfahren Sie mehr über diese Optionen in der MSBuild-Befehlszeilenreferenz.Learn more about these options in the MSBuild Command-Line Reference.

Ob das Projekt ausführbar ist oder nicht, richtet sich nach der <OutputType>-Eigenschaft in der Projektdatei.Whether the project is executable or not is determined by the <OutputType> property in the project file. Das folgende Beispiel zeigt ein Projekt, das ausführbaren Code erzeugt:The following example shows a project that will produce executable code:

<PropertyGroup>
  <OutputType>Exe</OutputType>
</PropertyGroup>

Lassen Sie die <OutputType>-Eigenschaft weg, um eine Bibliothek zu erstellen.In order to produce a library, omit the <OutputType> property. Der Hauptunterschied in der Buildausgabe ist, dass die IL-DLL für eine Bibliothek keine Einstiegspunkte enthält und nicht ausgeführt werden kann.The main difference in built output is that the IL DLL for a library doesn't contain entry points and can't be executed.

ArgumenteArguments

PROJECT

Die zu erstellende Projektdatei.The project file to build. Wenn Sie keine Projektdatei angeben, durchsucht MSBuild das aktuelle Arbeitsverzeichnis nach einer Dateierweiterung, die mit proj endet, und verwendet diese.If a project file is not specified, MSBuild searches the current working directory for a file that has a file extension that ends in proj and uses that file.

OptionenOptions

-c|--configuration {Debug|Release}

Legt die Buildkonfiguration fest.Defines the build configuration. Der Standardwert ist Debug.The default value is Debug.

-f|--framework <FRAMEWORK>

Kompiliert für ein bestimmtes Framework.Compiles for a specific framework. Das Framework muss in der Projektdatei definiert werden.The framework must be defined in the project file.

--force

Erzwingt das Auflösen aller Abhängigkeiten, auch wenn die letzte Wiederherstellung erfolgreich war.Forces all dependencies to be resolved even if the last restore was successful. Dies entspricht dem Löschen der Datei project.assets.json.This is equivalent to deleting the project.assets.json file.

-h|--help

Druckt eine kurze Hilfe für den Befehl.Prints out a short help for the command.

--no-dependencies

Ignoriert Verweise zwischen Projekten (P2P) und erstellt nur das zum Erstellen angegebene Stammprojekt.Ignores project-to-project (P2P) references and only builds the root project specified to build.

--no-incremental

Markiert den Build als unsicher für inkrementelle Builds.Marks the build as unsafe for incremental build. Deaktiviert die inkrementelle Kompilierung und erzwingt eine komplette Neuerstellung des Abhängigkeitsdiagramms des Projekts.This turns off incremental compilation and forces a clean rebuild of the project's dependency graph.

--no-restore

Führt ekine implizite Wiederherstellung während der Projekterstellung durch.Doesn't perform an implicit restore during build.

-o|--output <OUTPUT_DIRECTORY>

Verzeichnis, in dem die erstellten Binärdateien platziert werden.Directory in which to place the built binaries. Sie müssen außerdem --framework definieren, wenn Sie diese Option angeben.You also need to define --framework when you specify this option.

-r|--runtime <RUNTIME_IDENTIFIER>

Legt die Ziellaufzeit fest.Specifies the target runtime. Eine Liste der Runtime-IDs (RIDs) finden Sie unter RID-Katalog.For a list of Runtime Identifiers (RIDs), see the RID catalog.

-v|--verbosity <LEVEL>

Legt den Ausführlichkeitsgrad für den Befehl fest.Sets the verbosity level of the command. Zulässige Werte sind q[uiet], m[inimal], n[ormal], d[etailed] und diag[nostic].Allowed values are q[uiet], m[inimal], n[ormal], d[etailed], and diag[nostic].

--version-suffix <VERSION_SUFFIX>

Definiert das Versionssuffix für ein Sternchen (*) im Versionsfeld der Projektdatei.Defines the version suffix for an asterisk (*) in the version field of the project file. Das Format entspricht den NuGet-Versionsrichtlinien.The format follows NuGet's version guidelines.

BeispieleExamples

Erstellt ein Projekt und seine Abhängigkeiten:Build a project and its dependencies:

dotnet build

Erstellt ein Projekt und seine Abhängigkeiten mithilfe der Release-Konfiguration:Build a project and its dependencies using Release configuration:

dotnet build --configuration Release

Erstellt ein Projekt und seine Abhängigkeiten für eine bestimmte Laufzeit (in diesem Beispiel Ubuntu 16.04):Build a project and its dependencies for a specific runtime (in this example, Ubuntu 16.04):

dotnet build --runtime ubuntu.16.04-x64