转载:http://arksea.iteye.com/blog/520996
一、用实例感受一下reltool的功能
先来看看典型的目录结构
- /home/arksea
- |--client
- |--ebin
- |--include
- |--nbproject
- |--priv
- |--src
- |--test
用reltool生成目标系统的过程为
1、写配置文件client.config
2、启动erl,如果提示需要以smp方式启动要加上参数erl -smp
3、生成目标系统
- Eshell V5.7.3 (abort with ^G)
- 1> {ok,Server}=reltool:start_server([{config,"client.config"}]).
- {ok,<0.32.0>}
- 2> reltool:create_target(Server, "target").
- ok
- 3>
就这么简单,我们看看生成的目标系统的目录结构
- target
- |--bin
- |--erts-5.7.3
- |--release
- | |--0.1
- | | |--client.boot
- | | |--client.rel
- | | |--client.script
- | |--start_erl.data
- |--lib
- |--client-0.1
- | |--priv
- |--client-0.1.ez
- |--erts-5.7.3.ez
- |--kernel-2.13.3.ez
- ....
-
对,没错,所有的lib下的beam文件都被打包到一个.ez压缩包中了,这对于嵌入到客户端的系统来说是个好特性,啥时候再支持一下包认证就更棒了。
二、部署描述文件实例
看完了reltool的效果,现在来看看重点,也就是部署描述文件client.config的结构
下面是这个例子的部署描述文件,因为是嵌入到客户端程序中所以要尽量小,剔除了比较多的东西,服务端系统通常无需使用如此复杂的包含规则。最终的target目录里只剩12M的东东,还算可以接受,当然如果你愿意应该还是有不少东西是可以剔除的。
- {sys,[{lib_dirs,["/home/arksea"]},
- {boot_rel,"client"},
- {rel,"client","0.1",[kernel,stdlib,sasl,client]},
- {debug_info, keep},
- {incl_sys_filters,["^bin/","^erts-.*?/","^release"]},
- {excl_sys_filters,["/doc","/usr","/man","/src","/include","/lib",
- "/dialyzer.exe$","/escript.exe$","/werl.exe$",
- "/beam.debug.dll$","/beam.debug.smp.dll$",
- "\.pdb$"]},
- {incl_app_filters,["^ebin/"]},
- {excl_archive_filters,[]},
- {app,kernel,[{incl_cond,include}]},
- {app,stdlib,[{incl_cond,include}]},
- {app,sasl,[{incl_cond,include}]},
- {app,client,[{incl_cond,include},
- {incl_app_filters,["^ebin/","^priv/"]},
- {excl_archive_filters,["^priv$"]}]}
- ]
- }.
erlang的文档中有关于reltool部署描述的详细解释,说得很清楚了。需要说明的是别看reltool文档中列出了一坨的参数,不要害怕,基本上只要使用默认值就行了,比如以上的部署描述文件只要这样写就能正常工作了:
- {sys,[{lib_dirs,["/home/arksea"]},
- {boot_rel,"client"},
- {rel,"client","0.1",[kernel,stdlib,sasl,client]},
- {debug_info, keep},
- {app,kernel,[{incl_cond,include}]},
- {app,stdlib,[{incl_cond,include}]},
- {app,sasl,[{incl_cond,include}]},
- {app,client,[{incl_cond,include}]}
- ]
- }.
是不是简单了许多?只是打出来的包要大不少。
三、部署描述文件的编写
下面对一些常用的参数进行解释
1、首先是 lib_dirs,文档中说是系统依赖库的位置,实际上你也应该把项目路径的
父目录填在这里,这点
很重要,否则就搜索不到你的系统咯。比如这里,项目client所在的父目录是/home/arksea,
可以填写相对路径比如../server
2、文件包含规则有一系列的参数,这些参数都支持正则表达式
- incl_sys_filters
- excl_sys_filters
- incl_app_filters
- excl_app_filters
- incl_archive_filters
- excl_archive_filters
这里说说所谓“sys”、“app”、“archive”的概念
- sys是指erlang安装目录下的文件(除了lib目录),如果你配置了root_dir则为你指定的目录;
- app是指lib_dirs参数指定目录下的文件,以及root_dir/lib下的文件
- archive则指出了app中哪些文件将被打包到.ez中
强调一点,这里的文件名都是相对路径哟,写正则表达式的时候要注意
- sys的起始位置是root_dir
- app的起始位置是root_dir/lib/appname和lib_dirs/appname
举个例子
root_dir/lib/mnesia-4.4.11/doc将被表示为
doc
root_dir/lib/mnesia-4.4.11/examples/bench将被表示为
examples/bench
所以要剔除这些文件应该这样写正则表达式:
- {excl_app_filters, ["^doc","^examples/bench"]}
3、rel参数用于生成rel、script、boot文件,请参考systool文档。rel参数非常的简单,只要为系统起一个名字与版本号,然后列出本系统所直接依赖的app,连版本号都不要写,reltool会自动根据root_dir与lib_dirs中的erlang与各app版本生成rel文件
4、每个app可以有自己的filter参数,如果你写了它将覆盖sys层的filter参数。
需要注意的一点是,app的名字必须与其文件夹的名字相同,比如这里的app名是client,则其文件夹应为lib_dirs/client