AspNetCore.Docs/aspnetcore/hosting/directory-structure.md

2.6 KiB

title author description keywords ms.author manager ms.date ms.topic ms.assetid ms.technology ms.prod uid
Directory structure | Microsoft Docs guardrex The directory structure of published ASP.NET Core applications. ASP.NET Core, directory structure riande wpickett 10/14/2016 article e55eb131-d42e-4bf6-b130-fd626082243c aspnet asp.net-core hosting/directory-structure

Directory structure

By Luke Latham

In ASP.NET Core, the application directory, publish, is comprised of application files, config files, static assets, packages, and the runtime (for self-contained apps). This is the same directory structure as previous versions of ASP.NET, where the entire application lives inside the web root directory.

App Type Directory Structure
Framework-dependent Deployment
  • publish*
    • logs* (if included in publishOptions)
    • refs*
    • runtimes*
    • Views* (if included in publishOptions)
    • wwwroot* (if included in publishOptions)
    • .dll files
    • myapp.deps.json
    • myapp.dll
    • myapp.pdb
    • myapp.PrecompiledViews.dll (if precompiling Razor Views)
    • myapp.PrecompiledViews.pdb (if precompiling Razor Views)
    • myapp.runtimeconfig.json
    • web.config (if included in publishOptions)
Self-contained Deployment
  • publish*
    • logs* (if included in publishOptions)
    • refs*
    • Views* (if included in publishOptions)
    • wwwroot* (if included in publishOptions)
    • .dll files
    • myapp.deps.json
    • myapp.exe
    • myapp.pdb
    • myapp.PrecompiledViews.dll (if precompiling Razor Views)
    • myapp.PrecompiledViews.pdb (if precompiling Razor Views)
    • myapp.runtimeconfig.json
    • web.config (if included in publishOptions)
* Indicates a directory

The contents of the publish directory represent the content root path, also called the application base path, of the deployment. Whatever name is given to the publish directory in the deployment, its location serves as the server's physical path to the hosted application. The wwwroot directory, if present, only contains static assets. The logs directory may be included in the deployment by creating it in the project and adding it to publishOptions of project.json or by physically creating the directory on the server.

The deployment directory requires Read/Execute permissions, while the logs directory requires Read/Write permissions. Additional directories where assets will be written require Read/Write permissions.