KingbaseES中的参数查看与修改
KingbaseES数据库的配置参数都在kingbase.conf文件中,这些参数有些是直接修改就可以生效,有些需要重启数据库才能生效,而有些根本就不能修改。数据库把这些参数分为以下几类:
- internal:这类参数为只读参数。有些是程序写死的,有些是在安装数据库时intdb时设置好的。
- kingbase:这类参数需要重启数据库服务才能生效。
- sighup:无需重启数据库,但要向kingbase进程发送sighup信号,即需要操作系统命令sys_ctl reload或进入ksql中, select sys_reload_conf();重新加载配置文件。
- backend:无需重启数据库,只需向kingbase进程发送sighup信号。但新的配置参数只能在之后的新连接中生效,已有连接中这些参数值不会改变。
- superuser:这类参数可以由超级用户使用set命令修改。参数设置后只会影响超级用户自身的session配置,不会影响其他用户。
- user:普通用户使用set命令修改,这类参数修改后和superuser类参数一样,也是只影响自身session。
我们可以通过查询sys_settings表的context字段值来查看参数是否需要重启数据库生效。如下:
test=# select name,context,pending_restart from sys_settings where name like 'bgwriter%';
name | context | pending_restart
-------------------------+---------+-----------------
bgwriter_delay | sighup | f
bgwriter_flush_after | sighup | f
bgwriter_lru_maxpages | sighup | f
bgwriter_lru_multiplier | sighup | f
可以通过查看sys_file_settings查看你设置的参数是否生效。例如如果你设置了⼀个参数需要重启数据库才能生效或者设置错误,那么在此字典中会出现报错。
1.全局参数修改:
使用alter system 命令修改参数.使用alter system命令将修改kingbase.auto.conf文件,而不是kingbase.conf文件,这样可以很好的保护kingbase.conf文件,不要手工对kingbase.auto.conf文件进行修改。该文件保存最新的配置,当数据库服务重启时,kingbase.auto.conf 里的修建项配置优先。当 kingbase.conf 和kingbase.auto.conf两个文件中都存在相同参数,kingbase.conf文件修改无效。
查看kingbase.auto.conf文件
[kingbase@localhost data]$ cat kingbase.auto.conf |grep 'work'
work_mem = '8MB'
使用sys_ctl reload命令重载配置文件,再查看参数值:
test=# show work_mem;
work_mem
----------
8MB
(1 row)
2.使用set命令,在会话层修改,修改之后将被用于未来的每个事务,但只对当前会话有效。
test=# set work_mem='20MB';
SET
test=#
test=# show work_mem;
work_mem
----------
20MB
(1 row)
这时候再打开一个会话看到work_mem还是4MB,因为只对当前会话有效。
3.set命令后添加 local关键字, 只在当前事务中修改,只在当前事务内有效:
test=# show work_mem;
work_mem
----------
20MB
(1 row)
test=#
test=# begin;
BEGIN
test=# set local work_mem='10MB';
SET
test=#
test=# show work_mem;
work_mem
----------
10MB
(1 row)
test=# commit;
COMMIT
test=# show work_mem;
work_mem
----------
20MB
(1 row)
4.使用 reset恢复参数的默认值
可以通过视图sys_settings里的字段reset_val字段中的值了解此参数恢复默认值的大小。使用reset all可以恢复所有参数值。
test=# select name , reset_val from sys_settings where name like 'work%';
name | reset_val
----------+-----------
work_mem | 8192
(1 row)
test=# show work_mem;
work_mem
----------
20MB
(1 row)
test=# reset work_mem;
RESET
test=# show work_mem;
work_mem
----------
8MB
(1 row)
5.为特定的用户设置参数
5.1.为特定的数据库的所有用户设置参数.
单独为test数据库所有的连接设置work_mem为16MB:
test=# alter database test set work_mem='16MB';
ALTER DATABASE
test=#
5.2.为数据库中的某个用户设置参数.
例如为bob用户,设置work_mem为4MB:
test=# alter role bob set work_mem='4MB';
ALTER ROLE
经过测试发现,如果你同时为数据库和用户设置了特定参数,那么以用户参数为准.例如上面,如果我用bob用户连接到test数据库,那么我的work_mem应该为4MB:
test=# \c test bob
You are now connected to database "test" as user "brent".
test=>
test=# show work_mem;
work_mem
----------
4MB
(1 row)
5.3.为某个用户连接到特定的数据库设置参数.
例如为用户ttname在数据库test中设置work_mem为8MB
test=> alter role ttname in database test set work_mem='8MB';
ALTER ROLE
上面说的三种设置,优先级递增,例如,如果1,2,3全部设置了那么就以第3个为准,如果设置了1,2那么就是以2为准。
KingbaseES对此的实现方法和当用户连接数据库的时候,手动执行set命令的效果完全相同
查看你当前的参数值是从何处指定,可以通过查询sys_setttings中的source字段获取,例如如果设置了database级别的参数.那么查询结果如下:source为database
test=# select name,setting,source from sys_settings where name='work_mem';
name | setting | source
----------+---------+----------
work_mem | 16384 | database
例如设置了第三种:source为databae user
test=> \c test ttname
You are now connected to database "test" as user "ttname".
test=> select name,setting,source from sys_settings where name='work_mem';
name | setting | source
----------+---------+---------------
work_mem | 8192 | database user
(1 row)
总结:综上所述,如果通过数据字典视图查看参数生效条件。可从全局或session级更改参数等。
KingbaseES中的参数查看与修改的更多相关文章
- ORACLE隐藏参数查看及修改
查看隐藏参数 select x.ksppinm name, y.ksppstvl value, y.ksppstdf isdefault, decode(bitand(y.ksppstvf,7),1, ...
- Linux中文件权限查看和修改
权限定义 linux文件权限分为:r读权限(4).w写权限(2).x执行权限(1) linux权限对象分为:拥有者.组用户.其他用户 权限修改: chown user:group /usr/local ...
- 如何修改myeclipse 内存?eclipse.ini中各个参数的作用。
修改MyEclipse/eclipse文件夹中配置文件eclipse.ini中的内存分配就哦了 =================================== 一般的ini文件设置主要包括以下 ...
- 如何修改myeclipse 内存,eclipse.ini中各个参数的作用。
修改MyEclipse/eclipse文件夹中配置文件eclipse.ini中的内存分配就哦了 =================================== 一般的ini文件设置主要包括以下 ...
- 如何在cmd命令行中查看、修改、删除与添加环境变量,语法格式例子:set path;echo %APPDATA%
如何在cmd命令行中查看.修改.删除与添加环境变量 首先明确一点: 所有的在cmd命令行下对环境变量的修改只对当前窗口有效,不是永久性的修改.也就是说当关闭此cmd命令行窗口后,将不再起作用.永久性修 ...
- oracle隐含参数的查看与修改
v$parameter视图中查询参数的时候其实都是通过x$ksppi和x$ksppcv这两个内部视图中得到的. 1. 可以通过如下方式查询当前实例的所有隐含参数: col name for a30 ...
- centos linux中怎么查看和修改计算机名/etc/sysconfig/network
centos linux中怎么查看和修改计算机名 查看计算机名:在终端输入hostname 修改的话 hostname +计算机名(重启后失效)要永久修改的话要修改配置文件/etc/sysconfig ...
- js 获取url中的参数 修改url 参数 移除url参数
js 获取url中的参数 修改url 参数 移除url参数 var jsUrlHelper = { getUrlParam : function(url, ref) { var str = " ...
- JavaWeb 学习006-4个页面,5条sql语句(添加、查看、修改、删除)
今天遇到的问题: 1. 在list页面上添加信息时候,跳转到doAdd页面后,点击保存按钮,能够跳转回list页面,但是新增的信息不能显示出来,就像是没有执行添加操作一样. 这是什么问题? ①是不是到 ...
随机推荐
- 《阿里云天池大赛赛题解析》——O2O优惠卷预测
赛事链接:https://tianchi.aliyun.com/competition/entrance/231593/introduction?spm=5176.12281925.0.0.7e157 ...
- skywalking链路监控
1. 下载安装包官网地址:http://skywalking.apache.org/downloads/ 2. tar xzf apache-skywalking-apm-6.5.0.tar.gz - ...
- MYSQL中IF IN语句
以下代码摘自后台管理系统中的一部分SQL语句: 当取数状态为1或2时,才展示取数时间,否则,取数时间展示为空 当申报状态为2.3.4或5时,才展示申报时间,否则,申报时间展示为空 select A.Q ...
- Tapdata Real Time DaaS 技术详解 PART I :实时数据同步
摘要:企业信息化过程形成了大量的数据孤岛,这些并不连通的数据孤岛是企业数字化转型的巨大挑战.Tapdata Real Time DaaS 采用的CDC模式,具有巨大的优势,同时是一个有技术壁垒的活 ...
- 文件的下载,HttpMessageConverter原理
HttpMessageConverter<T> 1) HttpMessageConverter<T> 是 Spring3.0 新添加的一个接口,负责将请求信息转换为一个对象(类 ...
- Collection集合和Collection集合常用功能
Collection集合常用功能 方法: boolean add(E e); 向集合中添加元素 boolean remove(E e); 删除集合中的某个元素 void clear(); 清空集合所有 ...
- dubbo(九):timeout超时机制解析
在网络请求时,总会有各种异常情况出现,我们需要提前处理这种情况.在完善的rpc组件dubbo中,自然是不会少了这一层东西的.我们只需要通过一些简单的配置就可以达到超时限制的作用了. dubbo的设计理 ...
- 解读Go分布式链路追踪实现原理
摘要:本文将详细介绍分布式链路的核心概念.架构原理和相关开源标准协议,并分享我们在实现无侵入 Go 采集 Sdk 方面的一些实践. 本文分享自华为云社区<一文详解|Go 分布式链路追踪实现原理& ...
- MIT 6.824 Lab2C Raft之持久化
书接上文Raft Part B | MIT 6.824 Lab2B Log Replication. 实验准备 实验代码:git://g.csail.mit.edu/6.824-golabs-2021 ...
- 002 JWT令牌
1.JWT数据 Json Web Token 添加数据 --> 解析数据 --> 传递数据 1.1 JWT数据处传递流程 注意:JWT数据必须携带在请求头(Request Header)的 ...