.翻译自:https://github.com/dotnet/designs/blob/master/accepted/2020/single-file/staging.md

NET Core 3.0 中单文件应用程序的设计。

介绍

在 .NET Core 3.0 中实现阶段 1(在暂存文档中所述)对单文件应用的支持。

构建系统接口

可以通过将以下属性添加到应用程序的项目文件来触发发布到单个文件:

<PropertyGroup>
<PublishSingleFile>true</PublishSingleFile>
</PropertyGroup>
  • 该属性同时应用于框架依赖和自包含的发布操作。PublishSingleFile
  • 该属性适用于特定于平台的生成,与给定的运行时标识符有关。生成的输出是指定平台的本机二进制文件。设置为 时,将保留未定义或设置为 是一个错误。PublishSingleFilePublishSingleFiletrueRuntimeIdentifierUseAppHostfalse
  • 设置该属性会导致托管应用、托管依赖项、特定于平台的本机依赖项、配置等(基本上在运行时未设置属性的情况下运行发布目录的内容)嵌入到本机 中。PublishSingleFiledotnet publishapphost

默认情况下,符号文件不会嵌入到单文件中,而是作为单独的文件保留在发布目录中。这包括 IL 文件和即用式编译器生成的本机/文件。设置以下属性会导致符号文件包含在单文件中。.pdb.ni.pdbapp.guid.map

<PropertyGroup>
<IncludeSymbolsInSingleFile>true</IncludeSymbolsInSingleFile>
</PropertyGroup>

通过设置以下元数据,可以显式排除某些文件嵌入到单文件中:

<ExcludeFromSingleFile>true</ExcludeFromSingleFile>

例如,要将某些文件放在发布目录中,但不将它们捆绑到单文件中:

<ItemGroup>
<Content Update="*.xml">
<CopyToPublishDirectory>PreserveNewest</CopyToPublishDirectory>
<ExcludeFromSingleFile>true</ExcludeFromSingleFile>
</Content>
</ItemGroup>

捆绑器

捆绑包人是一个工具,将托管应用及其依赖项嵌入到本机可执行文件中,如下所述。下面将介绍 .NET Core 3.x 中的捆绑布局。AppHost

