|  | MySQL 9.4.0
    Source Code Documentation | 
Logging interface for using and extending the logging subsystem. More...
#include "harness_export.h"#include "mysql/harness/compiler_attributes.h"#include "mysql/harness/filesystem.h"#include "mysql/harness/stdx/process.h"#include <chrono>#include <cstdarg>#include <fstream>#include <list>#include <mutex>#include <string>Go to the source code of this file.
| Classes | |
| struct | mysql_harness::logging::Record | 
| Log record containing information collected by the logging system.  More... | |
| Namespaces | |
| namespace | mysql_harness | 
| namespace | mysql_harness::logging | 
| namespace | mysql_harness::logging::options | 
| option name used in config file (and later in configuration object) to specify log level. | |
| Macros | |
| #define | IMPORT_LOG_FUNCTIONS() | 
| convenience macro to avoid common boilerplate  More... | |
| Enumerations | |
| enum class | mysql_harness::logging::LogLevel { mysql_harness::logging::kFatal , mysql_harness::logging::kSystem , mysql_harness::logging::kError , mysql_harness::logging::kWarning , mysql_harness::logging::kInfo , mysql_harness::logging::kNote , mysql_harness::logging::kDebug , mysql_harness::logging::kNotSet } | 
| Log level values.  More... | |
| enum class | mysql_harness::logging::LogTimestampPrecision { mysql_harness::logging::kSec = 0 , mysql_harness::logging::kMilliSec = 3 , mysql_harness::logging::kMicroSec = 6 , mysql_harness::logging::kNanoSec = 9 , mysql_harness::logging::kNotSet } | 
| Log timestamp precision values.  More... | |
| Functions | |
| HARNESS_EXPORT bool | mysql_harness::logging::log_level_is_handled (LogLevel level, const char *domain) | 
| static bool | mysql_harness::logging::log_level_is_handled (LogLevel level) | 
| Variables | |
| const size_t | mysql_harness::logging::kLogMessageMaxSize = 4096 | 
| Max message length that can be logged; if message is longer, it will be truncated to this length.  More... | |
| constexpr char | mysql_harness::logging::options::kFilename [] = "filename" | 
| constexpr char | mysql_harness::logging::options::kDestination [] = "destination" | 
| constexpr char | mysql_harness::logging::options::kLevel [] = "level" | 
| constexpr char | mysql_harness::logging::options::kTimestampPrecision [] = "timestamp_precision" | 
| constexpr char | mysql_harness::logging::options::kSinks [] = "sinks" | 
| constexpr char | mysql_harness::logging::kConfigSectionLogger [] = "logger" | 
| constexpr char | mysql_harness::logging::kNone [] = "" | 
| constexpr char | mysql_harness::logging::kMainLogger [] = "main" | 
| Special names reserved for "main" program logger.  More... | |
| constexpr char | mysql_harness::logging::kMainLogHandler [] = "main_log_handler" | 
| constexpr char | mysql_harness::logging::kMainConsoleHandler [] = "main_console_handler" | 
| constexpr char | mysql_harness::logging::kSqlLogger [] = "sql" | 
| constexpr char | mysql_harness::logging::kDefaultLogFilename [] = "mysqlrouter.log" | 
| Default log filename.  More... | |
| const LogLevel | mysql_harness::logging::kDefaultLogLevel = LogLevel::kWarning | 
| Default log level used by the router.  More... | |
| const LogLevel | mysql_harness::logging::kDefaultLogLevelBootstrap = LogLevel::kInfo | 
| Default log level written by the router to the config file on bootstrap.  More... | |
| const char *const | mysql_harness::logging::kDefaultLogLevelName = "warning" | 
| Log level name for the default log level used by the router.  More... | |
| const char *const | mysql_harness::logging::kRawLogLevelName = "info" | 
| Log level name used in raw logging mode.  More... | |
| #define | MYSQL_ROUTER_LOG_DOMAIN "" | 
| Log message for the domain.  More... | |
| #define | log_debug2(...) log_debug(__VA_ARGS__) | 
| static void | mysql_harness::logging::log_system (const char *fmt,...) ATTRIBUTE_GCC_FORMAT(printf | 
| static void static void | mysql_harness::logging::log_error (const char *fmt,...) ATTRIBUTE_GCC_FORMAT(printf | 
| static void static void static void | mysql_harness::logging::log_warning (const char *fmt,...) ATTRIBUTE_GCC_FORMAT(printf | 
| static void static void static void static void | mysql_harness::logging::log_info (const char *fmt,...) ATTRIBUTE_GCC_FORMAT(printf | 
| static void static void static void static void static void | mysql_harness::logging::log_note (const char *fmt,...) ATTRIBUTE_GCC_FORMAT(printf | 
| static void static void static void static void static void static void | mysql_harness::logging::log_debug (const char *fmt,...) ATTRIBUTE_GCC_FORMAT(printf | 
| static void static void static void static void static void static void static void | mysql_harness::logging::log_custom (const LogLevel log_level, const char *fmt,...) ATTRIBUTE_GCC_FORMAT(printf | 
Logging interface for using and extending the logging subsystem.
| #define IMPORT_LOG_FUNCTIONS | ( | ) | 
convenience macro to avoid common boilerplate
| #define log_debug2 | ( | ... | ) | log_debug(__VA_ARGS__) | 
| #define MYSQL_ROUTER_LOG_DOMAIN "" | 
Log message for the domain.
This will log an error, warning, informational, or debug message for the given domain. The domain have to be be registered before anything is being logged. The Loader uses the plugin name as the domain name, so normally you should provide the plugin name as the first argument to this function.
| name | Domain name to use when logging message. | 
| fmt | printf-style format string, with arguments following. Pre-processor symbol containing the name of the log domain. If not defined explicitly when compiling, it will be an empty string, which means that it logs to the top log domain. |