温故知新,DotNet Core SDK和.Net CLI十八般武艺
简介
.NET命令行接口 (CLI) 工具是用于开发、生成、运行和发布.NET应用程序的跨平台工具链。

https://docs.microsoft.com/zh-cn/dotnet/core/tools/
SDK
| 里程碑 | 发布日期 |
|---|---|
| .NET Core 2.1.x (servicing) | LTS (Long Term Support) release. Approximately every 1-2 months or as needed. |
| .NET Core 3.1.x (servicing) | LTS (Long Term Support) release. Approximately every 1-2 months or as needed. |
| .NET 5.0 | Release scheduled for November 2020 |
| .NET 6.0 | LTS (Long Term Support) release, scheduled for November 2021 |
| .NET 7.0 | Release scheduled for November 2022 |
| .NET 8.0 | LTS (Long Term Support) release, scheduled for November 2023 |
- https://dotnet.microsoft.com/learn/dotnet/hello-world-tutorial/install
- https://github.com/dotnet/core/blob/main/roadmap.md
检查安装
dotnet

新建
dotnet new $templateName

其中常见的模板名称有:
| 模板名字 | 短名称 | 版本要求 |
|---|---|---|
| 控制台应用程序 | console |
>= 1.0 |
| 类库 | classlib |
>= 1.0 |
| WPF应用程序 | wpf |
>= 3.0 |
| WPF类库 | wpflib |
>= 3.0 |
| WPF自定义控件库 | wpfcustomcontrollib |
>= 3.0 |
| WPF用户控件库 | wpfusercontrollib |
>= 3.0 |
| Windows窗体(WinForms) 应用程序 | winforms |
>= 3.0 |
| Windows窗体(WinForms)类库 | winformslib |
>= 3.0 |
| Worker Service | worker |
>= 3.0 |
| 单元测试项目 | mstest |
>= 1.0 |
| NUnit 3测试项目 | nunit |
>= 2.1 |
| NUnit 3测试项 | nunit-test |
>= 2.2 |
| xUnit 测试项目 | xunit |
>= 1.0 |
| Razor组件 | razorcomponent |
>= 3.0 |
| Razor页 | page |
>= 2.0 |
| MVC ViewImports | viewimports |
>= 2.0 |
| MVC ViewStart | viewstart |
>= 2.0 |
| Blazor 服务器应用 | blazorserver |
>= 3.0 |
| Blazor WebAssembly应用 | blazorwasm |
>= 3.1 |
| ASP.NET Core空 | web |
>= 1.0 |
| ASP.NET Core Web应用程序 (Model-View-Controller) | mvc |
>= 1.0 |
| ASP.NET Core Web 应用程序 | webapp, razor |
>= 2.0 |
| 含 Angular 的ASP.NET Core | angular |
>= 2.0 |
| 含 React.js 的ASP.NET Core | react |
>= 2.0 |
| 含 React.js 和 Redux 的ASP.NET Core | reactredux |
>= 2.0 |
| Razor类库 | razorclasslib |
>= 2.1 |
| ASP.NET Core Web API | webapi |
>= 1.0 |
| ASP.NET Core gRPC服务 | grpc |
>= 3.0 |
| dotnet gitignore文件 | gitignore |
>= 3.0 |
| global.json文件 | globaljson |
>= 2.0 |
| NuGet配置 | nugetconfig |
>= 1.0 |
| Dotnet本地工具清单文件 | tool-manifest |
>= 3.0 |
| Web配置 | webconfig |
>= 1.0 |
| 解决方案文件 | sln |
>= 1.0 |
| 协议缓冲区文件 | proto |
>= 3.0 |
可选参数--list可查看本地安装的所有模板
dotnet new --list

可选参数-f 指定目标框架版本号
dotnet new $templateName -f $frameworkName

net5.0netcoreapp3.1netcoreapp3.0netcoreapp2.1
dotnet new webapi -f netcoreapp2.1


dotnet new webapi -f netcoreapp3.1


dotnet new webapi -f netcoreapp2.2


dotnet new webapi -f net5.0


可选参数-n 指定创建的输出名称,否认默认是当前文件夹名称
dotnet new webapi -n $projectName


https://docs.microsoft.com/zh-cn/dotnet/core/tools/dotnet-new
可选参数-o 指定输出目录,默认是当前目录
dotnet new webapi -o $projectName

可选参数--no-https关闭默认HTTPS要求,方便开发调试
dotnet new webapi -o $projectName --no-https

还原依赖
dotnet restore
dotnet restore $target.csproj

运行
dotnet run


输出文件会写入到默认位置,即bin/<configuration>/<target>。 例如,如果具有netcoreapp2.1应用程序并且运行dotnet run,则输出置于bin/Debug/netcoreapp2.1。 将根据需要覆盖文件。临时文件将置于obj目录。
如果在上下文中,需要直接运行某个文件,可以用
dotnet $fileName

