Logging

Introduction

The JavaScript SDK comes with a out-of-box Console based logger. The SDK emits various internal logs to help users understand the chain of events and troubleshoot problems. A consumer of this SDK can customize the verbosity of the log, as well as provide their own implementation for the logger.

Configure log level

There are five levels of logging in descending order of importance - error, warn, info, verbose, and debug. Setting the log to a level means that the logger will emit all the logs that are at least as important as the mentioned level. For example, setting to verbose log means that the SDK will not emit debug level logs. The default log level is info.

Dapr Client

  1. import { CommunicationProtocolEnum, DaprClient, LogLevel } from "@dapr/dapr";
  2. // create a client instance with log level set to verbose.
  3. const client = new DaprClient({
  4. daprHost,
  5. daprPort,
  6. communicationProtocol: CommunicationProtocolEnum.HTTP,
  7. logger: { level: LogLevel.Verbose },
  8. });

For more details on how to use the Client, see JavaScript Client.

DaprServer

  1. import { CommunicationProtocolEnum, DaprServer, LogLevel } from "@dapr/dapr";
  2. // create a server instance with log level set to error.
  3. const server = new DaprServer({
  4. serverHost,
  5. serverPort,
  6. clientOptions: {
  7. daprHost,
  8. daprPort,
  9. logger: { level: LogLevel.Error },
  10. },
  11. });

For more details on how to use the Server, see JavaScript Server.

Custom LoggerService

The JavaScript SDK uses the in-built Console for logging. To use a custom logger like Winston or Pino, you can implement the LoggerService interface.

Winston based logging:

Create a new implementation of LoggerService.

  1. import { LoggerService } from "@dapr/dapr";
  2. import * as winston from "winston";
  3. export class WinstonLoggerService implements LoggerService {
  4. private logger;
  5. constructor() {
  6. this.logger = winston.createLogger({
  7. transports: [new winston.transports.Console(), new winston.transports.File({ filename: "combined.log" })],
  8. });
  9. }
  10. error(message: any, ...optionalParams: any[]): void {
  11. this.logger.error(message, ...optionalParams);
  12. }
  13. warn(message: any, ...optionalParams: any[]): void {
  14. this.logger.warn(message, ...optionalParams);
  15. }
  16. info(message: any, ...optionalParams: any[]): void {
  17. this.logger.info(message, ...optionalParams);
  18. }
  19. verbose(message: any, ...optionalParams: any[]): void {
  20. this.logger.verbose(message, ...optionalParams);
  21. }
  22. debug(message: any, ...optionalParams: any[]): void {
  23. this.logger.debug(message, ...optionalParams);
  24. }
  25. }

Pass the new implementation to the SDK.

  1. import { CommunicationProtocolEnum, DaprClient, LogLevel } from "@dapr/dapr";
  2. import { WinstonLoggerService } from "./WinstonLoggerService";
  3. const winstonLoggerService = new WinstonLoggerService();
  4. // create a client instance with log level set to verbose and logger service as winston.
  5. const client = new DaprClient({
  6. daprHost,
  7. daprPort,
  8. communicationProtocol: CommunicationProtocolEnum.HTTP,
  9. logger: { level: LogLevel.Verbose, service: winstonLoggerService },
  10. });