一、设置参数

  • 所有参数名称都是不区分大小写的
  • 值为字符串时,需要单引号
  • 值为数值时不需要单引号,但带单位时,需要单引号
  • 配置文件(如:postgresql.conf、postgresql.auto.conf、pg_hba.conf) 默认在 database cluster 中
  • 可以在 postgresql.conf 中使用 include ‘file’ 或 include_dir ‘directory’ 形式插入外部文件或目录(其中的所有文件)内容

 二、文件位置

  • data_directory = '' 声明 database cluster 目录
  • hba_file = '' 指明 host base authentication 配置文件,通常是 pg_hba.conf(客户端认証主配置文件)
  • ident_file = '' 用于用户名匹配的配置文件,通常是 pg_ident.conf
  • external_pid_file = '' 声明此项将在 postmaster.pid 之外,生成一个額外的 PID 文件
  • 注:pg_ctl 与 initdb 的 -D 选项以及 PGDATA 环境变量指向的是 postgresql.conf 的位置,不是实际数据文件的位置,若配置文件与数据文件不在同一目录,必須在配置文件中指明 data_directory

三、连接与认証

  • listen_address = '' 监听目标,默认为 localhost ,多个 IP 用逗号分割,* 表示监听所有连接,0.0.0.0 表示监听所有 ipv4 连接,:: 表示监听所有 ipv6 连接,若留空,表示仅接受 Unix-domain sockets 本机连接
  • port = 5432 指明监听端口,默认 5432
  • max_connections = 100 最大并发连接数量,默认为 100 ,从服务器的此项设置必須大于或等于主服务器的值
  • superuser_reserved_connections = 3 为 PostgreSQL 的超級用户(通常为 postgres)預留的连接数,故普通客户端能连接的最大并发连接数量为 max_connections 减去本项之后的值
  • unix_socket_directories = '' 指明 Unix-domain sockets 的位置,以逗号分割多个值,若此项启用但值留空,则表示禁用 unix 域套接字连接,仅接受 TCP/IP 套接字连接
  • unix_socket_permissions = 0777 域套接字权限,默认为 0777 ,应设为 0700
  • authentication_timeout = ’1min‘ 默认是 1 分鈡,可设定范围 1s - 600s
  • ssl = off 是否启用 ssl 支持,默认是 off (bool 值无須加引号),启用设置 on
  • ssl_ca_file = ’‘ 用于証明客户端身份,指定包含可信任的 CA 机构信息(CA 的公钥等)的文件位置;若留空,则不进行客户端 SSL 认証
  • ssl_crl_file = ’‘ 用于証明客户端身份,指定包含其 CA 頒发机构的吊销列表的文件位置,在此列表中的客户端将不能连接 ;CRL 指 certificate revocation list
  • ssl_cert_file = ’‘ 用于証明服务端身份;指定服务器端 CA 証书的位置,默认是 server.crt
  • ssl_key_file = '' 用于証明服务端身份;指定服务器端 SSL 私钥的位置,默认是 server.key

四、資源消耗

  • shared_buffers = '128MB' Sets the amount of memory the database server uses for shared memory buffers,默认是 128MB ,对于专门的数据库服务器,应将其设置为物理内存的 25% 左右,最大不超过 40% ;同时需要上調 checkpoint_segments(9.5版本以前) 或 max_wal_size(9.6版本)
  • huge_pages = try 是否使用大頁内存,默认是 try ,即尽可能使用,否则转而使用普通的 4K 内存頁面;使用大頁可提高性能,仅在 Linux 平台上有效;另有 on 及 off 选项可用,分别代表强制使用大頁 及 不使用大頁
  • work_mem = '4MB' 单个排序、聚合、子查詢处理中使用的内存大小,默认是 4MB ,实际使用超限时会使用临时磁盘文件,设置较大的值可以提升性能,但并发較多时可能占用大量内存;
  • maintenance_work_mem = '64MB' 索引、外鍵等管理性操作可使用的最大内存数,默认为 64MB ,較大的值可以改进数据库转储、清理等操作的性能
  • max_stack_depth = '2MB' 服务器在栈中执行操作的最大深度,默认是 2MB ,較大的值可提升性能,但不能超过内核限制(使用 ulimits -s 查看),否则执行递归函数时可能会导致程序崩溃

五、Write Ahead Log

  • wal_level = minimal 預写式日志的记录級别,默认为 minimal ,推荐 replica(9.5及之前版本为 hot_standby),另可选 logical
  • fsync = on 磁盘同步,Linux 平台实际执行的是 fdatasync ,默认为 on
  • full_page_writes = on 默认开启;When this parameter is on, the PostgreSQL server writes the entire content of each disk page to WAL during the first modification of that page after a checkpoint
  • wal_compression = off 是否启用 WAL 压缩,默认关闭,开启将节省磁盘空间,但消耗更多 cpu 資源
  • wal_buffers = '' 推荐设置 5-10M ;The amount of shared memory used for WAL data that has not yet been written to disk. The default setting of -1 selects a size equal to 1/32nd (about 3%) of shared_buffers, but not less than 64kB nor more than the size of one WAL segment, typically 16MB
  • wal_writer_delay = '' WAL 写入延时,单位 ms ,即毫秒,默认 200ms