禁止隐式还原
dotnet run --no-restore

禁止生成项目
dotnet run --no-build

生成
dotnet build

dotnet build命令将项目及其依赖项生成为一组二进制文件。 二进制文件包括扩展名为.dll的中间语言 (IL) 文件中的项目代码。
根据项目类型和设置,可能会包含其他文件,例如:
- 可用于运行应用程序的可执行文件(如果项目类型是面向
.NET Core 3.0或更高版本的可执行文件)。 - 用于调试的扩展名为
.pdb的符号文件。 - 列出了应用程序或库的依赖项的
.deps.json文件。 - 用于指定应用程序的共享运行时及其版本的
.runtimeconfig.json文件。 - 项目通过项目引用或 NuGet 包引用所依赖的其他库。
对于目标版本低于.NET Core 3.0的可执行项目,通常不会将NuGet中的库依赖项复制到输出文件夹。 而是在运行时从NuGet全局包文件夹中对其进行解析。


对于面向.NET Core 3.0及更高版本的可执行项目,库依赖项会被复制到输出文件夹。 这意味着如果没有其他任何特定于发布的逻辑(例如,Web项目具有的逻辑),则应可部署生成输出。


输出可执行文件还是输出库的配置
要生成库,请省略<OutputType>属性或将其值更改为Library
<PropertyGroup>
<OutputType>Exe</OutputType>
</PropertyGroup>

<PropertyGroup>
<OutputType>Library</OutputType>
</PropertyGroup>

指定生成模式
DebugRelease
dotnet build -c Release

dotnet build -c Debug

指定文件版本
dotnet build -p:Version=$targetVersion


清理
dotnet clean
dotnet clean -c Release

打包
dotnet pack
dotnet pack -c Release

默认情况下,Web 项目不可打包。 若要覆盖默认行为,请将以下属性添加到 .csproj 文件中
<PropertyGroup>
<IsPackable>true</IsPackable>
</PropertyGroup>
Nuget
添加源
dotnet nuget add source $nugetUrl -n $sourceName

列举源
dotnet nuget list source

删除源
dotnet nuget remove source $sourceName

推送包到指定源
dotnet nuget push $packageName.nupkg -k $sourceAuthKey -s $sourceUrl

删除包
dotnet nuget delete $packageName $packageVersion -s $sourceName

发布
dotnet publish


以dll文件的形式将应用发布为依赖于框架的应用时,将创建跨平台二进制文件。 dll文件将与项目同名。 例如,如果有名为demoForWebApp3.1的应用,则会创建名为demoForWebApp3.1.dll的文件。 以这种方式发布的应用可通过dotnet <filename.dll>命令运行,并且可在任意平台上运行。
只要安装了目标.NET 运行时,就可以在任何操作系统上运行跨平台二进制文件。 如果未安装目标.NET运行时,如果将应用配置为前滚,则它可以使用较新的运行时运行。
指定框架的发布
--runtime=>-r
dotnet publish -r linux-x64 --self-contained false
dotnet publish -r win-x64 --self-contained false



所有可选的框架清单:https://docs.microsoft.com/zh-cn/dotnet/core/rid-catalog
其中--self-contained false参数表示不包括对应框架运行时。
dotnet publish -r linux-x64
dotnet publish -r win-x64
将包含完整的目标框架运行时+程序
将应用发布为独立应用,将生成特定于平台的可执行文件。 输出发布文件夹包含应用的所有组件,包括.NET库和目标运行时。 应用独立于其他.NET应用,且不使用本地安装的共享运行时。 应用的用户无需下载和安装.NET。


直接生成ReadyToRun映像
dotnet publish -c Release -r win-x64 -p:PublishReadyToRun=true

使用ReadyToRun映像发布可以缩短应用程序的启动时间,但代价是增加应用程序的大小。
https://docs.microsoft.com/zh-cn/dotnet/core/deploying/#produce-a-cross-platform-binary
指定项目文件发布
dotnet publish $packageName.csproj

监听并自动生成
开发阶段在源文件发生变动的情况下就自动执行
dotnet build
dotnet watch run


包管理
添加包
dotnet add package $packageName
dotnet add package $packageName -v $packageVersion

查看已安装包
dotnet list package

移除某安装包
dotnet remove package $packageName

用VSC打开当前目录
先cd到需要打开的当前目录,然后输入命令:
code .


让VSC支持C#语法检查
只要安装C#插件即可。


让VSC支持自动Using
只要安装Auto-Using for C#这个插件即可。


