跳到主要内容

通过yaml修改数据库参数教程

由于数据库的某些参数在修改后无法立即生效,因此需要通过应用yaml来实现修改参数并重启数据库通过yaml修改参数会导致数据库重启 ,整个过程大概会持续20s左右。这里以Postgres数据库的参数修改为例,具体操作步骤如下:

  1. 进入终端

config_1

  1. 编辑pg-config.yaml
$ vim pg-config.yaml

config_2

  1. 复制yaml到pg-config.yaml中,保存pg-config.yaml

config_3

apiVersion: apps.kubeblocks.io/v1alpha1
kind: OpsRequest
metadata:
name: test
spec:
clusterRef: test-pg #修改为自己的数据库名
reconfigure:
componentName: postgresql
configurations: #以下配置仅供参考,只需保留要修改的部分即可,并修改对应的参数的值
- keys:
- key: postgresql.conf
parameters:
- key: max_connections #设置可以同时与数据库建立的最大连接数
value: "1000"
name: postgresql-configuration
ttlSecondsAfterSucceed: 0
type: Reconfiguring

常见的postgres参数

参数名描述
max_connections设置可以同时与数据库建立
的最大连接数
max_wal_size设置WAL文件的最大大小
min_wal_size设置WAL文件的最小大小
max_worker_processes设置PostgreSQL可以启动
的最大后台进程数
shared_buffers设置PostgreSQL可以启动
的最大后台进程数

常见的mysql参数

参数名描述
innodb_buffer_pool_size设置InnoDB缓冲池的大小
max_connections允许的最大并发连接数
query_cache_size查询缓存的大小
thread_cache_size线程缓存的大小
max_allowed_packet最大数据包大小
innodb_log_file_sizeInnoDB日志文件的大小

常见的mongo参数

参数名描述
storage.dbPath数据文件存放路径
storage.journal.enabled启用日志
net.port服务器端口
net.bindIp绑定的IP地址

常见的redis参数

参数名描述
maxclients最大客户端连接数
maxmemory最大内存使用量
maxmemory-policy内存淘汰策略
appendonlyAOF持久化开关
appendfsyncAOF文件刷新频率
  1. 应用pg-config.yaml
$ kubectl apply -f pg-config.yaml

config_4

  1. 检查pg-config.yaml是否应用成功
# OpsRequest中对应的状态为Succeed且pod对应的状态为Running则说明配置应用成功
$ kubectl get OpsRequest
$ kubectl get pod

config_5

  1. 进入数据库查看配置是否生效
$ show max_connections;

config_6 config_7