From 0ac7f70c85f3be8fc65d814473b9a5a5a0aed0f7 Mon Sep 17 00:00:00 2001 From: Robert Newson Date: Wed, 10 Aug 2011 21:06:50 +0000 Subject: COUCHDB-1245 - enforce maximum chunk size for _log call to better manage memory. git-svn-id: https://svn.apache.org/repos/asf/couchdb/branches/1.1.x@1156369 13f79535-47bb-0310-9956-ffa450edef68 --- src/couchdb/couch_log.erl | 9 +++++++++ 1 file changed, 9 insertions(+) (limited to 'src/couchdb') diff --git a/src/couchdb/couch_log.erl b/src/couchdb/couch_log.erl index bb75f161..ab649cac 100644 --- a/src/couchdb/couch_log.erl +++ b/src/couchdb/couch_log.erl @@ -172,6 +172,15 @@ get_log_messages(Pid, Level, Format, Args) -> read(Bytes, Offset) -> LogFileName = couch_config:get("log", "file"), LogFileSize = filelib:file_size(LogFileName), + MaxChunkSize = list_to_integer( + couch_config:get("httpd", "log_max_chunk_size", "1000000")), + case Bytes > MaxChunkSize of + true -> + throw({bad_request, "'bytes' cannot exceed " ++ + integer_to_list(MaxChunkSize)}); + false -> + ok + end, {ok, Fd} = file:open(LogFileName, [read]), Start = lists:max([LogFileSize - Bytes, 0]) + Offset, -- cgit v1.2.3