mysql 内核参数修改_CentOS中运行PostgreSQL需要修改的内核参数及配置脚本分享

CentOS中运行PostgreSQL需要修改的内核参数及配置脚本分享

发布于 2016-02-26 09:13:28 | 290 次阅读 | 评论: 0 | 来源: 网友投递

PostgreSQL关系型数据库管理系统PostgreSQL是以加州大学伯克利分校计算机系开发的 POSTGRES,现在已经更名为PostgreSQL,版本 4.2为基础的对象关系型数据库管理系统(ORDBMS)。

这篇文章主要介绍了CentOS中运行PostgreSQL需要修改的内核参数及配置脚本分享,本文从系统资源限制类和内存参数优化类来进行说明,需要的朋友可以参考下

PostgreSQL在CentOS上部署的时候,需要设置一些操作系统的参数,官方文档上列举了一些(传送门)。除了这些,还有一些其他的设置,如单个用户允许的最大进程数,单个进程的最大句柄数等,这些一般也需要调整,否则系统会在一些条件下出现问题,或者性能下降。下面从系统资源限制类和内存参数优化类来进行说明.

系统资源限制类

1.单个用户允许的最大进程数:linux系统默认是1024,如果PG的最大连接数超过1024,则实际的连接数会小于1024(PG的postmaster进程,checkpointer进程,bgwriter进程,WAL发送进程,日志进程等会占用几个进程数,所以给客户段的连接数会小于1024),超过的连接请求会报资源不够的错误信息.所以为了避免这种情况,需要调整PG的linux用户的可以使用的进程数,一般通过limit.conf进行配置.

2.单个进程可以打开的最大文件数:linux默认是1024,在SQL很复杂,打开很多表,或者访问很多分区时,会出现句柄数不够的错误.

内存参数优化类

1.vm.dirty_background_ratio:这个参数控制当系统内存写脏的比例达到多少时,会启动后台进程将buffer刷到磁盘.默认是10%,对于大内存的机器,如超过64G,10%的内存为6.4,一次把6.4G数据写入磁盘,会瞬间产生大量磁盘IO,使系统失去响应,影响其他进程.所以一般8G以上内存的机器,推荐设置为1%.

2.vm.dirty_background_types:这个参数与上面的类似,只不过这个参数可以设置内存脏掉的绝对值.着两个参数其中一个为0,则另外一个会起作用.

下面是配置这几个参数的脚本,在CentOS 6.x上测试OK.

#limit process to 4096 instead 1024,for we may have 1024+ connections

echo "postgres        soft    nproc           4096" >> /etc/security/lmits.conf

#for big query,pg may open more than 1024 files per session

echo "postgres        hard    nofile          65535" >> /etc/security/limits.conf

echo "postgres        soft    nofile          65535" >> /etc/security/limits.conf

#default is 10% of memory,to smooth the io peek value,

#set this to tune background process flush buffer more frequently

echo "vm.dirty_background_ratio=0" >> /etc/sysctl.conf

echo "vm.dirty_background_bytes=1024000000" >> /etc/sysctl.conf

#make the sysctl.conf setting take effect

sysctl -p

#make limit to take effect

/etc/init.d/sshd restart

相关阅读:

CentOS中运行PostgreSQL需要修改的内核参数及配置脚本分享

PostgreSQL中关闭死锁进程的方法

深入解读PostgreSQL中的序列及其相关函数的用法

PostgreSQL中的OID和XID 说明

PostgreSQL中的XML操作函数代码

PostgreSQL中常用的时间日期脚本使用教程

PostgreSQL中使用dblink实现跨库查询的方法

详解PostgreSQL 语法中关键字的添加

Ubuntu中卸载Postgresql出错的解决方法

window下在cmd下进入postgreSQL数据库的设置方法

让PostgreSQL支持没有别名的子查询(Oracle兼容)

PostgreSQL中调用存储过程并返回数据集实例

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值