postgresSQL 配置文件设置

news/2024/7/9 20:22:52 标签: postgresql

postgres.conf 是 PostgreSQL 数据库的主要配置文件,其中包含了许多关于数据库行为的设置。以下是一些常见的配置项:

  1. listen_addresses: 这个参数定义了 PostgreSQL 服务监听的网络地址。默认值是 ‘localhost’,这意味着只有本机的客户端才能连接到数据库。如果你希望其他机器也能够连接到此数据库服务,你可以改成 ‘*’(表示所有地址)或者一个特定的 IP 地址。
  2. port: 这个参数定义了 PostgreSQL 服务监听的端口号,默认是 5432。
  3. max_connections: 这个参数定义了同时连接到 PostgreSQL 的最大客户端数量。这个数目应该根据系统的能力和需求来设定。
  4. shared_buffers: 这个参数设置了 PostgreSQL 用于缓存数据的内存大小。提高此值可以加速数据库操作,但是过高的值可能会浪费系统资源。
  5. work_mem: 这个参数设置了排序操作和哈希表需要使用的内存。每个活动的排序操作或哈希表都会分配到这么多内存。
  6. maintenance_work_mem: 这个参数定义了 VACUUM 和 CREATE INDEX 等维护操作的内存量。
  7. wal_level: 这个参数决定了写入预写日志(WAL)的信息等级。可选的值包括 ‘minimal’, ‘replica’, 和 ‘logical’。
  8. autovacuum: 这个参数开启或关闭自动清理功能。当它开启时,PostgreSQL 将会定期清理数据库,删除旧的记录和更新统计信息。

以上配置项,如何设置postgressql性能最高呢
下面是一些常见的 PostgreSQL 配置项和相应的调整方法,可以提高数据库的性能:

  1. shared_buffers:这个参数决定了 PostgreSQL 数据库引擎在内存中缓存多少数据和索引。根据系统内存量选择适当的值,通常设置为总物理内存的 25% - 40%。
  2. work_mem:这个参数控制了排序操作和哈希表操作可用的内存大小。将它设置得越大,进行大查询和复杂排序时速度就越快。但是要注意,这个值过高可能会导致系统内存不足,每个连接都会使用这么多内存。
  3. maintenance_work_mem:这个参数用于 VACUUM ,ANALYZE,CREATE INDEX 等命令,增加这个数值可以使得这些命令执行得更快。通常可以设置为系统内存的 10%。
  4. effective_cache_size:这个参数决定了 PostgreSQL 认为在操作系统和自身缓冲区之外还有多少可用的磁盘缓存。一般设置为物理内存的50%-75%。
  5. wal_buffers:日志缓冲区的大小。如果你的系统有大量的写入操作,增加这个参数可以提高性能。
  6. checkpoint_completion_target:提高检查点完成目标可以减少 I/O 的峰值和平均值,一般设为0.9。
  7. random_page_cost:这个参数用于 PostgreSQL 查询计划器评估扫描一张表的成本。降低此值会使得 PostgreSQL 更倾向于使用索引扫描而非顺序扫描。
  8. max_connections:根据实际业务并发需求设定,设的过高会浪费系统资源。

以上仅为通用建议,实际操作中,优化数据库需要根据具体情况来调整参数,并且需要反复测试以确保改动真正提高了性能。最后,PostgreSQL 官方文档将这些参数的作用描述的非常详细,强烈推荐阅读。


http://www.niftyadmin.cn/n/4953844.html

相关文章

optee中如何开启或关闭所有中断的

我们知道在Linux Kernel中开启或关闭中断的函数是:local_irq_enable()和local_irq_disable(), 那么在optee os中是怎样做到的呢? optee中通过使用thread_mask_exceptions()和thread_unmask_exceptions()来开启或关闭中断。 thread_mask_exceptions()和thread_unmask_excepti…

热门调查问卷平台排名公布!

在如今这个信息爆炸的时代,随着互联网和科技的蓬勃发展,各种软件和应用层出不穷,其中问卷工具更是早已经被广泛应用了。通过问卷调查,不仅可以有效的获取用户的意见和反馈,还可以为企业或团队提供更优质的服务和产品。…

【Python机器学习】实验13 基于神经网络的回归-分类实验

文章目录 神经网络例1 基于神经网络的回归(简单例子)1.1 导入包1.2 构造数据集(随机构造的)1.3 构造训练集和测试集1.4 构建神经网络模型1.5 采用训练数据来训练神经网络模型 实验:基于神经网络的分类(鸢尾花数据集)1. 导入包2. 构造数据集3.…

17.HPA和rancher

文章目录 HPA部署 metrics-server部署HPA Rancher部署Rancherrancher添加集群仪表盘创建 namespace仪表盘创建 Deployments仪表盘创建 service 总结 HPA HPA(Horizontal Pod Autoscaling)Pod 水平自动伸缩,Kubernetes 有一个 HPA 的资源&…

8月19日,每日信息差

1、电影《孤注一掷》票房突破25亿 2、东京面临“缺水危机”,政府呼吁居民节水,东京主要水源上游多个水库蓄水量告急,水位今后可能进一步降低,希望居民配合节约用水 ​3、西安等14城市将实现住房公积金互认互贷,西安、…

RuoYi项目下载及配置启动

一. 前置要求 这里假设你已经安装并配置了JDK1.8,Node,Git,IDEA,vscode,MySQL,navicat 16,Redis,RDM环境,如果没有下载安转可以参考我的博客找到对应的软件下载安装即可 二.下载源码 官网地址 方式一:直接下载ZIP压缩包 方式二:利用Git下载源码 点击复制之后,在需要下载代码…

C++系列-类和对象-初始化列表

类和对象-初始化列表 初始化列表 初始化列表 用于初始化属性构造函数():属性1(值1), 属性2(值2),属性3(值3)构造函数(属性1,属性2,属性3):属性1&…

Docker-compose详解和LNMP搭建实战

目录 一、Docker-compose简介 1.前言 2.概述 二、Docker-compose安装 安装源获取 安装包下载 三、YAML文件格式及编写注意事项 1.简介 2.使用方法 四、Docker Compose 常用命令 五、Docker Compose 配置常用字段 六、Docker-compose搭建LNMP实战 一、Docker-compose…