.net打独立运行环境遇到无法trim遇到的bug
背景介绍
工作中我用到kotlin写代码,在orm上ktorm是一款非常优秀的操作db的框架,我喜欢用它所以我写了一个插件能够增加我的工作效率,这款idea插件的主体逻辑是.net开发的(没错是跨平台的.net)。因为db-schema的解析逻辑我很在以前写的一个visualstudio的插件就搞过了,所以改改就行了!
这里也算是提供给大家另外一个思路去开发idea或者rider插件路吧:
就是不管你用什么语言开发逻辑,然后把你的逻辑打包成可以独立运行,然后使用Process进行套壳调用就行了。
如何进行套壳调用请参考我写的:ktorm的idea代码生成器插件
代码位置: src/main/kotlin/CodeGen.kt
遇到的问题
来自一个issue Mac上Sqlserver运行出错,可能是配置问题?
因为以前都没有在mac机器上测试过,所以才没有发现这个bug:
原因是:sqlserver客户端驱动得从 System.Data.SqlClient 换成 Microsoft.Data.SqlClient
因为后者才是跨平台的
好了,.net自从跨平台开始就已经支持打包独立运行时了。我改好bug后按照往常一样用下面的命令打包:
windows平台:dotnet publish -r win-x64 -c Release --self-contained true mac平台:dotnet publish -r osx-x64 -c Release --self-contained true linux平台:dotnet publish -r linux-x64 -c Release --self-contained true
由于上面的命令打的包很大,所以我加了下面几个参数
/p:PublishSingleFile=true (打包成单个文件) /p:PublishTrimmed=true (打包的时候去掉不必要依赖减少体积) /p:IncludeNativeLibrariesForSelfExtract=true(用到指定平台native环境依赖也一起打包到单个文件)
这样打出来的单个平台的独立运行包就会从70M左右变成20M左右,因为我的idea插件是要支持windows和mac这2个平台的,所以需要mac平台20M和windows平台20M都要同时打进一个jar包后大概是18M的大小(压缩能力可以),支持双平台这个大小可以接受吧!

但是问题来了,换成 Microsoft.Data.SqlClient后,运行sqlserver的逻辑会报一个错:
Column requires a valid DataType.

因为本次改动只是换了一个依赖,所以肯定是这个依赖不能Trim,果然把Trim的开关给去掉之后就没有这个报错了。
找了下相关资料说是可以针对某个依赖不Trimmer
<ItemGroup>
<TrimmerRootAssembly Include="Microsoft.Data.SqlClient" />
</ItemGroup>
不过即使加了这个也没有解决!有哪位大佬知道怎么搞请留言教育下我!
既然不能加trim的话那包就太大了。如何解决呢
解决方案
https://github.com/dgiagio/warp
介绍如下:
Warp lets you create self-contained single binary applications
making it simpler and more ergonomic to deliver your application to your customers.
A self-contained binary is specially convenient when the technology you use,
such as Node.js, .NET Core, Java and others,
contain many dependencies that must be shipped alongside your application.
Warp is written in Rust and is supported on Linux, Windows and macOS.
这是一个大佬用Rust写的支持把你的所有依赖打包独立运行时,支持windows,mac,linux跨平台的。
使用方式:
首先准备好你要打包的目录,这里我新建一个warp文件夹,然后把没有trimmer的包含运行时的独立包给放进去

然后去大佬的github上下载windows平台的warp-packer.exe
然后运行:
warp-packer.exe --arch windows-x64 --input_dir warp --exec AntOrmGen.exe --output AntOrmGen.exe
打出来的包同样是包含独立运行时的,体积减少到了20M
同样的方式到mac上进行同样的操作

研究了一下这个打包运行的原理,其实它时将你的依赖全部压缩放进了它打出来的成果物里了
然后你运行它的时候会解压出来,在windows平台的解压路径为:C:\Users{User}\AppData\Local\warp\packages\

