Skip to content
Snippets Groups Projects
sample_log_config.yaml 2.67 KiB
Newer Older
  • Learn to ignore specific revisions
  • Richard van der Hoff's avatar
    Richard van der Hoff committed
    #
    # This is a YAML file containing a standard Python logging configuration
    # dictionary. See [1] for details on the valid settings.
    #
    
    # Synapse also supports structured logging for machine readable logs which can
    # be ingested by ELK stacks. See [2] for details.
    #
    
    # [1]: https://docs.python.org/3/library/logging.config.html#configuration-dictionary-schema
    
    # [2]: https://matrix-org.github.io/synapse/latest/structured_logging.html
    
    Richard van der Hoff's avatar
    Richard van der Hoff committed
    
    version: 1
    
    formatters:
        precise:
            format: '%(asctime)s - %(name)s - %(lineno)d - %(levelname)s - %(request)s - %(message)s'
    
    handlers:
        file:
    
            class: logging.handlers.TimedRotatingFileHandler
    
    Richard van der Hoff's avatar
    Richard van der Hoff committed
            formatter: precise
    
            filename: /var/log/matrix-synapse/homeserver.log
    
            when: midnight
            backupCount: 3  # Does not include the current log file.
    
    Richard van der Hoff's avatar
    Richard van der Hoff committed
            encoding: utf8
    
        # Default to buffering writes to log file for efficiency.
        # WARNING/ERROR logs will still be flushed immediately, but there will be a
        # delay (of up to `period` seconds, or until the buffer is full with
        # `capacity` messages) before INFO/DEBUG logs get written.
    
            class: synapse.logging.handlers.PeriodicallyFlushingMemoryHandler
    
    
            # The capacity is the maximum number of log lines that are buffered
            # before being written to disk. Increasing this will lead to better
    
            # performance, at the expensive of it taking longer for log lines to
            # be written to disk.
    
    
            # Logs with a level at or above the flush level will cause the buffer to
            # be flushed immediately.
            # Default value: 40 (ERROR)
            # Other values: 50 (CRITICAL), 30 (WARNING), 20 (INFO), 10 (DEBUG)
            flushLevel: 30  # Flush immediately for WARNING logs and higher
    
            # The period of time, in seconds, between forced flushes.
            # Messages will not be delayed for longer than this time.
            # Default value: 5 seconds
            period: 5
    
    
        # A handler that writes logs to stderr. Unused by default, but can be used
        # instead of "buffer" and "file" in the logger handlers.
    
    Richard van der Hoff's avatar
    Richard van der Hoff committed
        console:
            class: logging.StreamHandler
            formatter: precise
    
    loggers:
        synapse.storage.SQL:
            # beware: increasing this to DEBUG will make synapse log sensitive
            # information such as access tokens.
            level: INFO
    
    root:
        level: INFO
    
    
        # Write logs to the `buffer` handler, which will buffer them together in memory,
        # then write them to a file.
        #
    
        # Replace "buffer" with "console" to log to stderr instead.
    
    Richard van der Hoff's avatar
    Richard van der Hoff committed
    
    disable_existing_loggers: false