六、复制

PostgreSQL——服务器配置_{postgresql.conf}的更多相关文章

  1. PostgreSQL重新读取pg_hba.conf文件

    PostgreSQL  配置文件之pg_hba.conf 该文件用于控制访问安全性,管理客户端对于PostgreSQL服务器的访问权限,内容包括:允许哪些用户连接到哪个数据库,允许哪些IP或者哪个网段 ...

  2. PostgreSQL入门,PostgreSQL和mysql

    PostgreSQL被誉为“世界上功能最强大的开源数据库”,是以加州大学伯克利分校计算机系开发的POSTGRES 4.2为基础的对象关系型数据库管理系统. PostgreSQL支持大部分 SQL标准并 ...

  3. Mac安装postgresql和卸载PostgreSQL

    1.homebrew安装 brew install postgresql 2.初始化 initdb /usr/local/var/postgres 3.创建数据库及查看数据库 (1)先创建db. cr ...

  4. navicat 连接postgresql报错pg_hba.conf

    PostgreSQ数据库为了安全,它不会监听除本地以外的所有连接请求,当用户通过JDBC访问是,会报一些如下的异常: org.postgresql.util.PSQLException: FATAL: ...

  5. PostgreSQL configuration file postgresql.conf recommanded settings and how it works

    1        Set max_connections to three times the number of processor cores on the server. Include vir ...

  6. configs for postgresql restart and postgresql reload

    -- configs requiring postgresql restart select name, setting, context from pg_settings where context ...

  7. [PostgreSQL] 图解安装 PostgreSQL

    图解安装 PostgreSQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5894462.html 序 园友的一篇<Asp.Net Cor ...

  8. 【PostgreSQL 15】PostgreSQL 15对UNIQUE和NULL的改进

    用一句话来总结这种改进就是: 支持唯一性约束和索引将null值视为相同的值.之前是将null值索引成不同的值,现在可以通过使用unique nulls not distinct创建约束,将null值视 ...

  9. Understanding postgresql.conf : log*

    After loooong pause, adding next (well, second) post to the “series“. This time, I'd like to describ ...

随机推荐

  1. (9)C++ 对象和类

    一.类 1.访问控制 class student { int age;//默认私有控制 public: string name; double weight; }; 2.成员函数 定义成员函数时,使用 ...

  2. 用php写爬虫去爬数据

    参考文档1 参考文档2 这里是我自己写的一个小需求 <?php /** 采集http://www.959.cn/school,即时更新的最新的文章内容:每分钟采集一次.采集结束后实时入库并展示. ...

  3. J. The Volcano Eruption(圆相交+并查集)

    题目链接:https://codeforces.com/gym/101915/problem/J 思路:将所有相交的圆用并查集维护看做一个整体,然后枚举每个整体的左边界和右边界,判断能不能同时覆盖整个 ...

  4. 【react】---redux-actions的基本使用---【巷子】

    一.安装 cnpm install --save redux-actions 二.为什么使用 redux-actions reducer使用switch case语句进行action类型判断,当act ...

  5. sql合并字段

    <!-- 对发送方式合并查询 --> <!--查询所有满足条件的营销活动 --> <select id="CRM-MK-ACT-DEFINE-SELECT&qu ...

  6. MySQL中的关系

    关系 将实体与实体的关系,反应到最终数据库表的设计中来.将关系分为三种:一对一,一对多(多对一)和多对多.所有的关系都是指的是表与表之间的关系. 一对一 一张表中的一条记录一定只能与另外一张表的一条记 ...

  7. Javascript高级程序设计--读书笔记之Array类型

    1.数组的lenght属性 数组的lenght属性很有特点---他不是只读的,可以同过修改这个属性来向数组的末尾添值加或删除值, 删除值 var color = ["red", & ...

  8. tail - 输出文件的末尾部分

    SYNOPSIS(总览) ../src/tail [OPTION]... [FILE]... DESCRIPTION(描述) 在标准输出上显示每个FILE的最后10行. 如果多于一个FILE,会一个接 ...

  9. zabbix生产环境案例(三)

    生产环境案例(三) 链接:https://pan.baidu.com/s/1q5YwJMTcZLcS5OQ0iOu44A 提取码:8gdi 复制这段内容后打开百度网盘手机App,操作更方便哦 1. Z ...

  10. POJ-2888 Magic Bracelet(Burnside引理+矩阵优化+欧拉函数+逆元)

    Burnside引理经典好题呀! 题解参考 https://blog.csdn.net/maxwei_wzj/article/details/73024349#commentBox 这位大佬的. 这题 ...