reltool使用入门

一、用实例感受一下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












.

你可能感兴趣的:(工作,正则表达式,erlang,嵌入式)