dotnet builddotnet build

Dieser Artikel gilt für: ✓.NET Core 1.x SDK und spätere VersionenThis article applies to: ✓ .NET Core 1.x SDK and later versions

nameName

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

ÜbersichtSynopsis

dotnet build [<PROJECT>|<SOLUTION>] [-c|--configuration] [-f|--framework] [--force] [--interactive] [--no-dependencies]
    [--no-incremental] [--nologo] [--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 can't 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 Azure DevOps 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 Azure DevOps 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.

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.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.

MSBuildMSBuild

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. Sie können auch den Befehl dotnet msbuild verwenden.Or you can also use the dotnet msbuild command.

Die Ausführung von dotnet build entspricht dotnet msbuild -restore -target:Build.Running dotnet build is equivalent to dotnet msbuild -restore -target:Build.

ArgumenteArguments

PROJECT | SOLUTION

Die zu erstellende Projekt- oder Projektmappendatei.The project or solution file to build. Wenn Sie keine Projekt- oder Projektmappendatei angeben, durchsucht MSBuild das aktuelle Arbeitsverzeichnis nach einer Dateierweiterung, die mit proj oder sln endet, und verwendet diese.If a project or solution file isn't specified, MSBuild searches the current working directory for a file that has a file extension that ends in either proj or sln and uses that file.

OptionenOptions

  • -c|--configuration {Debug|Release}

    Legt die Buildkonfiguration fest.Defines the build configuration. Der Standardwert ist Debugsein.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. Verfügbar seit .NET Core 2.0 SDK.Available since .NET Core 2.0 SDK.

  • -h|--help

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

  • --interactive

    Ermöglicht dem Befehl, anzuhalten und auf Benutzereingaben oder Aktionen zu warten.Allows the command to stop and wait for user input or action. Beispielsweise, um die Authentifizierung abzuschließen.For example, to complete authentication. Verfügbar seit .NET Core 3.0 SDK.Available since .NET Core 3.0 SDK.

  • --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-logo

    Unterdrückt die Anzeige von Startbanner und Copyrightmeldung.Doesn't display the startup banner or the copyright message. Verfügbar seit .NET Core 3.0 SDK.Available since .NET Core 3.0 SDK.

  • --no-restore

    Führt keine implizite Wiederherstellung während der Projekterstellung durch.Doesn't execute an implicit restore during build. Verfügbar seit .NET Core 2.0 SDK.Available since .NET Core 2.0 SDK.

  • -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. Wenn nicht angegeben, ist der Standardpfad ./bin/<configuration>/<framework>/.If not specified, the default path is ./bin/<configuration>/<framework>/.

  • -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 MSBuild-Ausführlichkeitsgrad fest.Sets the MSBuild verbosity level. 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]. Die Standardeinstellung ist minimal.The default is minimal.

  • --version-suffix <VERSION_SUFFIX>

    Hiermit wird der Wert der $(VersionSuffix)-Eigenschaft festgelegt, die beim Erstellen des Projekts verwendet werden soll.Sets the value of the $(VersionSuffix) property to use when building the project. Dies funktioniert nur, wenn die $(Version)-Eigenschaft nicht festgelegt ist.This only works if the $(Version) property isn't set. Dann wird $(Version) auf $(VersionPrefix) festgelegt, kombiniert mit dem $(VersionSuffix), getrennt durch einen Bindestrich.Then, $(Version) is set to the $(VersionPrefix) combined with the $(VersionSuffix), separated by a dash.

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 18.04):Build a project and its dependencies for a specific runtime (in this example, Ubuntu 18.04):

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

    dotnet build --source c:\packages\mypackages
    
  • Erstellen Sie das Projekt, und legen Sie Version 1.2.3.4 als Buildparameter mithilfe der -p MSBuild-Option fest:Build the project and set version 1.2.3.4 as a build parameter using the -p MSBuild option:

    dotnet build -p:Version=1.2.3.4