reltool使用入门

转载:http://arksea.iteye.com/blog/520996


一、用实例感受一下reltool的功能
先来看看典型的目录结构

代码   收藏代码
  1. /home/arksea  
  2.        |--client  
  3.             |--ebin  
  4.             |--include  
  5.             |--nbproject  
  6.             |--priv  
  7.             |--src  
  8.             |--test  


用reltool生成目标系统的过程为
1、写配置文件client.config
2、启动erl,如果提示需要以smp方式启动要加上参数erl -smp
3、生成目标系统
代码   收藏代码
  1. Eshell V5.7.3  (abort with ^G)  
  2. 1> {ok,Server}=reltool:start_server([{config,"client.config"}]).  
  3. {ok,<0.32.0>}  
  4. 2> reltool:create_target(Server, "target").  
  5. ok  
  6. 3>  


就这么简单,我们看看生成的目标系统的目录结构
代码   收藏代码
  1. target  
  2.   |--bin  
  3.   |--erts-5.7.3  
  4.   |--release  
  5.   |     |--0.1  
  6.   |     |   |--client.boot  
  7.   |     |   |--client.rel  
  8.   |     |   |--client.script  
  9.   |     |--start_erl.data  
  10.   |--lib  
  11.       |--client-0.1  
  12.       |     |--priv  
  13.       |--client-0.1.ez  
  14.       |--erts-5.7.3.ez  
  15.       |--kernel-2.13.3.ez  
  16.      ....  
  17.    

      
对,没错,所有的lib下的beam文件都被打包到一个.ez压缩包中了,这对于嵌入到客户端的系统来说是个好特性,啥时候再支持一下包认证就更棒了。

二、部署描述文件实例
看完了reltool的效果,现在来看看重点,也就是部署描述文件client.config的结构

下面是这个例子的部署描述文件,因为是嵌入到客户端程序中所以要尽量小,剔除了比较多的东西,服务端系统通常无需使用如此复杂的包含规则。最终的target目录里只剩12M的东东,还算可以接受,当然如果你愿意应该还是有不少东西是可以剔除的。
代码   收藏代码
  1. {sys,[{lib_dirs,["/home/arksea"]},  
  2.       {boot_rel,"client"},  
  3.       {rel,"client","0.1",[kernel,stdlib,sasl,client]},  
  4.       {debug_info, keep},  
  5.       {incl_sys_filters,["^bin/","^erts-.*?/","^release"]},  
  6.       {excl_sys_filters,["/doc","/usr","/man","/src","/include","/lib",  
  7.                          "/dialyzer.exe$","/escript.exe$","/werl.exe$",  
  8.                          "/beam.debug.dll$","/beam.debug.smp.dll$",  
  9.                          "\.pdb$"]},  
  10.       {incl_app_filters,["^ebin/"]},  
  11.       {excl_archive_filters,[]},  
  12.       {app,kernel,[{incl_cond,include}]},  
  13.       {app,stdlib,[{incl_cond,include}]},  
  14.       {app,sasl,[{incl_cond,include}]},  
  15.       {app,client,[{incl_cond,include},  
  16.                    {incl_app_filters,["^ebin/","^priv/"]},  
  17.                    {excl_archive_filters,["^priv$"]}]}  
  18.      ]  
  19. }.  

erlang的文档中有关于reltool部署描述的详细解释,说得很清楚了。需要说明的是别看reltool文档中列出了一坨的参数,不要害怕,基本上只要使用默认值就行了,比如以上的部署描述文件只要这样写就能正常工作了:
代码   收藏代码
  1. {sys,[{lib_dirs,["/home/arksea"]},  
  2.       {boot_rel,"client"},  
  3.       {rel,"client","0.1",[kernel,stdlib,sasl,client]},  
  4.       {debug_info, keep},  
  5.       {app,kernel,[{incl_cond,include}]},  
  6.       {app,stdlib,[{incl_cond,include}]},  
  7.       {app,sasl,[{incl_cond,include}]},  
  8.       {app,client,[{incl_cond,include}]}  
  9.      ]  
  10. }.  

是不是简单了许多?只是打出来的包要大不少。

三、部署描述文件的编写

下面对一些常用的参数进行解释
1、首先是 lib_dirs,文档中说是系统依赖库的位置,实际上你也应该把项目路径的 父目录填在这里,这点 很重要,否则就搜索不到你的系统咯。比如这里,项目client所在的父目录是/home/arksea, 可以填写相对路径比如../server
2、文件包含规则有一系列的参数,这些参数都支持正则表达式
代码   收藏代码
  1. incl_sys_filters  
  2. excl_sys_filters  
  3. incl_app_filters  
  4. excl_app_filters  
  5. incl_archive_filters  
  6. 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
所以要剔除这些文件应该这样写正则表达式:
代码   收藏代码
  1. {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

你可能感兴趣的:(server,正则表达式,erlang,文档,include,archive)