滞后日志行被截断



我正在修改一些ejabberd代码,遇到了一个通过lager:打印的错误

2014-04-25 18:29:39.380 [error] emulator Error in process <0.652.0> on node 'ejabberd@localhost' with exit value: {function_clause,[{lists,zip,[[transport,connection,pid,method,version,peer,host,host_info,port,path,path_info,qs,qs_vals,bindings,headers,p_headers,cookies,meta,body_state,multipart,buffer,resp_compress...

不幸的是,这行被截断了,我看不到堆栈跟踪的其余部分。如何查看整个错误消息?

我认为拉格的trunk大小可以调整如下:在lager.erl源文件中

%% @doc Manually log a message into lager without using the parse transform.
-spec log(log_level(), pid() | atom() | [tuple(),...], list()) -> ok | {error, lager_not_running}.
log(Level, Pid, Message) when is_pid(Pid); is_atom(Pid) ->
    dispatch_log(Level, [{pid,Pid}], Message, [], ?DEFAULT_TRUNCATION);
log(Level, Metadata, Message) when is_list(Metadata) ->
    dispatch_log(Level, Metadata, Message, [], ?DEFAULT_TRUNCATION).
%% @doc Manually log a message into lager without using the parse transform.
-spec log(log_level(), pid() | atom() | [tuple(),...], string(), list()) -> ok | {error, lager_not_running}.
log(Level, Pid, Format, Args) when is_pid(Pid); is_atom(Pid) ->
    dispatch_log(Level, [{pid,Pid}], Format, Args, ?DEFAULT_TRUNCATION);
log(Level, Metadata, Format, Args) when is_list(Metadata) ->
    dispatch_log(Level, Metadata, Format, Args, ?DEFAULT_TRUNCATION).

?DEFAULT_TRUNCATION在lager.hrl文件中定义。

-define(DEFAULT_TRUNCATION, 4096).
-define(DEFAULT_TRACER, lager_default_tracer).

我认为你可以增加上面的默认值,然后再次编译拉格以供使用。

但是你的日志没有4096那么长,而且日志不是来自拉格,而是来自拉格的重定向(error_logger)。以下问题可能与您的问题有关:erlang 中的截断错误报告

有两种可能性。第一个是在rebar/elang.mk中的erlc选项中添加以下编译选项:

+'{lager_truncation_size, 20480}'

这将把erlc编译的所有模块的总日志的最大允许大小设置为20kb,如果你不处理制作文件,可能所有模块都在项目中。截断限制的一个原因是为了不让更大的进程过载,因此在整个项目中这样做可能是危险的。

请注意,使用-compile属性在每个模块的基础上添加它是不起作用的,请参阅此问题。

另一种方法是自己调用lager:dispatch_log,并绕过转换:

lager:dispatch_log(info, [{pid, self()}], "hello ~s|", [lists:duplicate(1000, "hello")], 20480).

这两种方法都要求您对代码或构建过程进行修改。

最新更新