Navicat使用教程:MySQL 8组件架构和错误记录

翻译|使用教程|编辑:黄竹雯|2019-02-28 10:31:04.000|阅读 68 次

概述:本文主要介绍MySQL 8 的组件架构和错误记录。MySQL Server for Version 8的众多重大变化之一包括一个新的基于组件的基础架构。这将使架构更加模块化,同时允许用户通过添加单个组件来扩展服务器功能。

相关链接:

Navicat Premium是一个可连接多种数据库的管理工具,它可以让你以单一程序同时连接到MySQL、Oracle及PostgreSQL数据库,让管理不同类型的数据库更加的方便。

下载Navicat Premium最新版本

MySQL Server for Version 8的众多重大变化之一包括一个新的基于组件的基础架构。这将使架构更加模块化,同时允许用户通过添加单个组件来扩展服务器功能。

每个组件都提供服务器以及其他组件可用的服务。事实上,服务器本身现在被认为是一个组件,与其他组件一样。组件仅通过它们提供的服务相互交互。

启用组件

通过INSTALL COMPONENTUNINSTALL COMPONENT SQL语句实现组件加载和卸载。例如:

INSTALL COMPONENT 'file://component_validate_password';

UNINSTALL COMPONENT 'file://component_validate_password';

加载器服务处理组件加载和卸载,还列出mysql.component系统表中加载的组件。

INSTALL COMPONENT将组件加载到服务器中并立即激活它们。加载器服务还在mysql.component系统表中注册已加载的组件。对于后续服务器重启,mysql.component中列出的任何组件都在启动期间由加载器服务加载。

UNINSTALL COMPONENT取消激活组件并从服务器卸载它们。加载程序服务还会从mysql.component系统表中取消注册组件,以便在后续服务器启动期间不再加载它们。

错误日志筛选和发送

由于采用了新的组件架构,可以过滤日志事件,并可以将各种格式的输出发送到多个目标,包括JSON。日志事件甚至可以发送到第三方产品,如Navicat Monitor,以进行其他处理和分析。

错误日志配置存储在全局log_error_services和log_error_verbosity变量中,这些变量都存储在global_variables表中。错误日志变量以“log_error_”为前缀,因此我们可以按如下方式获取两者:

获取两个全局变量

有四个可用的日志组件。它们存储在lib / plugins目录中,扩展名为“.so”:

  • component_log_filter_dragnet.so
  • component_log_sink_json.so
  • component_log_sink_syseventlog.so
  • component_log_sink_test.so

组件可以细分为两种类型:过滤器和接收器。

  • 过滤器组件实现错误日志事件的过滤。如果未启用过滤器组件,则不会进行过滤。某些接收器组件描述是指默认的错误日志目标。否则,任何已启用的过滤器组件仅影响log_error_services变量中列出的组件的日志事件。
  • 错误日志接收器组件是实现错误日志输出的写入器。如果未启用接收器组件,则不会发生日志输出。某些接收器组件描述是指默认的错误日志目标。这是由log_error系统变量指示的控制台或文件。

要加载组件,你需要指定其URN。这包括:

“file://” +[没有.so扩展名的文件名]

例如,要将编写器加载到json组件,你可以这样操作来启用它:

将编写器加载到json组件

我们将在后续的文章中更详细地探索MySQL 8中的错误记录~

想要购买正版授权,或者获取更多Navicat相关信息的朋友可以点击" 咨询在线客服 "~


标签:数据库mysqloracle

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处,尊重他人劳动成果

登录 慧都网发表评论


暂无评论...

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
相关厂商
相关产品
Navicat Premium

Navicat Premium 是一套数据库管理工具,让你使用一个程序即可同時连接到 MySQL、MariaDB、SQL Server、SQLite、Oracle 和 PostgreSQL 数据库。

购物车 在线客服 在线QQ 电话咨询
400-700-1020
反馈
在线客服系统
live chat