6

I'm working on modifying some ejabberd code, and I'm coming across an error printed via 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...

Unfortunately the line is truncated and I can't see the rest of the stack trace. How do I view the whole error message?

4

2 回答 2

4

有两种可能性。首先是在 rebar/erlang.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).

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

于 2015-04-23T15:32:59.970 回答
4

我认为啤酒的 trunc 大小可以调整如下:在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_TRUNCATIONlager.hrl 文件中定义。

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

我认为您可以增加上述默认值,然后再次编译啤酒以供使用。

但是你的日志没有 4096 长,而且日志不是来自 lager,而是来自 lager 的重定向(error_logger)。以下问题可能与您的问题有关: Truncated error report in erlang

于 2014-04-26T05:29:38.997 回答