Electron 应用打包
为舒缓 Windows
下路径名过长的问题 issues
,稍微加快 require
的速度以及简单隐匿源代码,我们可以选择把应用打包成 asar
档案文件,这只需要对源代码做一些很小的改动。大部分用户可以轻松实现这个功能,因为它在 electron-packager
、electron-forge
和 electron-builder
中都得到了支持,开箱即用。
生成asar包
asar
是一种将多个文件合并成一个文件的类 tar
风格的归档格式。Electron
无需解压整个文件,就可以从其中读取任意文件内容。 可以按如下步骤来将应用打包成 asar
:
- 安装
asar
:
$ npm install -g asar
- 使用
asar pack
打包:
$ asar pack your-app app.asar
使用asar包
在 Electron
中有两类 APIs
,分别是 Node.js
提供的 Node API
和 Chromium
提供的 Web API
。这两种 API
都支持从 asar
包中读取文件。
Node API
由于 Electron
中打了特别补丁, Node API
中如 fs.readFile
或者 require
之类的方法可以将 asar
视之为虚拟文件夹,读取 asar
里面的文件就和从真实的文件系统中读取一样。
示例:
例如假设我们在 /path/to
文件夹下有个 example.asar
包:
$ asar list /path/to/example.asar /app.js /file.txt /dir/module.js /static/index.html /static/main.css /static/jquery.min.js
从 asar
包读取一个文件:
const fs = require('fs'); fs.readFileSync('/path/to/example.asar/file.txt');
列出 asar
包中根目录下的所有文件:
const fs = require('fs'); fs.readdirSync('/path/to/example.asar');
使用 asar
包中的一个模块:
const BrowserWindow = require('electron').BrowserWindow; var win = new BrowserWindow({width: 800, height: 600}); win.loadURL('file:///path/to/example.asar/static/index.html');
Web API
在 Web
页面里,用 file:
协议可以获取 asar
包中文件。和 Node API
一样,视 asar
包如虚拟文件夹。
示例:
例如可以使用 $.get
来获取文件:
<script> var $ = require('./jquery.min.js'); $.get('file:///path/to/example.asar/file.txt', function(data) { console.log(data); }); </script>
把asar包当作一个普通的文件
某些情况下,例如对 asar
包文件进行校验,我们需要像读取 “文件” 那样读取 asar
包文件。 为此我们可以使用内置的没有 asar
功能的和原始 fs
模块一模一样的 original-fs
模块。
示例:
const originalFs = require('original-fs') originalFs.readFileSync('/path/to/example.asar')
也可以将 process.noAsar
设置为 true
,用来禁用 fs
模块中对 asar
的支持:
const fs = require('fs') process.noAsar = true fs.readFileSync('/path/to/example.asar')
Node API缺陷
尽管我们已经尽了最大努力使得 asar
包在 Node API
下的应用尽可能的趋向于真实的目录结构,但仍有一些底层 Node API
我们无法保证其正常工作。
asar包文件是只读的
asar
包中的内容不可更改,所以 Node APIs
里那些可以用来修改文件的方法在对待 asar
包时都无法正常工作。
工作目录在 asar 包中无效
尽管 asar
包是虚拟文件夹,但其实并没有真实的目录架构对应在文件系统里,所以我们不可能将工作目录 working Directory
设置成 asar
包里的一个文件夹。将 asar
中的文件夹以 cwd
形式作为参数传入一些 API
中也会报错。
某些API需要额外解压的asar包
大部分 fs
可以无需解压即从 asar
包中读取文件或者文件的信息,但是在处理一些依赖真实文件路径的底层系统方法时,Electron
会将所需文件解压到临时目录下,然后将临时目录下的真实文件路径传给底层系统方法使其正常工作。 对于这类 API
,花销会略多一些。
以下是一些需要额外解压的 API
:
child_process.execFile
child_process.execFileSync
fs.open
fs.openSync
process.dlopen
fs.stat的不真实统计信息
对 asar
包中的文件取 fs.stat
,返回的 Stats
对象不是精确值,因为这些文件不是真实存在于文件系统里。所以除了文件大小和文件类型以外,我们不应该依赖 Stats
对象的值。
执行asar包中的二进制文件
Node
中有一些可以执行程序的 API
,如 child_process.exec
,child_process.spawn
和 child_process.execFile
等,但只有 execFile
可以执行 asar
包中的程序。
因为 exec
和 spawn
允许 command
替代 file
作为输入,而 command
是需要在 shell
下执行的,目前没有可靠的方法来判断 command
中是否在操作一个 asar
包中的文件,而且即便可以判断,我们依旧无法保证可以在无任何副作用的情况下替换 command
中的文件路径。
添加未打包的文件到asar包
一些 Node API
会在调用时将文件解压到文件系统中,除了效率问题外,也有可能引起杀毒软件的注意!
为解决这个问题,我们可以在生成 asar
包时使用 --unpack
选项来排除一些文件,使其不打包到 asar
包中,下面是如何排除一些用作共享用途的 native
模块的方法:
$ asar pack app app.asar --unpack *.node
经过上述命令后,除了生成的 app.asar
包以外,还有一个包含了排除文件的 app.asar.unpacked
文件夹,我们需要将这个文件夹一起拷贝,提供给用户。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
信号量Semaphore一篇文章叫你明白
已经习惯了阿里面试官的冷笑:用过Semaphore吧,不妨说说? 本质就是 信号量模型,模型图如下: 其中的 计数器 和 等待队列 对外部是透明的,仅能通过提供的三大方法访问它们。 详细说说哪三大方法? init() 用于设置计数器的初始值。 down() 计数器-1。若此时计数器<0,则当前线程被 阻塞。 up() 计数器+1。若此时计数器≤0,则唤醒 等待队列 中的一个线程,并将其从【等待队列】移除。有同学可能会认为这里的判断条件应该≥0,估计你是理解成生产者-消费者模式中的生产者了。可以反过来想,>0 意味着没有阻塞的线程,所以只有 ≤0 时才需要唤醒一个等待的线程。 down()、up()应配对使用,并按序使用: 先调用down(),获取锁 执行处理完后,调用up(),释放锁 若信号量init值为1,并发场景下应该不会出现>0情况,除非故意调先用up(),但这也失去了信号量的意义。 注意,这些方法都是原子性的,由信号量模型的实现方保证。JDK里的信号量模型就是由Semaphore实现,Semaphore保证了这三个方法都是原子操作。 talk is cheap...
- 下一篇
关于Pulsar与Kafka的一些比较和思考
Pulsar是一款分布式发布/订阅消息平台,近两年非常火,被称为下一代的消息流平台,大有取代Kafka的势头。今天我们就来比较一下Pulsar跟Kafka。 历史背景 Pulsar源自Yahoo,于2016年开源并捐献给Apache基金会,并在2018年9月升级成为Apache顶级项目。 Kafka最初由Linkedin开发,并于2010年贡献给了Apache基金会,之后成为Apache顶级项目。 架构 Kafka Kafka架构由broker和zookeeper组成,如下图: 注意:Kafka2.8版本可以不依赖Zookeeper独立运行了 Pulsar Pulsar的架构如下: Pulsar Broker会在本地缓存消息,并且支持TTL, 从上面的2个架构我们看到,Kafka和Pulsar有3点不同: Pulsar采用分层架构,将计算和存储相分离,存储使用BookKeeper集群,计算使用Broker集群,Broker需要内置BookKeeper客户端。 Pulsar的部署和架构更加复杂,但是也更具有伸缩性。 Pulsar在最新版本中依然不能脱离Zookeeper独立运行。 消息存...
相关文章
文章评论
共有0条评论来说两句吧...