---
title: ASP.NET Core directory structure
author: guardrex
description: Learn about the directory structure of published ASP.NET Core apps.
manager: wpickett
ms.author: riande
ms.custom: mvc
ms.date: 04/09/2018
ms.prod: asp.net-core
ms.technology: aspnet
ms.topic: article
uid: host-and-deploy/directory-structure
---
# ASP.NET Core directory structure
By [Luke Latham](https://github.com/guardrex)
In ASP.NET Core, the published application directory, *publish*, is comprised of application files, config files, static assets, packages, and the runtime (for [self-contained deployments](/dotnet/core/deploying/#self-contained-deployments-scd)).
| App Type | Directory Structure |
| -------- | ------------------- |
| [Framework-dependent Deployment](/dotnet/core/deploying/#framework-dependent-deployments-fdd) |
- publish†
- logs† (optional unless required to receive stdout logs)
- Views† (MVC apps; if views aren't precompiled)
- Pages† (MVC or Razor Pages apps; if pages aren't precompiled)
- wwwroot†
- *\.dll files
- \.deps.json
- \.dll
- \.pdb
- \.PrecompiledViews.dll
- \.PrecompiledViews.pdb
- \.runtimeconfig.json
- web.config (IIS deployments)
|
| [Self-contained Deployment](/dotnet/core/deploying/#self-contained-deployments-scd) | - publish†
- logs† (optional unless required to receive stdout logs)
- refs†
- Views† (MVC apps; if views aren't precompiled)
- Pages† (MVC or Razor Pages apps; if pages aren't precompiled)
- wwwroot†
- \*.dll files
- \.deps.json
- \.exe
- \.pdb
- \.PrecompiledViews.dll
- \.PrecompiledViews.pdb
- \.runtimeconfig.json
- web.config (IIS deployments)
|
†Indicates a directory
The *publish* directory represents the *content root path*, also called the *application base path*, of the deployment. Whatever name is given to the *publish* directory of the deployed app on the server, its location serves as the server's physical path to the hosted app.
The *wwwroot* directory, if present, only contains static assets.
The stdout *logs* directory can be created the deployment using one of the following two approaches:
* Add the following `` element to the project file:
```xml
```
The `` element creates an empty *Logs* folder in the published output. The element uses the `PublishDir` property to determine the target location for creating the folder. Several deployment methods, such as Web Deploy, skip empty folders during deployment. The `` element generates a file in the *Logs* folder, which guarantees deployment of the folder to the server. Note that folder creation may still fail if the worker process doesn't have write access to the target folder.
* Physically create the *Logs* directory on the server in the deployment.
The deployment directory requires Read/Execute permissions. The *Logs* directory requires Read/Write permissions. Additional directories where files are written require Read/Write permissions.