炫“库”行动-人大金仓有奖征文-KingbaseES的参数设置介绍(三)

 【本文正在参与炫“库”行动-人大金仓有奖征文】

活动链接:https://marketing.csdn.net/p/98bd30353e7cb998b6070a89e8b91edb

参数设置总结

从上文的参数优先级别介绍与示例中,我们可以得出KingbaseES的各种优先级的参数设置方式具备如下的特性:

优先级

影响范围

是否操作语句(Y/N)

参数可在线更新(Y/N)

持久化(Y/N)

1

整个系统

N

N

Y

2

整个系统

Y

Y

Y

3

整个系统

N

N

N(服务运行时有效)

4

整个系统

Y

N

Y

5

数据库

Y

N

Y

6

角色

Y

N

Y

7

会话

Y

Y

N(会话重启后复位)

8

事务

Y

Y

N

9

函数

Y

Y

Y(函数定义持久化)

10

语句

Y

Y

N

从上表与上文的描述,我们可以得出以下结论:

  1. 参数影响的范围越小,优先级往往越高。
  2. 一些参数配置方式可持久化参数的配置,一些配置方式不可持久化,用户需要按需使用。
  3. 仅ALTER SYSTEM SET+sys_reload_conf()组合命令与SET命令可实现参数的在线更新。

一般而言,一旦数据库服务启动,用户多采用可支持在线更新的“操作语句”来设置配置参数。其中的SET属于会话级别语句,修改后参数立即生效,支持在线更新;ALTER SYSTEM SET命令仅仅能够修改配置文件kingbase.auto.conf,它与函数sys_reload_conf()配合可实现参数在线更新。用户在应用ALTER SYSTEM SET与SET命令时,特别是同时配置同一个参数是需要注意几种场景。它们的关系是:

  1. 会话级参数设置命令SET仅仅影响自身会话而不影响其它会话,ALTER SYSTEM SET+sys_reload_conf()组合命令影响所有的会话。
  2. 先被SET命令设置过的参数,再被ALTER SYSTEM SET+sys_reload_conf()组合命令修改时,不会更改该参数在本会话的设置。
  3. ALTER SYSTEM SET+sys_reload_conf()组合命令修改过的参数,会被优先级高的SET命令覆盖在本会话的设置。

场景一、用户同时开启多个(假设3个)连接会话,用户在其中一个会话中使用ALTER SYSTEM SET+sys_reload_conf()组合命令配置参数param,其它会话未进行该参数的配置,则参数param完成对所有会话的设置。示例如下:

会话A:(参数work_mem由4MB修改为10MB

kingbase=# show work_mem;

 work_mem

----------

 4MB

(1 row)

kingbase=# alter system set work_mem='10MB';

ALTER SYSTEM

kingbase=# select sys_reload_conf();

 sys_reload_conf

----------------

 t

(1 row)

kingbase=# show work_mem;

 work_mem

----------

 10MB

(1 row)

会话B:(参数work_mem被A会话同步修改为10MB

kingbase=# show work_mem;

 work_mem

----------

 10MB

(1 row)

会话C:(参数work_mem被A会话同步修改为10MB

kingbase=# show work_mem;

 work_mem

----------

 10MB

(1 row)

场景二、用户同时开启多个(假设3个)连接会话,用户在其中一个会话中使用ALTER SYSTEM SET+sys_reload_conf()组合命令配置参数param,并在本会话使用了SET命令配置参数param,其它会话未进行该参数的配置,则ALTER SYSTEM SET+sys_reload_conf()组合命令完成对除本会话之外的所有会话的param参数设置,SET命令完成对本会话的param参数设置。示例如下:

会话A:(参数work_mem由4MB修改为10MB,最后再被SET修改为12MB

kingbase=# show work_mem;

 work_mem

----------

 4MB

(1 row)

kingbase=# alter system set work_mem='10MB';

ALTER SYSTEM

kingbase=# select sys_reload_conf();

 sys_reload_conf

----------------

 t

(1 row)

kingbase=# show work_mem;

 work_mem

----------

 10MB

(1 row)

kingbase=# set work_mem ='12MB';

SET

kingbase=# show work_mem;

 work_mem

----------

 12MB

(1 row)

会话B:(参数work_mem被A会话同步修改为10MB,不受会话A的SET命令影响

kingbase=# show work_mem;

 work_mem

----------

 10MB

(1 row)

会话C:(参数work_mem被A会话同步修改为10MB,不受会话A的SET命令影响

kingbase=# show work_mem;

 work_mem

----------

 10MB

(1 row)

场景三、用户同时开启多个(假设3个)连接会话,用户先并在一个会话使用了SET命令配置参数param,然后再在该会话中使用ALTER SYSTEM SET+sys_reload_conf()组合命令配置参数param,其它会话未进行该参数的配置,则ALTER SYSTEM SET+sys_reload_conf()组合命令完成对除本会话之外的所有会话的param参数设置,SET命令完成对本会话的param参数设置。示例如下:

会话A:(参数work_mem使用SET由4MB修改为10MB,最后再被ALTER SYSTEM修改为12MB,由于ALTER SYSTEM优先级低于SET命令所以值仍然为10MB

kingbase=# set work_mem ='10MB';

SET

kingbase=# show work_mem;

 work_mem

----------

 10MB

(1 row)

kingbase=# alter system set work_mem='12MB';

ALTER SYSTEM

kingbase=# select sys_reload_conf();

 sys_reload_conf

----------------

 t

(1 row)

kingbase=# show work_mem;

 work_mem

----------

 10MB

(1 row)

会话B:(参数work_mem被A会话同步修改为12MB,不受会话A的SET命令影响

kingbase=# show work_mem;

 work_mem

----------

 12MB

(1 row)

会话C:(参数work_mem被A会话同步修改为12MB,不受会话A的SET命令影响

kingbase=# show work_mem;

 work_mem

----------

 12MB

(1 row)

场景四、用户同时开启多个(假设3个)连接会话,用户在其中一个会话中使用ALTER SYSTEM SET+sys_reload_conf()组合命令配置参数param,并在另外一个会话使用了SET命令配置参数param,其它会话未进行该参数的配置,则ALTER SYSTEM SET+sys_reload_conf()组合命令完成对除另外会话之外的所有会话的param参数设置,SET命令完成对另外会话的param参数设置。示例如下:

会话A:(参数work_mem被ALTER SYSTEM修改为14MB

kingbase=# show work_mem;

 work_mem

----------

 4MB

(1 row)

kingbase=# alter system set work_mem='14MB';

ALTER SYSTEM

kingbase=# select sys_reload_conf();

 sys_reload_conf

----------------

 t

(1 row)

kingbase=# show work_mem;

 work_mem

----------

 14MB

(1 row)

会话B:(参数work_mem被A会话同步修改为14MB,使用SET命令后设置为10MB

kingbase=# show work_mem;

 work_mem

----------

 14MB

(1 row)

kingbase=# set work_mem ='10MB';

SET

kingbase=# show work_mem;

 work_mem

----------

 10MB

(1 row)

会话C:(参数work_mem被A会话同步修改为14MB,不受会话B的SET命令影响

kingbase=# show work_mem;

 work_mem

----------

 14MB

(1 row)

【本文正在参与炫“库”行动-人大金仓有奖征文】

活动链接:https://marketing.csdn.net/p/98bd30353e7cb998b6070a89e8b91edb

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值