.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 系统上迅速创建一个容器(轻量级虚拟机)并部署和运行应用程序 ...
随机推荐
- Catch That Cow 经典广搜
链接:http://poj.org/problem?id=3278 题目: Farmer John has been informed of the location of a fugitive co ...
- 分布式/微服务必配APM系统,SkyWalking让你不迷路
前言 如今分布式.微服务盛行,面对拆分服务比较多的系统,如果线上出现异常,需要快速定位到异常服务节点,假如还用传统的方式排查肯定效率是极低的,因为服务之间的各种通信会让定位更加繁琐:所以就急需一个分布 ...
- python jinja2初见
吸取了长城杯的教训,学习python-web迫在眉睫. 正常难度的python_template_injection,由于现在没学面向对象,理解原理比较困难,所以先使用简单版复现:并附上正常版的常用p ...
- go-zero 实战之 blog 系统
go-zero 实战项目:blog 本文以 blog 的网站后台为例,着重介绍一下如何使用 go-zero 开发 blog 的用户模块. 本文涉及的所有资料都已上传 github 仓库 kougazh ...
- Java:并发笔记-04
Java:并发笔记-04 说明:这是看了 bilibili 上 黑马程序员 的课程 java并发编程 后做的笔记 本章内容-3 线程状态转换 活跃性 Lock 3.10 重新理解线程状态转换 假设有线 ...
- 占位符,SQL注入?
这两天在上课时被同学拿了一段代码问我,这段代码有什么问题,我看了一会说:Connection和PreparedStatement都没关.他说不止这方面的问题,还有sql注入的问题,我就坚决的说使用了占 ...
- Scrum Meeting 0605
零.说明 日期:2021-6-5 任务:简要汇报两日内已完成任务,计划后两日完成任务 一.进度情况 组员 负责 两日内已完成的任务 后两日计划完成的任务 困难 qsy PM&前端 暂无 重新设 ...
- [对对子队]会议记录5.25(Scrum Meeting11)
今天已完成的工作 吴桐雨 工作内容:设计第10.11关 相关issue:设计额外关卡 相关签入:level10 level11 吴昭邦 工作内容:写测试代码 相关issue:测试初 ...
- OO助教工作总结
\(OO\)助教的工作结束了,在这一学期中,我主要负责对作业进行测试,对指导书进行检查,讨论区管理,部分数据构造,以及完成随班助教的工作. 测试 指导书检查 每次指导书公开前我都会先把指导书看 ...
- js基础学习之"=="与"==="的区别
var a = 1; var b = 1; var c = "1"; 1. "==" 可理解为相等运算符.相等运算符比较时,会自己进行类型转换,等于什么类型就会 ...