捆绑布局(第 1.0 版)
AppHost
(Bundle-Marker)
嵌入式文件
app.dll
app.deps.json
app.runtimeconfig.json
dependency.dll
...
捆绑标题
(版本 #)1.0
#Number of Embedded Files
Bundle-ID
每个捆绑文件的捆绑清单
:(

此信息在 3.0 中不使用)Location (Offset, Size)Type :IL, ReadyToRun, other

主机

启动时,AppHost 会检查其是否具有嵌入文件。如果是这样,它

  • 内存映射整个捆绑包文件。
  • 检查内容是否已提取到提取位置(如下所述)
    • 如果提取位置中的所有文件都完好无损,则执行将继续重用提取的文件。
    • 如果没有,则提取缺少的组件
  • 如果提取不可用,主机将嵌入的文件提取到磁盘,如本文档中所述。
  • 调用运行时(通过其他主机组件)。

提取位置

对于单文件应用,提取目录为<base>/<app>/<bundle-id>

  • <base>

    • DOTNET_BUNDLE_EXTRACT_BASE_DIR环境变量(如果已设置)。
    • 如果没有,则默认为:
      • 窗户:%TEMP%\.net
      • Unix:
        • ${TMPDIR}/.net/${UID}如果已设置;如果已设置否则${TMPDIR}
        • /var/tmp/.net/${UID}如果存在,并且是可写;否则/var/tmp
        • /tmp/.net/${UID}如果存在,并且是可写;否则失败。/tmp
  • <app>是单 exe 二进制的名称

  • <bundle-id>是唯一的捆绑标识符。

API 影响

大多数应用开发对于应用是否以单文件形式发布是不可知的。但是,处理文件物理位置的应用部分需要了解单文件打包。

  • Assembly.Location:返回提取位置内的实际位置。
  • AppContext.BaseDirectory:返回提取目录,其中驻留的位置。app.dll

用户体验

总之,以下是创建 HelloWorld 单文件应用的总体体验

  • 创建新的 HelloWorld 应用:HelloWorld$ dotnet new console

框架依赖HelloWorld

  • 正常发布:dotnet publish

    • 发布目录包含主机、应用程序、配置文件 和 PDB 文件。HelloWorld.exeHelloWorld.dllHelloWorld.deps.jsonHelloWorld.runtimeconfig.jsonHelloWorld.pdb
  • 单文件发布:dotnet publish -r win10-x64 --self-contained=false /p:PublishSingleFile=true

    • 发布目录包含:HelloWorld.exe HelloWorld.pdb

    • HelloWorld.dll中嵌入 和 , 并嵌入 到 中。HelloWorld.deps.jsonHelloWorld.runtimeconfig.jsonHelloWorld.exe

  • 运行:HelloWorld.exe

    • 该应用程序完全从单一文件运行,无需中间提取即可归档。

独立世界

  • 正常发布:dotnet publish -r win10-x64

    • 发布目录包含 221 个文件,包括主机、应用程序、配置文件、PDB 文件和运行时。
  • 单文件发布:dotnet publish -r win10-x64 /p:PublishSingleFile=true

    • 发布目录包含:HelloWorld.exe HelloWorld.pdb
    • 其余 219 个文件嵌入在主机中。HelloWorld.exe
  • 运行:HelloWorld.exe

    • 首次运行时,219 个嵌入式文件将在启动时提取到磁盘。
    • 应用的后续运行将重用提取,而不会产生启动开销。

调试

在应用的调试和分析方面,预计没有差异。

.net core 3.x 发布单文件的更多相关文章

  1. .NET Core 3.0 发布单文件可执行程序

    Windows dotnet publish -r win10-x64 /p:PublishSingleFile=true maxOS dotnet publish -r osx-x64 /p:Pub ...

  2. VS2019(NET Core 3.0)发布单文件可执行程序

    NET Core 3.0 发布单文件可执行程序 两种方法. 一.右击vs编辑项目文件,增加PublishSingleFile节点配置,代码如下: <Project Sdk="Micro ...

  3. .NET Core 3.0 Preview 5 亮点之一:发布单文件可执行程序

    在阅读 Announcing .NET Core 3.0 Preview 5 时发现了 .NET Core 3.0 Preview 5 的一个新特性 —— Publishing Single EXEs ...

  4. .NET Core 新特性:发布单文件可执行程序

    一.前言 .NET Core 3.0中新增加了一个特性:Publishing Single EXEs,可以通过dotnet publish 命令将整个.net core应用发布为一个可执行文件. 二. ...

  5. VS2017开发.net core 时默认发布路径文件夹多个BPC

    新安装的VS2017,编译后进行发布,结果在bin文件夹下多了个BPC文件夹,很是费解,查了资料才知道是VS2017默认设置了环境变量.在此记录下,如果不需要默认路径可修改环境变量,具体操作如下: 我 ...

  6. VS2019 发布单文件

    在项目.csproj文件下添加 <PropertyGroup> <OutputType>Exe</OutputType> <TargetFramework&g ...

  7. DotnetCore 单文件发布

    NETCORE3.0开始,可以发布单文件,参考https://www.cnblogs.com/ZaraNet/p/11790645.html 发布后(config目录 是手工复制进去的)   运行时, ...

  8. ASP.NET Core应用针对静态文件请求的处理[1]: 以Web的形式发布静态文件

    虽然ASP.NET Core是一款"动态"的Web服务端框架,但是在很多情况下都需要处理针对静态文件的请求,最为常见的就是这对JavaScript脚本文件.CSS样式文件和图片文件 ...

  9. 译 .NET Core 3.0 发布

    原文:<Announcing .NET Core 3.0> 宣布.NET Core 3.0 发布 很高兴宣布.NET Core 3.0的发布.它包括许多改进,包括添加Windows窗体和W ...

  10. Web的形式发布静态文件

    Web的形式发布静态文件 虽然ASP.NET Core是一款"动态"的Web服务端框架,但是在很多情况下都需要处理针对静态文件的请求,最为常见的就是这对JavaScript脚本文件 ...

随机推荐

  1. Games101 光线追踪 代码框架解读

    目录 1 前言 2 main.cpp 3 render.cpp 3.1 折射reflect 反射refract 相关 3.2 Fresnel equation 3.3 递归函数光线追踪 3.2.1 t ...

  2. 92. 反转链表 II Golang实现

    题目描述: 给你单链表的头指针 head 和两个整数 left 和 right ,其中 left <= right .请你反转从位置 left 到位置 right 的链表节点,返回 反转后的链表 ...

  3. 使用 vscode 编译+运行 typescropt Mac win同理

    一..d.ts文件最好在src/typings 目录下,可在tsconfig.json 文件配置 二.vs 监听文件变化,自动编译ts文件 tsconfig.json { "compiler ...

  4. 题解:CSP-S2020] 函数调用

    题解:CSP-S2020] 函数调用 一句话题意:给定一个有初始值的序列,支持如下三种操作: 1.单点加 2.全局乘 3.递归某些操作1.2.3 求最终的序列. 标签:topsort,动态规划,转化贡 ...

  5. Python不同数据结构的元素频率统计

    1.list的词频统计 这里利用Python字典的键值对来进行统计.逻辑就是,根据list的内容生成一个字典,把要统计的列表元素的值作为字典的key,而后给字典中对应的key进行赋值,赋值方法采用字典 ...

  6. PicGo+CloudFire搭建免费图床

    目录 CloudFire对象存储 创建bucket 配置域名 配置 Bucket 访问 API PicGO配置 参考博客 CloudFire对象存储 | CloudFire提供对象存储服务,每个月有1 ...

  7. The Bento Box Adventure

    题目来源:codeforces 2041A 题目名称:The Bento Box Adventure 题目链接:https://codeforces.com/contest/2041/problem/ ...

  8. Getting Flex 3 talking to Java via JSON

    packagecom.giantflyingsaucer; importjava.io.*; importjava.io.PrintWriter; importjavax.servlet.*; imp ...

  9. golang之常用方法/函数

    1. io.Reader转化为字符串, byte切片 import "bytes" func StreamToByte(stream io.Reader) []byte { buf ...

  10. Blazor 组件库 BootstrapBlazor 中Alert组件介绍

    组件介绍 Alert组件几乎是组件库里必不可少的组件了,即使浏览器,也自带了一个alert,会弹出一个模态框. 但是这个模态框有点太丑了,所以各大组件库分分实现了自己的Alert组件. 当然Boots ...