dotnet-builddotnet-build

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

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]

descriptionDescription

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 explicitly 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 implicitly 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

Ab .NET Core 2.0 müssen Sie dotnet restore nicht mehr ausführen, da der Befehl implizit von allen Befehlen, z.B. dotnet build und dotnet run, ausgeführt wird, die eine Wiederherstellung erfordern.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. In bestimmten Fällen eignet sich der Befehl dennoch. Dies ist etwa bei Szenarios der Fall, in denen das Ausführen einer expliziten Wiederherstellung sinnvoll ist. Beispiele hierfür sind Continuous Integration-Builds in Visual Studio Team Services oder Buildsystemen, die den Zeitpunkt für die Wiederherstellung explizit festlegen müssen.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.

Dieser Befehl unterstützt auch die dotnet restore-Optionen, wenn sie in der Langform übergeben werden (z.B. --source).This command also supports the dotnet restore options when passed in the long form (for example, --source). Optionen in Kurzform wie z.B. -s werden nicht unterstützt.Short form options, such as -s, are not supported.

dotnet build verwendet MSBuild zum Erstellen des Projekts und unterstützt daher parallele und inkrementelle Builds.dotnet build uses MSBuild to build the project, so it supports both parallel and incremental builds. Weitere Informationen finden Sie unter Incremental Builds (Inkrementelle Builds).For more information, see Incremental Builds.

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. Weitere Informationen zu diesen Optionen finden Sie in der MSBuild-Befehlszeilenreferenz.For more information about these options, see 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 produces 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. Dieses Flag anzugeben, entspricht dem Löschen der Datei project.assets.json.Specifying this flag is the same as 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 angegebene Stammprojekt.Ignores project-to-project (P2P) references and only builds the specified root project.

--no-incremental

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

--no-restore

Führt keine implizite Wiederherstellung während der Projekterstellung durch.Doesn't execute 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

Erstellt ein Projekt und verwendet die angegebene NuGet-Paketquelle während des Wiederherstellungsvorgangs (.NET Core SDK 2.0 und spätere Versionen):Build the project and use the specified NuGet package source during the restore operation (.NET Core SDK 2.0 and later versions):

dotnet build --source c:\packages\mypackages