24、MySQL 8.0 5.1.6.1结构化系统变量

结构化变量在两个方面与常规系统变量不同:

它的值是一个包含组件的结构,这些组件指定被认为密切相关的服务器参数。

可能有几个给定类型的结构化变量的实例。每个人都有不同的名称,并且指的是由服务器维护的不同资源。

MySQL支持一种结构化变量类型,它指定了控制键缓存操作的参数。密钥缓存结构化变量具有以下组件:

key_buffer_size

key_cache_block_size

key_cache_division_limit

key_cache_age_threshold
本节介绍用于引用结构变量的语法。密钥缓存变量用于语法示例,但关于密钥缓存如何操作的具体细节可在第8.10.2节“MyISAM密钥缓存”中的其他位置找到。

要引用结构化变量实例的组件,可以使用instance_name.component_name格式化合物名称 。例子:

hot_cache.key_buffer_size
hot_cache.key_cache_block_size
cold_cache.key_cache_block_size
对于每个结构化系统变量,名称为的实例default始终是预定义的。如果您引用没有任何实例名称的结构化变量的组件,default则使用该实例。因此, default.key_buffer_size与 key_buffer_size这两个指代相同的系统变量。
结构化变量实例和组件遵循以下命名规则:

对于给定类型的结构化变量,每个实例必须具有在 该类型的变量中唯一的名称。但是,实例名称在结构变量类型中不必是唯一的。例如,每个结构化变量都有一个名为的实例default,所以 default在变量类型中不是唯一的。

每个结构化变量类型的组件名称在所有系统变量名称中必须是唯一的。如果这不是真的(即,如果两种不同类型的结构变量可以共享组件成员名称),那么将不清楚哪个默认结构变量用于引用不受实例名称限定的成员名称。

如果结构化变量实例名称作为不加引号的标识符不合法,请使用反引号将其引用为带引号的标识符。例如,hot-cache 不合法,但是`hot-cache`。

global,session并且 local不是合法的实例名称。这避免了与记号的冲突,例如 引用非结构化系统变量。 @@global.var_name

目前,前两条规则不可能被违反,因为唯一的结构化变量类型是用于键缓存的。如果将来会创建其他类型的结构化变量,这些规则将具有更大的意义。


除了一个例外,您可以在任何可能出现简单变量名称的上下文中使用复合名称来引用结构化变量组件。例如,您可以使用命令行选项将值分配给结构化变量:

shell> mysqld --hot_cache.key_buffer_size=64K
在选项文件中,使用以下语法:
[mysqld]
hot_cache.key_buffer_size=64K
如果使用此选项启动服务器,hot_cache除默认大小为8MB的默认密钥缓存外,它还会创建一个大小为64KB的密钥缓存。

假设您按如下方式启动服务器:
shell> mysqld --key_buffer_size=256K \
         --extra_cache.key_buffer_size=128K \
         --extra_cache.key_cache_block_size=2048
在这种情况下,服务器将默认密钥缓存的大小设置为256KB。(您也可以写入 --default.key_buffer_size=256K)。另外,服务器创建一个名为extra_cache大小为128KB 的第二个键缓存 ,缓存表索引块的块缓冲区大小设置为2048字节。

以下示例使用三个不同大小的3:1比例的密钥缓存启动服务器:

shell> mysqld --key_buffer_size=6M \
         --hot_cache.key_buffer_size=2M \
         --cold_cache.key_buffer_size=2M
结构化变量值也可以在运行时设置和检索。例如,要设置一个名为hot_cache大小为10MB 的密钥缓存 ,请使用以下任一语句:

mysql> SET GLOBAL hot_cache.key_buffer_size = 10*1024*1024;
mysql> SET @@global.hot_cache.key_buffer_size = 10*1024*1024;
要检索缓存大小,请执行以下操作:
mysql> SELECT @@global.hot_cache.key_buffer_size;
但是,以下声明不起作用。该变量不被解释为复合名称,而是作为LIKE模式匹配操作的简单字符串 :
mysql> SHOW GLOBAL VARIABLES LIKE 'hot_cache.key_buffer_size';

这是能够在任何可能发生简单变量名的地方使用结构化变量名的例外。

本文由:学什么技术好

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值