postgresql服务器配置

PostgreSQL服务器配置

环境准备与安装

PostgreSQL对操作系统有一定要求,推荐在Linux系统(如CentOS 7+/Ubuntu 20.04+)上部署,因其对系统资源管理更友好且兼容性佳。

操作系统与依赖安装

  • CentOS
    sudo yum update -y
    sudo yum install -y gcc make bison flex libtool ncurses-devel readline-devel zlib-devel openssl-devel perl
  • Ubuntu
    sudo apt update
    sudo apt install -y build-essential bison flex libreadline-dev libssl-dev zlib1g-dev libncurses5-dev libgdbm-dev libsqlite3-dev libxml2-dev libxml2-dev libxslt1-dev libffi-dev liblzma-dev

下载与编译安装

  • 从官网下载PostgreSQL源码包(如 postgresql-15.8.tar.gz),解压后编译安装:
    tar -xzf postgresql-15.8.tar.gz
    cd postgresql-15.8
    ./configure --prefix=/usr/local/pgsql
    make -j$(nproc)
    sudo make install
  • 配置环境变量(可选,方便命令使用):
    echo 'export PATH=$PATH:/usr/local/pgsql/bin' >> ~/.bashrc
    source ~/.bashrc

核心配置文件调整

PostgreSQL主要配置通过两个文件控制:postgresql.conf(服务器行为)和 pg_hba.conf(客户端认证)。

配置文件位置

  • 默认路径:
    • postgresql.conf/usr/local/pgsql/data/postgresql.conf
    • pg_hba.conf/usr/local/pgsql/data/pg_hba.conf
  • 数据目录初始化:
    sudo -u postgres initdb -D /usr/local/pgsql/data
    sudo systemctl start postgresql

postgresql.conf 关键参数说明
| 参数名 | 作用 | 常见配置 | 说明 |
|——–|——|———-|——|
| shared_buffers | 共享缓冲区大小(内存) | shared_buffers = 256MB | 推荐设置为物理内存的1/4~1/3 |
| work_mem | 单个查询工作内存 | work_mem = 8MB | 根据查询复杂度调整,复杂查询可增大 |
| effective_cache_size | 有效缓存大小 | effective_cache_size = 80% | 建议为系统物理内存的80% |
| max_connections | 最大连接数 | max_connections = 100 | 根据并发需求调整,默认100 |
| wal_level | WAL日志详细程度 | wal_level = logical | logical 支持逻辑复制,full 提高恢复安全性 |
| archive_mode | WAL归档模式 | archive_mode = on | 开启后自动归档日志,避免数据丢失 |

pg_hba.conf 认证规则
该文件定义客户端连接认证方式,格式为 host/deny + 数据库 + 用户 + 认证方法

  • 示例配置(允许本地用户md5认证):
    # IPv4 local connections:
    host    all             all             127.0.0.1/32            md5
    # IPv6 local connections:
    host    all             all             ::1/128                 md5
    # Allow remote connections from specific IP (e.g., 192.168.1.0/24)
    host    all             all             192.168.1.0/24         md5
  • 认证方法推荐:md5(密码加密传输)或 scram-sha-256(更安全的密码哈希算法)。

数据库连接与网络设置

监听地址与端口

  • listen_addresses:指定监听地址,默认 localhost(仅允许本地连接)。
    • 修改为 允许所有地址:
      sudo sed -i 's/^listen_addresses = \'localhost\'/listen_addresses = \'*\'/' /usr/local/pgsql/data/postgresql.conf
  • port:默认 5432,修改后需通知客户端。

数据库初始化与角色创建

  • 创建数据库(示例):
    createdb mydb
  • 创建用户并授权(示例):
    createuser --interactive
    # 输入用户名(如 app_user)、密码、是否创建数据库(N)、是否超级用户(N)

性能优化配置

内存与缓存优化

  • 根据系统内存调整 shared_bufferseffective_cache_size
    # 示例:16GB内存
    shared_buffers = 6GB
    effective_cache_size = 12GB
  • 启用预取(enable_seqscan)和并行查询(max_parallel_workers_per_gather):
    enable_seqscan = on
    max_parallel_workers_per_gather = 4

日志与归档配置

  • 调整日志记录级别(log_min_duration_statement):
    log_min_duration_statement = 5000  # 记录5秒以上查询
  • 启用WAL归档(确保 archive_mode = onarchive_command 正确):
    archive_command = 'cp %p /var/lib/postgresql/archives/%f'

