.net core 3.x 发布单文件
.翻译自: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.dllapp.deps.jsonapp.runtimeconfig.jsondependency.dll... |
| 捆绑标题 (版本 #) 1.0#Number of Embedded FilesBundle-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
- 发布目录包含主机、应用程序、配置文件 和 PDB 文件。
单文件发布:
dotnet publish -r win10-x64 --self-contained=false /p:PublishSingleFile=true发布目录包含:
HelloWorld.exeHelloWorld.pdbHelloWorld.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.exeHelloWorld.pdb - 其余 219 个文件嵌入在主机中。
HelloWorld.exe
- 发布目录包含:
运行:
HelloWorld.exe- 首次运行时,219 个嵌入式文件将在启动时提取到磁盘。
- 应用的后续运行将重用提取,而不会产生启动开销。
调试
在应用的调试和分析方面,预计没有差异。
.net core 3.x 发布单文件的更多相关文章
- .NET Core 3.0 发布单文件可执行程序
Windows dotnet publish -r win10-x64 /p:PublishSingleFile=true maxOS dotnet publish -r osx-x64 /p:Pub ...
- VS2019(NET Core 3.0)发布单文件可执行程序
NET Core 3.0 发布单文件可执行程序 两种方法. 一.右击vs编辑项目文件,增加PublishSingleFile节点配置,代码如下: <Project Sdk="Micro ...
- .NET Core 3.0 Preview 5 亮点之一:发布单文件可执行程序
在阅读 Announcing .NET Core 3.0 Preview 5 时发现了 .NET Core 3.0 Preview 5 的一个新特性 —— Publishing Single EXEs ...
- .NET Core 新特性:发布单文件可执行程序
一.前言 .NET Core 3.0中新增加了一个特性:Publishing Single EXEs,可以通过dotnet publish 命令将整个.net core应用发布为一个可执行文件. 二. ...
- VS2017开发.net core 时默认发布路径文件夹多个BPC
新安装的VS2017,编译后进行发布,结果在bin文件夹下多了个BPC文件夹,很是费解,查了资料才知道是VS2017默认设置了环境变量.在此记录下,如果不需要默认路径可修改环境变量,具体操作如下: 我 ...
- VS2019 发布单文件
在项目.csproj文件下添加 <PropertyGroup> <OutputType>Exe</OutputType> <TargetFramework&g ...
- DotnetCore 单文件发布
NETCORE3.0开始,可以发布单文件,参考https://www.cnblogs.com/ZaraNet/p/11790645.html 发布后(config目录 是手工复制进去的) 运行时, ...
- ASP.NET Core应用针对静态文件请求的处理[1]: 以Web的形式发布静态文件
虽然ASP.NET Core是一款"动态"的Web服务端框架,但是在很多情况下都需要处理针对静态文件的请求,最为常见的就是这对JavaScript脚本文件.CSS样式文件和图片文件 ...
- 译 .NET Core 3.0 发布
原文:<Announcing .NET Core 3.0> 宣布.NET Core 3.0 发布 很高兴宣布.NET Core 3.0的发布.它包括许多改进,包括添加Windows窗体和W ...
- Web的形式发布静态文件
Web的形式发布静态文件 虽然ASP.NET Core是一款"动态"的Web服务端框架,但是在很多情况下都需要处理针对静态文件的请求,最为常见的就是这对JavaScript脚本文件 ...
随机推荐
- HDFS 重要机制之 checkpoint
核心概念 hdfs checkpoint 机制对于 namenode 元数据的保护至关重要, 是否正常完成检查点是评估 hdfs 集群健康度和风险的重要指标 editslog : 对 hdfs 操作的 ...
- BasicDataSourceFactory类简介
BasicDataSourceFactory实现了javax.naming.spi.ObjectFactory接口. 因此,先从ObjectFactory学习. 一.ObjectFactory接 ...
- java通过SSE实现消息推送
一.什么是SSE 严格地说,HTTP 协议无法做到服务器主动推送信息.但是,有一种变通方法,就是服务器向客户端声明,接下来要发送的是流信息(streaming). 也就是说,发送的不是一次性的数据包, ...
- Verilog代码规范
历史修改信息 版本 更改描述 更改人 批准人 修订日期/生效日期 A01 发布首版 ldy 一.目的 作为我司verilog开发过程中的输入文件,用于统一FPGA开发人员的代码风格.从而在满足功能和性 ...
- Nginx支持https访问
为了提高web应用的安全性,现在基本上都需要支持https访问.在此记录一下自己在nginx下的配置过程 安装Nginx这里就省略了 安装openssl模块 yum -y install openss ...
- 大便系统无法使用source的原因及解决方法
debian中shell脚本无法使用source的原因及解决方法 现象: shell脚本中source aaa.sh时提示 source: not found 原因: ls -l `which sh` ...
- 5.Kubeadm和二进制方式对比
Kubeadm方式搭建K8S集群 安装虚拟机,在虚拟机安装Linux操作系统[3台虚拟机] 对操作系统初始化操作 所有节点安装Docker.kubeadm.kubelet.kubectl[包含mast ...
- DDCA —— 内存架构和子系统&存储器控制器
1. 内存架构和子系统 1.1 如何控制访问? 访问控制: 存储单元的访问是通过 访问晶体管(access transistors) 进行控制的.访问晶体管像开关一样,可以连接或断开存储单元和位线(b ...
- 洛谷P4913【深基16.例3】二叉树深度题解
很简单的二叉树遍历问题,可以用dfs(深度优先搜索)解决. 看到数据范围,最大不超过 \(10^6\) ,可以不开 long long (但我还是习惯性地开了) 接下来上代码: #include< ...
- JUC (Java Util Concurrency) 基础内容概述
目录[-] 转自:http://www.goldendoc.org/2011/05/juc/ 1. JUC概况 2. 原子操作 3. 指令重排 4. Happens-before法则:(Java 内存 ...