由于它自带了压缩功能,所以体积才减少到了20M左右!
以上研究遇到的一个坑点: 我刚开始发现的是有个大佬把上面的工具封装成了一个 dotnet-tool
按照下面的命令进行安装
$ dotnet tool install --global dotnet-warp
可以指定r参数来区分平台
dotnet-warp -r win-x64
dotnet-warp -r osx-x64
这里要注意一点,打包mac的得去mac系统,不要在windows系统操作生成mac端,虽然可以打包成功,但是拿到mac系统运行会报错。
最后
自从.net跨平台之后,在很多方面都可以派上用场,可以用来blazor开发chrome插件(基于webassbemly)link,还可以开发idea插件。是不是很好玩!
Enjoy!!!
关注公众号一起学习
.net打独立运行环境遇到无法trim遇到的bug的更多相关文章
- Linux/CentOS7搭建Anaconda运行环境
1. 安装miniconda 下载并安装miniconda到$HOME/.miniconda/ #从官网下载 wget -c "https://repo.anaconda.com/minic ...
- docker 和 vagrant 作为程序发布 和 开发的独立而统一的运行环境
docker 和 vagrant 作为程序发布 和 开发的运行环境,可以提供打包程序,并使得程序运行在一个独立的虚拟环境中,避免程序发布到客户机之后,环境不一致导致的诸多问题. refer: ...
- 为应用创建多个独立python运行环境
在开发Python应用程序的时候,系统安装的Python3只有一个版本:3.4.所有第三方的包都会被pip安装到Python3的site-packages目录下. 如果我们要同时开发多个应用程序,那这 ...
- 理解Docker(3):Docker 使用 Linux namespace 隔离容器的运行环境
本系列文章将介绍Docker的有关知识: (1)Docker 安装及基本用法 (2)Docker 镜像 (3)Docker 容器的隔离性 - 使用 Linux namespace 隔离容器的运行环境 ...
- 【转】如何使用VS 2013发布一个可以在Windows XP中独立运行的可执行文件
问题描述: 用VS2013写好一个程序,在本机上运行一切正常.但是如果直接把exe文件放到另一台机器上用,则会出现: Windows XP:不是一个正常的win32程序 Window 7:缺少msvc ...
- [转]virtualenv建立多个Python独立开发环境
不同的人喜欢用不同的方式建立各自的开发环境,但在几乎所有的编程社区,总有一个(或一个以上)开发环境让人更容易接受. 使用不同的开发环境虽然没有什么错误,但有些环境设置更容易进行便利的测试,并做一些重复 ...
- hadoop:将WordCount打包成独立运行的jar包
hadoop示例中的WordCount程序,很多教程上都是推荐以下二种运行方式: 1.将生成的jar包,复制到hadoop集群中的节点,然后运行 $HADOOP_HOME/bin/hadoop xxx ...
- [转].NET程序在windows操作系统上独立运行的技术要点
发现一个不错的网站,转载一篇文章方便查看 转自 http://www.linuxdot.net/bbsfile-3354 ===================================== ...
- Docker学习笔记之一,搭建一个JAVA Tomcat运行环境
Docker学习笔记之一,搭建一个JAVA Tomcat运行环境 前言 Docker旨在提供一种应用程序的自动化部署解决方案,在 Linux 系统上迅速创建一个容器(轻量级虚拟机)并部署和运行应用程序 ...
随机推荐
- 从 MVC 到使用 ASP.NET Core 6.0 的最小 API
从 MVC 到使用 ASP.NET Core 6.0 的最小 API https://benfoster.io/blog/mvc-to-minimal-apis-aspnet-6/ 2007 年,随着 ...
- 更好的 java 重试框架 sisyphus 背后的故事
sisyphus 综合了 spring-retry 和 gauva-retrying 的优势,使用起来也非常灵活. 今天,让我们一起看一下西西弗斯背后的故事. 情景导入 简单的需求 产品经理:实现一个 ...
- netty系列之:让TLS支持http2
目录 简介 TLS的扩展协议NPN和ALPN SslProvider ApplicationProtocolConfig 构建SslContext ProtocolNegotiationHandler ...
- Go语言核心36讲(Go语言进阶技术五)--学习笔记
11 | 通道的高级玩法 我们已经讨论过了通道的基本操作以及背后的规则.今天,我再来讲讲通道的高级玩法. 首先来说说单向通道.我们在说"通道"的时候指的都是双向通道,即:既可以发也 ...
- 整数划分为k份
题目 将整数n分成k份,且每份不能为空,任意两个方案不能相同(不考虑顺序). 例如:n=7,k=3,下面三种分法被认为是相同的. 1,1,5; 1,5,1; 5,1,1; 问有多少种不同的分法. 输入 ...
- 第5次 Beta Scrum Meeting
本次会议为Beta阶段第6次Scrum Meeting会议 会议概要 会议时间:2021年6月6日 会议地点:「腾讯会议」线上进行 会议时长:10min 会议内容简介:对完成工作进行阶段性汇报:对下一 ...
- 【二食堂】Alpha - Scrum Meeting 1
Scrum Meeting 1 例会时间:4.10 8:00 - 8:30 进度情况 组员 上周进度 明日任务 李健 1. 在Anaconda3中搭建了python和django的环境issue1. ...
- Noip模拟50 2021.9.10
已经好长时间没有考试不挂分的良好体验了... T1 第零题 开场数据结构,真爽 对于这道题首先要理解对于一条链从上向下和从下向上走复活次数相等 (这可能需要晚上躺在被窝里面脑摸几种情况的样例) 然后就 ...
- TCP/IP简述
一.TCP/IP简述 TCP/IP从字面异议看起来是指TCP和IP两种协议,实际上,它只是利用IP进行通信时必须用到的协议群的统称.具体的来说,IP或ICMP.TCP或UDP.Telnet或FTP.以 ...
- linux cut
参考:Linux cut 命令详解_Linux_脚本之家 (jb51.net) 参考:cut命令_Linux cut 命令用法详解:连接文件并打印到标准输出设备上 (linuxde.net)