安全加固与权限管理

身份验证强化

  • md5 替换为 scram-sha-256(推荐):
    sudo sed -i 's/md5/scram-sha-256/' /usr/local/pgsql/data/pg_hba.conf
  • 设置密码策略:
    alter user app_user with password 'newpassword' password_lifecycle_options (min_password_length = 12, password_reuse_time = 180);

最小权限原则

  • 为应用创建专用角色(非超级用户):
    create role app_user login password 'securepwd';
    create database myappdb owner app_user;
    grant connect on database myappdb to app_user;
    grant usage on schema public to app_user;

故障排查与维护

常见问题

  • 连接失败(”could not connect to server”):检查 pg_hba.conf 认证规则和 listen_addresses 配置。
  • 性能瓶颈(查询慢):查看 pg_stat_statements 统计信息,调整 work_mem 或增加 shared_buffers
  • 内存溢出(OOM):通过 pg_stat_activity 查看进程占用,优化大查询或增加物理内存。

相关问答FAQs

如何允许远程PostgreSQL连接?
答:

  1. 修改 postgresql.conf 中的 listen_addresses 参数为 (允许所有地址),或指定具体IP。
  2. 修改 pg_hba.conf,添加允许远程IP的认证规则(如 host all all 192.168.1.0/24 md5)。
  3. 重启PostgreSQL服务:sudo systemctl restart postgresql

如何优化PostgreSQL的内存使用?
答:

  1. 调整共享缓冲区:根据系统内存设置 shared_buffers(如16GB内存可设为6GB)。
  2. 启用缓存优化:设置 effective_cache_size 为物理内存的80%以上,提升缓存命中率。
  3. 限制连接数:根据并发需求调整 max_connections,避免资源过度占用。
  4. 监控内存使用:使用 pg_stat_activitypg_stat_statements 视图,定位高内存消耗的查询。

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/199397.html

(0)
上一篇 2025年12月27日 18:35
下一篇 2025年12月27日 18:53

相关推荐

  • 宽带连接的命令是什么,宽带连接命令

    在Windows 11及Windows 10系统中,最通用且高效的宽带连接命令是“rasdial 连接名称 用户名 密码”,若需断开连接则使用“rasdial 连接名称 /disconnect”,该命令通过调用RAS API直接管理拨号连接,无需打开图形界面即可完成网络鉴权与建立,命令核心逻辑与基础语法解析命令……

    2026年5月15日
    0313
  • 如何注册proc域名?解析设置及功能使用中的常见疑问有哪些?

    关于proc文件系统的深度解析什么是proc文件系统(proc域名的核心概念)在Linux操作系统中,proc文件系统(通常简称为“proc域”或“proc空间”)是一个关键的虚拟文件系统,它由Linux内核提供,用于动态访问内核数据结构,这个“proc域名”并非传统意义上的互联网域名,而是指Linux内核通过……

    2026年1月2日
    02220
    • 服务器间歇性无响应是什么原因?如何排查解决?

      根源分析、排查逻辑与解决方案服务器间歇性无响应是IT运维中常见的复杂问题,指服务器在特定场景下(如高并发时段、特定操作触发时)出现短暂无响应、延迟或服务中断,而非持续性的宕机,这类问题对业务连续性、用户体验和系统稳定性构成直接威胁,需结合多维度因素深入排查与解决,常见原因分析:从硬件到软件的多维溯源服务器间歇性……

      2026年1月10日
      020
  • 宽带一级商是什么?宽带一级商代理怎么找

    2026 年宽带一级商的核心价值在于掌握运营商底层资源与价格体系,企业用户通过一级商采购可节省 30%-50% 成本并享受优先故障响应,而个人用户需警惕“二级代理”冒充一级商的风险,2026 年宽带一级商生态格局与核心定义在 2026 年,随着“东数西算”工程全面落地及千兆光网 2.0 的普及,宽带一级商(Ti……

    2026年5月10日
    0545
  • pptp服务器

    PPTP服务器:技术原理、安全风险与应用实践PPTP(Point-to-Point Tunneling Protocol,点对点隧道协议)作为早期虚拟专用网络(VPN)技术的重要代表,是Microsoft于1996年开发的第二层隧道协议,核心目标是实现远程用户通过公共IP网络安全访问私有网络资源,尽管随着更先进……

    2026年1月20日
    04040

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注