Importance of logs in custom development
Introduction We all know that Drupal logs most of the things. During CUSTOM DEVELOPMENT it is important to do a little brainstorming on logging and to analyze the questions like - Where, Why, Why not, When and What to log.
How it helps? Logging helps to maintain the bug free modules and themes longer. Easy to debug, trace and resolve the issues.
Is it necessary to log? It is not necessary, it depends on the module or theme that we are building but it should not be ignored.
Background This presentation will try to give all question`s answer. Why we should log? Where we should log? Where we should not log? When to log or not? What to log or not?
Let us get started ….
Why we should log? Logging makes code more effective. It helps to understand the processing of the output and program flow. It saves developers lots of time. Non technical people can also understand the program flow. Helps to monitor the system like CPU usage, execution time of a functionality, etc. Log helps to generate reports and analytics which can very useful to take business decisions.
Where we should log? Wherever we want ! Few examples of files are below. .php .module .inc .tpl .test .js
Where we should log ... With respect to path, try to put log file in easily accessible path like - Desktop, Documents, etc. It is irritating to keep log files in deeper paths. Logging format and settings are different for individual platform. Like - Acquia Dev Desktop
Where we should not log? In the large loops In the hooks or functions which are called multiple times like hook_init in D7. Avoid heavy logging during bootstrapping mode of Drupal, It can slow down Drupal.
Where we should not log? ... Logging is not possible in all the plain files like .info, .css, .txt, etc.
When to log or not? During big calculations During page loads During ajax calls During site visit During login and logout Avoid logs if data is too heavy.
What to log or not? There is no restriction in logging of any type data, every type of data collection can be logged in Drupal. Criticality of data decides that it should be logged or not. Use PHP`s error_log to log every possible data collection.
Logging functions Watchdog ( < D8 ) \Drupal::logger in ( D8 ) PHP`s error_log
Important contrib modules Export logs https://www.drupal.org/project/export_logs
Important Note Keep only critical loggings in production environment. It should be as small as possible. and rest of the loggings should be limited to development environment. Log statements may be removed or commented before deployment to production. It also depends on the application whether it wants to maintain a detailed log or not.
Important Note ... Try to keep log messages small. Large log messages are difficult to understand and to go through. It is better to maintain the logs file to know the behavior of the application for a period of time. Failure, info, warning, status logs are equally important like success. Over a period of time logs should be cleared. A log file should not be too big to open in editor.
Questions?