NAME

Log::ger::Manual::Tutorial::01 - What is logging? Why logging? Logging vs ...

VERSION

version 0.021.002

WHAT IS LOGGING?

Logging is recording information during run-time. You can log any kind of information, from dumping internal data structures and tracing the flow of program execution (for debugging purposes), showing the progress of activities (for verbose output a.k.a. progress report to the user), and so on (auditing, accounting, security monitoring, source code documentation, etc).

With Log::ger, this is as simple as use-ing Log::ger and adding logging statements, for example:

use Log::ger;

sub process_user {
    log_trace("Entering process_user(%s)", \@_);

    ...

    log_trace("Leaving process_user(), result=%s", $res);
    return $res;
}

log_trace("Starting program");
for my $user (@ARGV) {
    log_info("Processing user %s", $user);
    process_user($user);
}
log_trace("Ending program");

WHY LOGGING? LOGGING VS ...

Compared to using a debugger (with standard features like single-stepping, breakpoints, watchpoints, etc), logging can help diagnose problems while you run an application normally in production environment, as opposed to having to stop a program and run it under the debugger. Of course, a proper debugger has its strengths too.

Compared to peppering "print" statements all over your prgoram, logging using a framework brings the flexibility of turning on/off the statements according to the notion of level/severity (or other criteria), and redirecting where the log messages should go. On the other hand, "print" statement is simpler and does not require extra module/framework.

AUTHOR

perlancar <perlancar@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2017 by perlancar@cpan.org.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.