[转帖]PostgreSQL 参数优化设置 32GB内存(推荐) 内存参数 检查点 日志参数 自动初始化参数shell脚本
这个shell脚本可以使用shell的关联数组对
-
#!/bin/bash
-
#command to execute script: su - postgres -c "./create.sh"
-
#default value refer to standard server(cpu:6cores,memory:32G,storage:12T)
-
#value according to the actual situation
-
-
#List of parameters to be modified
-
:<<!
-
enable_seqscan = off
-
enable_indexscan = on
-
enable_bitmapscan = on
-
max_connections = 1000
-
shared_buffers = 16GB
-
effective_cache_size = 24GB
-
work_mem = 32MB
-
temp_buffers = 32MB
-
wal_buffers = 512MB
-
maintenance_work_mem = 2GB
-
autovacuum_max_workers = 3
-
autovacuum_work_mem = 256MB
-
checkpoint_timeout = 30min
-
max_wal_size = 4GB
-
min_wal_size = 1GB
-
checkpoint_completion_target = 0.9
-
log_destination = csvlog
-
log_directory = pg_log
-
logging_collector = on
-
log_min_duration_statement = 800
-
log_rotation_size = 1024MB
-
log_truncate_on_rotation = on
-
log_filename = 'xl_log_%a.log'
-
!
-
-
ERROR="\033[41;37m ERROR \033[0m"
-
INFO="\033[42;37m INFO \033[0m"
-
WARN="\033[43;37m WARN \033[0m"
-
COMMON_ERROR="some error happened, specific information please see console output"
-
-
# Array of parameters
-
declare -A parameter_array
-
parameter_array=([enable_seqscan]=off [enable_indexscan]=on [enable_bitmapscan]=on [max_connections]=1000 [shared_buffers]=16GB
-
[effective_cache_size]=24GB [work_mem]=32MB [temp_buffers]=32MB [wal_buffers]=512MB [maintenance_work_mem]=2GB
-
[autovacuum_max_workers]=3 [autovacuum_work_mem]=256MB [checkpoint_timeout]=30min [max_wal_size]=4GB
-
[min_wal_size]=1GB [checkpoint_completion_target]=0.9 [log_destination]=csvlog [log_directory]=pg_log
-
[logging_collector]=on [log_min_duration_statement]=800 [log_rotation_size]=1024MB [log_truncate_on_rotation]=on [log_filename]=viid_log_%a.log )
-
-
#default value :
-
pgctl_path=
-
data_directory=
-
memory=
-
-
# check command exit value, 0 is success
-
function check_fun(){
-
status=$?
-
error=${COMMON_ERROR}
-
if [[ 0 -ne ${status} ]] ; then
-
echo -e "${ERROR} ${error}"
-
exit 1
-
fi
-
}
-
-
# prepare conditions
-
function prepare_conditions(){
-
data_directory=$(psql -qtAX -c "show data_directory" | sed 's/[ ]//g')
-
check_fun
-
if [[ ! -d "${data_directory}" ]] ; then
-
echo -e "${ERROR} database's data directory does not exist"
-
exit 1
-
fi
-
# physical machine environment
-
memory=$(grep MemTotal /proc/meminfo | awk '{print $2 / 1024 / 1024}' | sed 's/\.[0-9]*//' | tail -n 1)
-
check_fun
-
# docker environment
-
memory_limit=$(($(awk '{print $1}' /sys/fs/cgroup/memory/memory.limit_in_bytes) / 1024 / 1024 /1024))
-
check_fun
-
# comparing the two, choose the smaller one.
-
if [[ "${memory_limit}" -le "${memory}" ]] ; then
-
memory=${memory_limit}
-
fi
-
}
-
-
# calculate parameters
-
function calculate_parameters(){
-
# 50%*memory
-
parameter_array[shared_buffers]=$((memory * 1024 / 2))"MB"
-
# 75%*memory
-
parameter_array[effective_cache_size]=$((memory * 1024 * 3 / 4 ))"MB"
-
# <1%
-
parameter_array[work_mem]=${memory}"MB"
-
# <1%
-
parameter_array[temp_buffers]=${memory}"MB"
-
# 32GB => 512MB
-
parameter_array[wal_buffers]=$((memory * 16 ))"MB"
-
# 32GB => 2048MB
-
parameter_array[maintenance_work_mem]=$((memory * 64 ))"MB"
-
}
-
-
# modify parameters
-
function modify_parameters(){
-
# modify parameters by modifying file postgresql.conf:
-
for parameter in ${!parameter_array[*]}
-
do
-
#check whether the parameters have been modified
-
# PostgreSQL's default parameter configuration example: enable_seqscan = on
-
# viid's example: enable_seqscan='on'
-
check_out=$(grep "^${parameter}=" "${data_directory}"/postgresql.conf | grep -v '#' | tail -n 1)
-
# process sleep
-
sleep 0.2s
-
if [[ -z "${check_out}" ]] ; then
-
echo "${parameter}='${parameter_array[${parameter}]}'" >> "${data_directory}"/postgresql.conf
-
check_fun
-
echo -e "${INFO} modify ${parameter} successfully"
-
else
-
if [[ "${check_out}" = "${parameter}='${parameter_array[${parameter}]}'" ]] ; then
-
echo -e "${INFO} ${parameter} is already configured, then skip this step"
-
else
-
sed -i s!^"${check_out}"!"${parameter}='${parameter_array[${parameter}]}'"!g "${data_directory}"/postgresql.conf
-
check_fun
-
echo -e "${INFO} modify ${parameter} successfully"
-
fi
-
fi
-
done
-
}
-
-
# create directory(pg_log and pg_arch), and set user postgres permission
-
function create_dir(){
-
directory_array=("pg_arch" "pg_log")
-
for directory in ${directory_array[*]};
-
do
-
# process sleep
-
sleep 0.2s
-
if [[ ! -d "${data_directory}/${directory}" ]] ; then
-
mkdir -p "${data_directory}"/"${directory}"
-
echo -e "${INFO} path ${data_directory}/${directory} create successfully"
-
else
-
echo -e "${INFO} ${data_directory}/${directory} is already exists, then skip this step"
-
fi
-
# set user postgres permission
-
chown postgres:postgres "${data_directory}"/"${directory}"
-
done
-
}
-
-
# because the environment is different, need to find the path of the database restart command 'pg_ctl'
-
function find_cmd(){
-
result=$(find / -name pg_ctl 2> /dev/null | grep bin/pg_ctl$ | tail -n 1 )
-
# check whether the path exists
-
if [[ -z "${result}" ]] ; then
-
echo -e "${ERROR} database restart command 'pg_ctl' not exists"
-
echo -e "${ERROR} please check to see if the database is installed or the command directory does not have permission to access it"
-
exit 1
-
else
-
echo -e "${INFO} database restart command 'pg_ctl' path: ${result}"
-
pgctl_path=${result}
-
fi
-
}
-
-
# user choose whether to restart or not
-
function check_restart(){
-
read -r -p "Is it necessary to restart database immediately?[Enter YES or NO]:" result
-
if [[ "${result,,}" = "yes" ]] ; then
-
echo -e "${INFO} start to restart database"
-
${pgctl_path} restart -D "${data_directory}" >& /dev/null
-
if [[ 0 -ne ${status} ]] ; then
-
echo -e "${ERROR} restart database failed"
-
exit 12
-
fi
-
elif [[ "${result,,}" = "no" ]] ; then
-
echo -e "${WARN} please restart database manually"
-
echo -e "${WARN} if you don't restart, database may not be available"
-
exit 11
-
else
-
echo -e "${ERROR} invalid input,please enter again"
-
check_restart
-
fi
-
}
-
-
# ******* start *******
-
# prepare conditions:memory ,data_directory
-
prepare_conditions
-
# calculate parameters
-
calculate_parameters
-
# modify parameters
-
modify_parameters
-
# create directory(pg_log and pg_arch)
-
create_dir
-
# the path of the database restart command 'pg_ctl'
-
find_cmd
-
# remind user that they need to restart database to take effect
-
# process sleep
-
sleep 0.5s
-
echo -e ""
-
echo -e "*******************************************************************"
-
echo -e "* *"
-
echo -e "* *"
-
echo -e "* restart database to take effect *"
-
echo -e "* *"
-
echo -e "* *"
-
echo -e "*******************************************************************"
-
# process sleep
-
sleep 0.5s
-
# user choose whether to restart or not
-
# check_restart
-
echo -e "${INFO} start to restart database"
-
${pgctl_path} restart -D "${data_directory}" >& /dev/null
-
[转帖]PostgreSQL 参数优化设置 32GB内存(推荐) 内存参数 检查点 日志参数 自动初始化参数shell脚本的更多相关文章
- vm内核参数优化设置
http://www.cnblogs.com/wjoyxt/archive/2014/06/08/3777042.html (1)vm.overcommit_memory 执行grep -i com ...
- ajax 参数data问题 data中的 参数名 参数值为string 提交到后台后,会自动转换参数名相同的 类型 和 js字符串拼接
latlng"14.6005238,100.43635419999998"Cusid"accb5c1b-6aef-4f3b-a4eb-d60ea1ca5f54" ...
- AI人脸识别SDK接入 — 参数优化篇(虹软)
引言 使用了虹软公司免费的人脸识别算法,感觉还是很不错的,当然,如果是初次接触的话会对一些接口的参数有些疑问的.这里分享一下我对一些参数的验证结果(这里以windows版本为例,linux.andro ...
- 虹软AI 人脸识别SDK接入 — 参数优化篇
引言 使用了免费的人脸识别算法,感觉还是很不错的,但是初次接触的话会对一些接口的参数有些疑问的.这里分享一下我对一些参数的验证结果(这里以windows版本为例,linux.android基本一样), ...
- linux——系统内核参数优化
vim /etc/sysctl.conf net.ipv4.tcp_syncookies = 1 fs.file-max = 999999 net.ipv4.tcp_max_tw_buckets = ...
- 使用服务器参数文件(SPFILE)管理初始化参数
传统上,Oracle数据库的初始化参数存储在文本初始化参数文件中.为了更好的可管理性,您可以选择在二进制服务器参数文件中维护初始化参数,该文件在数据库启动和关闭期间保持不变.本节介绍服务器参数文件,并 ...
- Ubuntu 系统服务器初始化配置、安全加固、内核优化和常用软件安装的Shell脚本分享
转载自:https://www.bilibili.com/read/cv13875402?spm_id_from=333.999.0.0 描述: 适用于企业内部 Ubuntu 操作服务器初始化.系统安 ...
- CentOS7 系统服务器初始化配置、安全加固、内核升级优化常用软件安装的Shell脚本分享
转载自:https://www.bilibili.com/read/cv13875630?spm_id_from=333.999.0.0 描述: 适用于企业内部 CentOS7 系列操作服务器初始化. ...
- javaee学习-servlet初始化参数
1.需要定义ServletConfig对象来接收servlet配置的初始化参数. 2.当servlet配置了初始化参数后,web容器在创建servlet实例对象时, 会自动将这些初始化参数封装到Ser ...
- ORACLE初始化参数文件概述
ORACLE初始化参数文件概述 在9i之前,参数文件只有一种,它是文本格式的,称为pfile,在9i及以后的版本中,新增了服务器参数文件,称为spfile,它是二进制格式的.这两种参数文件都是用来存储 ...
随机推荐
- 用 Socket.D 替代原生 WebSocket 做前端开发
socket.d.js 是基于 websocket 包装的 socket.d 协议的实现.就是用 ws 传输数据,但功能更强大. 功能 原生 websocket socket.d 说明 listen ...
- Programming Abstractions in C阅读笔记:p242-p245
<Programming Abstractions in C>学习第67天,p242-p245总结,总计4页. 一.技术总结 6.2小结主要讲回溯算法及递归算法在迷宫求解中应用,当然,理解 ...
- 面试官让列举Spring的事务会失效的场景,我说了8个
本文分享自华为云社区<哪些场景下Spring的事务会失效?>,作者:冰 河 . 在日常工作中,如果对Spring的事务管理功能使用不当,则会造成Spring事务不生效的问题.而针对Spri ...
- 揭秘GES超大规模图计算引擎HyG:图切分
摘要:GES大规模图计算引擎HyG通过实现不同的点边分区算法,可以灵活地供用户选择多种多样的切分策略,进而达到更好的运算性能. 本文分享自华为云社区<GES超大规模图计算引擎HyG揭秘之图切分& ...
- 带你了解NB-IoT标准演进
摘要:本文将带大家详细了解NB-IoT标准演进与产业发展. 本文分享自华为云社区<一文带你了解NB-IoT标准演进与产业发展>,作者:万万万. 我们都知道,物联网的场景和手机.电脑在使用的 ...
- 浏览器史话中chrome霸主地位的奠定与国产浏览器的割据混战
作为前端老鸟,从IE的6.7.8开始做前端,各种兼容性折磨死人.js还好有了jQuery.chrome出来后,真是救苦救难,解救程序员的于水火.但是可恶的boss还是要求兼容ie6,7.感谢淘宝团队的 ...
- 最高提升10倍性能!揭秘火山引擎ByteHouse查询优化器实现方案
更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 作为企业级数据库的核心组件之一,查询优化器的地位不可忽视.对于众多依赖数据分析的现代企业来说,一个强大且完善 ...
- docker镜像列表存在但删除显示 No such image问题解决
近期使用了docker,但删除镜像时候遇到了无法删除问题.提示:No such Image.原因有两个,解决方法如下: 原因1: 容器还存在是无法删除镜像的 解决步骤: 1.停掉容器(docker s ...
- JAVA CRC8
Java CRC8 /** * CRC-8 * * <table width="400px" border="1" cellpadding="0 ...
- 你不知道的vue3:使用runWithContext实现在非 setup 期间使用inject
前言 日常开发时有些特殊的场景需要在非 setup 期间调用inject函数,比如app中使用provide注入的配置信息需要在发送http请求时带上传给后端.对此我们希望不在每个发起请求的地方去修改 ...