You are viewing a plain text version of this content. The canonical link for it is here.
Posted to log4cxx-user@logging.apache.org by Madhu Gowda <ma...@yahoo.com> on 2008/06/02 14:13:08 UTC
using RollingFileAppender
Hi all,
I am trying to make use of RollingFileAppender.
My code is as follows:
LoggerPtr logger( Logger::getLogger("CustomLogger"));
RollingFileAppender *pAppender = new RollingFileAppender();
pAppender->setName( log4cxx::helpers::Transcoder::decode("TestAppender"));
pAppender->setFile( log4cxx::helpers::Transcoder::decode("TestLogFile.txt"));
pAppender->setAppend( true);
pAppender->setMaxBackupIndex( 5);
pAppender->setMaxFileSize( log4cxx::helpers::Transcoder::decode("5 KB"));
pAppender->setLayout( new PatternLayout( log4cxx::helpers::Transcoder::decode("%d [%t] %-5p %c - %l - %m%n")));
logger->addAppender( fAppender);
This code is giving the error as:
"No output stream or file set for the appender named TestAppender"
But, if I create the appender as:
RollingFileAppender *pAppender = new RollingFileAppender( new PatternLayout( log4cxx::helpers::Transcoder::decode("%d %-5p %c - %l - %m%n")),
log4cxx::helpers::Transcoder::decode("TestLogFile.txt"));
and I set the MaxBackupIndex and MaxFileSize as follows:
pAppender->setMaxBackupIndex( 5);
pAppender->setMaxFileSize( log4cxx::helpers::Transcoder::decode("5 KB"));
It works fine but, the new log file is not getting created after the MaxFileSize (5 KB) is reached, the log messages are just getting appended to same log file ().
Please, suggest what is going wrong here.
Thanks & Regards,
Madhu Gowda
Re: using RollingFileAppender
Posted by Curt Arnold <ca...@apache.org>.
On Jun 2, 2008, at 7:13 AM, Madhu Gowda wrote:
> Hi all,
>
>
> I am trying to make use of RollingFileAppender.
>
> My code is as follows:
>
>
> LoggerPtr logger( Logger::getLogger("CustomLogger"));
>
>
> RollingFileAppender *pAppender = new RollingFileAppender();
>
Instead use:
RollingFileAppenderPtr pAppender(new RollingFileAppender());
Otherwise, reference counts are likely to be mismanaged.
> pAppender-
> >setName( log4cxx::helpers::Transcoder::decode("TestAppender"));
>
> pAppender-
> >setFile( log4cxx::helpers::Transcoder::decode("TestLogFile.txt"));
>
> pAppender->setAppend( true);
>
> pAppender->setMaxBackupIndex( 5);
>
> pAppender->setMaxFileSize( log4cxx::helpers::Transcoder::decode("5
> KB"));
>
> pAppender->setLayout( new
> PatternLayout( log4cxx::helpers::Transcoder::decode("%d [%t] %-5p %c
> - %l - %m%n")));
>
>
If an appender (also applies to layouts, etc) is created with the
default constructor, the activateOptions() method must be called after
the properties are set.
Pool p;
pAppender->activateOptions(p);
>
> logger->addAppender( fAppender);
>
>
> This code is giving the error as:
>
> "No output stream or file set for the appender named TestAppender"
>
>
> But, if I create the appender as:
>
>
> RollingFileAppender *pAppender = new RollingFileAppender( new
> PatternLayout( log4cxx::helpers::Transcoder::decode("%d %-5p %c - %l
> - %m%n")),
>
> log4cxx::helpers::Transcoder::decode("TestLogFile.txt"));
>
>
> and I set the MaxBackupIndex and MaxFileSize as follows:
>
>
> pAppender->setMaxBackupIndex( 5);
>
> pAppender->setMaxFileSize( log4cxx::helpers::Transcoder::decode("5
> KB"));
>
>
> It works fine but, the new log file is not getting created after the
> MaxFileSize (5 KB) is reached, the log messages are just getting
> appended to same log file ().
>
When an constructor takes arguments, it has a call to
activateOptions() to make it ready for action upon construction.
However, any changes that occur after that point would need an call to
activateOptions() to ensure that the changes are reflected in the
behavior.
>
> Please, suggest what is going wrong here.
>
>
> Thanks & Regards,
>
> Madhu Gowda
>
>
>