温故知新,DotNet Core SDK和.Net CLI十八般武艺的更多相关文章
- 腾讯云 docker 镜像 dotnet/core sdk aspnet
ccr.ccs.tencentyun.com/mcr.microsoft.com/dotnetcoresdk = mcr.microsoft.com/dotnet/core/sdk => 3 ...
- 使用mongodb提供的dotnet core sdk进行地理位置运算
mongodb提供地理位置运算功能,比较常用的场景比如,先判断用户所在的街道,然后看看街道附近有啥餐厅,然后算算用户与餐厅的距离什么的,官网里提供了比较详细的demo介绍不同api的用法 此处记录下d ...
- dotnet core sdk 2.1 在centos下的安装
1. 安装微软的仓库 rpm -Uvh https://packages.microsoft.com/config/rhel/7/packages-microsoft-prod.rpm 2. 修改仓库 ...
- ServiceStack DotNet Core前期准备
下载DotNet Core SDK 下载地址:https://dotnet.microsoft.com/download. 安装完成之后通过cmd的命令行进行确认. 官方自带的cmd比较简陋,可以用c ...
- 使用 dotnet core 和 Azure PaaS服务进行devOps开发(Web API 实例)
作者:陈希章 发表于 2017年12月19日 引子 这一篇文章将用一个完整的实例,给大家介绍如何基于dotnet core(微软.NET的最新版本,支持跨平台,跨设备的应用开发,详情请参考 https ...
- devOps开发(Web API 实例)dotnet core 和 Azure PaaS服务
使用 dotnet core 和 Azure PaaS服务进行devOps开发(Web API 实例) 作者:陈希章 发表于 2017年12月19日 引子 这一篇文章将用一个完整的实例,给大家介绍如何 ...
- dotnet core 跨平台编译发布
vs2017 建立的项目,在项目目录 ,执行 dotnet publish -r ubuntu.15.04-x64 dotnet publish -r linux-x64 dotnet publish ...
- Docker系列之AspNetCore Runtime VS .NetCore Runtime VS .NET Core SDK(四)
前言 接下来我们就要慢慢步入在.NET Core中使用Docker的殿堂了,在开始之前如题,我们需要搞清楚一些概念,要不然看到官方提供如下一系列镜像,我们会一脸懵逼,不知道到底要使用哪一个. AspN ...
- 【ASP.NET Core分布式项目实战】(五)Docker制作dotnet core控制台程序镜像
Docker制作dotnet core控制台程序镜像 基于dotnet SDK 新建控制台程序 mkdir /home/console cd /home/console dotnet new cons ...
随机推荐
- Mybatis-plus在原有的select查询语句中动态追加查询条件
一.适用场景 1.使用了xml形式的mapper.2.不想在select查询中大量使用<if>标签来判断条件是否存在而加入条件. 二.步骤 1.自定义wrapper继承QueryWrapp ...
- grub救援模式
http://www.jinbuguo.com/linux/grub.cfg.html
- head元素的内容
一.head元素 head元素的内容用来向浏览器提供一些文档信息,此外还可以包含js脚本和css层叠样式单.head中一般包含title.meta.css.js等内容,head中元素的内容在浏览器中不 ...
- Fio 输出内容的解释
Fio 输出内容的解释 feilianbb 2016-01-11 16:18:54 27828 收藏 19 文章标签: Linux 存储 Fio SSD 性能 翻译原文来源 https://t ...
- iozone的使用与介绍-20191105
https://www.jianshu.com/p/faf82e400aa6 iozone的使用与介绍 0.0722017.05.10 07:40:41字数 550阅读 1817 iozone的使用与 ...
- 二进制部署K8S-2集群部署
二进制部署K8S-2集群部署 感谢老男孩教育王导的公开视频,文档整理自https://www.yuque.com/duduniao/k8s. 因为在后期运行容器需要有大量的物理硬件资源使用的环境是用的 ...
- Ansible_实施处理程序
一.Ansible配置处理程序 1.处理程序 1️⃣:处理程序是响应由其他任务触发的通知的任务 2️⃣:仅当任务在受管主机上更改了某些内容时,任务才通知其处理程序 3️⃣:每个处理程序具有全局唯一的名 ...
- "sar"工具 利用率
LTP--linux稳定性测试 linux性能测试 ltp压力测试 余二五 2017-11-14 16:20:00 浏览1172 linux 日志 配置 内存管理 测试 脚本 性能测试 压力测试 ...
- C++知识点案例 笔记-2
1.友元函数 2.友元类 3.继承(公有继承) 4.公有继承的访问权限 5.私有继承的访问权限 6.保护继承的访问权限(两次继承) ==友元函数== #include <iostream> ...
- Linux服务之批量部署篇
批量部署步骤: 1.检查环境 getenforce #检查内核防火墙是否关闭 systemctl status firewalld #检查firewalld是否 ...