.NET Core应用类型(Portable apps & Self-contained apps)

介绍

有许多种方式可以用来考虑构建应用的类型,通常类型用来描述一个特定的执行模型或者基于此的应用。举例说:控制台应用(Console Application)、Web应用(Web Application)等等。所有这些类型的应用都可以用.NET Core来创建。.NET Core本身就是一个通用的开发平台。但是要赋予.NET Core跨平台的特性,.NET Core仍要需要一个角来发掘应用的类型,这被称为:应用的可移植性(application's portablility)。可移植性本质上意味着哪里可以运行你的应用程序以及要在某个特定的机器上运行需要满足哪些先决条件。下面我们要描述两种主要的.NET Core具有的可移植类型。

Portable applications

可移植应用是.NET Core的默认的应用类型。这需要.NET Core被事先安装到运行程序的目标机器上。这就意味着你作为开发人员,在不同的.NET Core装置之间你的程序是可移植的。这种类型的应用只需要携带、部署自身的代码和依赖即可(.NET Core库之外的)。为了创建一个可移植的应用程序,所有你需要做的就是在project.json里面设置目前.NET Core的类库,然后把frameworks改成如下所示:

"dependencies": {
 "Microsoft.NETCore.App": {
  "version": "1.0.0",
  "type": "platform"
 }
},
"frameworks": {
 "netcoreapp1.0": {}
}

【Microsoft.NETCore.App】是一个“元数据包”,它向你表明你的目标.NET Core类库。依赖里的【type:platform】属性意味着当发布时,发布工具将省略发布这些依赖的.NET Core类库文件,因为这些依赖类库文件已经随着.NET Core安装到目标服务器上了。

使用原生依赖的可以移植应用

使用原生依赖的可以移植应用是上面可移植应用的子集。这些可以移植的应用拥有一些在依赖链上特定地方指定的原生依赖,这样这些原生依赖项可以直接运行的目标平台,我们的可以移植程序也同样可以直接运行在这些平台上。最典型的例子就是我们的Kestrel服务器(ASP.NET 跨平台 Web 服务器),它的构建是基于libuv(原生依赖)。当你发布一个具有原生依赖的可移植应用时,所有的发布输出都和上述一致,至于原生依赖,发布输出则会为每一个RID(Runtime Identifier)生成一个文件夹。下面的project.json文件展示了一个可移植应用使用原生依赖:

"dependencies": {
 "Microsoft.NETCore.App": {
  "version": "1.0.0",
  "type": "platform"
 },
 "Microsoft.AspNetCore.Server.Kestrel": "1.0.0-*"
},
"frameworks": {
 "netcoreapp1.0": {}
}

Self-contained applications

和可移植的应用不同,独立的应用不依赖任何分享的组件在你准备部署程序的目标机器上。和它名字的暗示一样,它意味着整个依赖是闭环的,运行时将会和整个程序一起发布。这会使整个发布包变更大一些,但是这也使得程序可以使用正确的原生依赖运行在任何一个.NET Core支持的平台上(而不用管.NET Core是否已事先被安装到目标服务器上)。这使得更加容易去部署你的应用程序到目标服务器上。因为现在应用程序的发布会自身携带运行时,所以必须事先明确指定哪些平台你的程序将会运行。比如,如果你想发布一个独立的程序到Windows 10,但不准备运行到macOS和Linux,这样你在开发时必须新增或删除一些平台(platforms)。完成一个独立的程序会经历很多步骤,但第一步需要删除任何 "type": "platform"

属性。第二步是保留对Microsoft.NETCore.App的依赖,它会拉入一些我们需要的剩余的事情。最后,我们需要在project.json中添加一个运行时(runtimes)节点,以此来表明我们的程序将会在哪些平台上运行。

"dependencies": {
 "Microsoft.NETCore.App": "1.0.0"
},
"frameworks": {
 "netcoreapp1.0": {}
},
"runtimes": {
 "win10-x64": {},
 "osx.10.11-x64": {}
}

当我们restore项目时,如果project.json中包含runtimes节点,NuGet将会restore所有指定的运行时。接下来,当需要为给定的平台发布应用程序时,我们使用如下的命令行:

dotnet publish --runtime <RID>

RID必须是project.json中指定的RID,如:win10-x64或者osx.10.11-x64,否则会报错。如果你将要发布到的操作系统是你当前的.NET Core正在运行的操作系统,则直接使用如下命令即可:

dotnet publish

但是你仍然需要在project.json中指定对应的RID。

但需要注意的是:在.NET Core Tools Preview 2 的时间期限内,独立的应用是从本机NuGet缓存中发布的,这就意味着应用所有的依赖包括.NET Core运行时和类库并不是运行优化的。因此,独立的应用比可移植的应用整体上性能要低,原因在于可移植应用所依赖的.NET Core运行时和类库都是随时可以运行(ready-to-run)的。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • .NET Core 1.0创建Self-Contained控制台应用

    开发机器:win7-x64 .NET Core版本:1.0.0-preview2-003121 Visual Studio Code:1.2.1 至于什么是Self-Contained应用类型以及与Portable应用类型的区别,请参考另一篇文章:.NET Core应用类型(Portable apps & Self-contained apps),这篇文章仅仅是做一个完整的Demo供大家参考. 1.在指定目录创建一个HelloWorld的目录,使用命令行切换到此目录,执行:dotnet new

  • .NET调用控制台下生成的exe文件,传参及获取返回参数的思路及代码

    最近客户要求把一个树型目录导出成文件夹套文件夹的结构,并提供下载功能,刚开始感觉功能比较容易实现就在最短的时间把基本功能搞定,当发布到服务器上之后发现直接在本应用程序中导出目录(下带ntko文档及附件)再进行压缩,程序直接卡死了!后来就想到了要做一window服务,只是客户给的时间太短,没办法先写一控制台程序生成一个exe文件,然后再调用这个exe文件,这样就可以缓解本程序压力了! 下面写一个测试项目 在调用exe端传过去一个要压缩的文件夹的路径,然后在控制台下获取该路径进行压缩,压缩完成之后返

  • .NET Core应用类型(Portable apps & Self-contained apps)

    介绍 有许多种方式可以用来考虑构建应用的类型,通常类型用来描述一个特定的执行模型或者基于此的应用.举例说:控制台应用(Console Application).Web应用(Web Application)等等.所有这些类型的应用都可以用.NET Core来创建..NET Core本身就是一个通用的开发平台.但是要赋予.NET Core跨平台的特性,.NET Core仍要需要一个角来发掘应用的类型,这被称为:应用的可移植性(application's portablility).可移植性本质上意味

  • ASP.NET Core程序发布到Linux生产环境详解

    在这篇文章里我们将介绍如何在 Ubuntu 14.04 Server上部署ASP.NET Core应用程序.我们将把ASP.NET Core应用程序放到一个反向代理服务器的后面,由代理服务器把请求转交给我们的Kestrel服务器.除此之外,我们还将保证我们的web应用程序作为一个守护进程来进行启动.我们需要配置一个进程管理工具来帮助我们在程序崩溃时恢复程序,以保证高可用性. 章节: 准备 复制你的应用程序 配置一个反向代理服务器 监控我们的应用程序 启动我们的应用程序 观察日志 使我们的应用程序

  • Entity Framework Core实现软删除与查询过滤器

    注意:我使用的是 Entity Framework Core 2.0 (2.0.0-preview2-final).正式版发布后,功能可能存在变动. 继续探索Entity Framework Core 2.0,今天我将探讨如何轻松使用软删除(或逻辑删除).我的意思是以透明的方式实现软删除,例如,您是物理上的删除行. 要实现软删除,您需要添加一列以指示该行数据是否被逻辑删除.如果您想知道该行被删除,可以使用布尔列,如果您想知道删除的时间,可以使用日期列.其次是更改所有查询,使用此列过滤结果集:您还

  • Django+Vue实现WebSocket连接的示例代码

    近期有一需求:前端页面点击执行任务,实时显示后端执行情况,思考一波:发现 WebSocket 最适合做这件事. 效果 测试 ping www.baidu.com 效果 点击连接建立ws连接 后端实现 所需软件包 后端主要借助Django Channels 实现socket连接,官网文档链接 这里想实现每个连接进来加入组进行广播,所以还需要引入 channels-redis . pip channels==2.2.0 channels-redis==2.4.0 引入 settings.py INS

  • 详解iOS应用开发中的ARC内存管理方式

    提示:本文中所说的"实例变量"即是"成员变量","局部变量"即是"本地变量" 零.简介 ARC是自iOS 5之后增加的新特性,完全消除了手动管理内存的烦琐,编译器会自动在适当的地方插入适当的retain.release.autorelease语句.你不再需要担心内存管理,因为编译器为你处理了一切 注意:ARC 是编译器特性,而不是 iOS 运行时特性(除了weak指针系统),它也不是类似于其它语言中的垃圾收集器.因此 ARC

  • Swift使用Cocoa中的数据类型教程

    作为对 Objective-C 互用性(互操作性)的一部分,Swift提供快捷高效的方式来处理Cocoa数据类型. Swift 会自动将一些 Objective-C 类型转换为 Swift 类型,以及将 Swift 类型转换为 Objective-C 类型.在 Objective-C 和 Swift 中也有一些具有互用性的数据类型.那些可转换的数据类型或者具有互用性的数据类型被称为bridged数据类型.举个例子,在 Swift 中,您可以将一个Array值传递给一个要求为NSArray对象的方

  • ASP.NET MVC5+EF6+EasyUI 后台管理系统(81)-数据筛选(万能查询)实例

    前言 听标题的名字似乎是一个非常牛X复杂的功能,但是实际上它确实是非常复杂的,我们本节将演示如何实现对数据,进行组合查询(数据筛选) 我们都知道Excel中是如何筛选数据的.就像下面一样 他是一个并的关系,我们现在要做的也是这样的效果,下面我们将利用EasyUI的DataGrid为例来扩展(就算是其他组件也是可以的,同样的实现方式!) 实现思路 1.前台通过查询组合json 2.后台通过反射拆解json 3.进行组合查询 虽然短短3点,够你写个3天天夜了 优点:需要从很多数据中得到精准的数据,通

  • Django中的Signal代码详解

    本文研究的主要是Django开发中的signal 的相关内容,具体如下. 前言 在web开发中, 你可能会遇到下面这种场景: 在用户完成某个操作后, 自动去执行一些后续的操作. 譬如用户完成修改密码后, 你要发送一份确认邮件. 当然可以把逻辑写在一起,但是有个问题是,触发操作一般不止一种(如用户更改了其它信息的确认邮件),这时候这个逻辑会需要写多次,所以你可能会想着DRY(Don't repeat yourself),于是你把它写到了一个函数中,每次调用.当然这是没问题的. 但是, 如果你换个思

  • django rest framework 数据的查找、过滤、排序的示例

    对于管理系统,常常需要展示列表数据,我们对于列表内的数据常常需要查找.过滤.排序等操作,其中查找等操作大部分是在后台进行的.django rest framework可以轻松的实现数据的查找.过滤等操作.接下来我们将以实际的例子进行介绍. 示例代码github地址: https://github.com/jinjidejuren/drf_learn 例如cmdb系统,作为资产管理系统常常需要对数据进行过滤或查找,获取期望的信息. 实现model 1.在这个示例项目中,需要实现对物理服务器的条件过

随机推荐