Some Good Practices of Logging

Logging is structured or unstructured text information generated by the system during operation. Usually, it can be regarded as a record of an event by the application. Logging can often help us discover unexpected behaviors in systems, especially in some microservice architecture systems. As an important part of Observability, Logging plays an irreplaceable role in our system development and maintenance.

Pillars of Observability

To understand why logging plays an important role in products or systems, we must understand its value. Currently, the most widely used logging forms are alerting, troubleshooting, and business data visualization.

Logging can be used as an important data source for our business system monitoring; mature product systems have alarm systems. If there is a problem exceeding a certain defined indicator in the system, the log system will automatically send the alarm information to the notification platform. The On-call people can locate and solve the problem according to the alarm information.

Imagine that the system you are responsible for developing and maintaining is found to be faulty. What is the first thing you should do? Check the system information to verify that it’s true. The log printed on the server is the best auxiliary information. As programmers, logs are the most familiar tool for solving problems.

Many companies can use the logs of the production environment stored in their own databases to visualize business data in combination with the corresponding tools such as Grafana and SumoLogic.

It’s necessary to sort out our log format and write logs according to certain specifications. Logging Format

  • Basic template

    • At minimum, qualified logs should have the following information: time, log level, and log information.
  • Advanced Template Add thread name, hostname, method name, class name, and the number of lines corresponding to the method;

    • Thread Name: Most applications don’t have a single user. For a single-instance service, many users accessing the same interface will execute the application in different threads. So using the thread name is best to differentiate the business process of corresponding users.
    • Hostname: Most current applications are deployed in the cloud with multiple instances, so on the basis of a single node, the logging needs to be distinguished at the instance level on multiple instances, and the hostname is the best way to differentiate.
    • Method Name: A convenient way to differentiate the source within the same log.
    • Class Name: A convenient way to quickly locate the business process.
    • Number of lines: A quick way to find the specific location of the log.

To improve the readability of the log, we can focus on formatting.

  • Put square brackets around the log level, host name, and thread name;
  • Add parentheses to the class name and line number where the method name is located, and separate the class name and line number with a colon;
  • Add a horizontal line between the line number and log information; Specific formatting is also possible for log information:
  • For regular requests, response or other business logs, you can separate custom information and parameters with an underscore; multiple parameters are separated by commas;
  • For error message formatting, you can use Key:Value.

If the recorded log is just a simple text description line by line, it’ll be hard to read. In a complex system or a system with frequent business operations, there will be multiple logs and we’ll have to spend time filtering out the relevant logs. The best way to solve this problem is through chain tracking of logs: putting one or more unique IDs in the business system that are added to each log, so that when locating business problems, we can quickly filter out the relevant logs through these unique IDs and Other criteria (e.g. time).

Log Level

The output of the log is divided into levels.Different scenarios need to print different levels of logs.

  • Debug: Record technical details and logs to help understand the system operation;
  • Info: Record business information;
  • Warn: Acceptable error messages that are manageable and not urgent;
  • Error: Unexpected errors or system behavior, usually caused by system bugs or environmental problems.

At the same time, not all logs need to be recorded, we need to record as needed. The following table shows which logs should be recorded depending on the environment.

EnvironmentLog Leave
DevDebug
TestDebug
UATInfo
ProdInfo

The location of the log print also needs to be made clear.

  • When other systems call their own systems, they need to print the log once each when they receive a request and when the request is completed;
  • The log is printed once before the self-hosted system calls the interface of the third-party system and after receiving the response;
  • The log needs to be printed in any abnormal place in the system.

Different programming languages have different logging tools; the most famous is Apache’s Log4j, which is highly configurable and can be configured via external files at runtime. It is based on logging priority and provides mechanisms to instruct logging information to many destinations such as database, file, console, UNIX system log, etc.; log4j has been ported to other programming languages, such as logging in Python, log4js in NodeJS, log4rs in Rust.

Avoid printing or recording any sensitive information, including but not limited to various PII, PCI information. Remember to obey local laws and regulations, such as China’s PILI (Personal Information Protection Law) or Europe’s GDPR (General Data Protection Regulation). Choose the appropriate log level and log position as needed. ……

A good log can not only facilitate program development and provide the most important auxiliary information for troubleshooting, it also gives optimization suggestions or data statistics for business or infrastructure.

本文仅代表个人观点,与 Thoughtworks 公司无任何关系。


谷哥说-微信公众号

SHA256 checksum: f2fe1394e4ab9297ed69ff73ac32e9ac1375f01c2102183b509bf9379a5995d6

PayForGuzhongren

SHA256 checksum: 964978ecd2059064abe542e51dc02e204d3ee2e6c320ca68e2b1399ce0c6953c

使用此文件进行校验: gpg --verify PayForGuzhongren.svg.sig