在CentOS上以源码编译的方式安装PostgreSQL

下载目录:PostgreSQL: File Browser,我使用的PostgreSQLv17.5 。Linux系统:CentOS Linux release 7.9.2009 (Core)

  1. 安装依赖包和工具链(必须且重要!)

    shell 复制代码
    yum groupinstall "Development Tools" -y
    yum install -y readline-devel zlib-devel libicu-devel openssl-devel pam-devel libxml2-devel libxslt-devel systemd-devel
  2. 上传安装包至服务器后解压此包

    shell 复制代码
    # 先在Windows的CMD 或 macOS的terminal下执行scp命令
    scp postgresql-17.5.tar.gz root@192.168.31.199:/root
    # Linux执行以下命令
    tar -xvf postgresql-17.5.tar.gz # 解压
  3. 编译并安装

    shell 复制代码
    cd postgresql-17.5
    ./configure \
      --prefix=/opt/pgsql \ # 申明安装在哪里
      --with-openssl \
      --with-libxml \
      --with-icu \
      --with-systemd
    make -j $(nproc) && sudo make install # $(nproc)使用CPU多核编译
  4. 增加postgres组和postgres用户

    shell 复制代码
    groupadd postgres && useradd -g postgres postgres
    passwd postgres # 定义postgres用户密码
  5. 创建目录并授权:创建存储数据的文件夹(我创建在**/opt/pgsql/data**)

    shell 复制代码
    mkdir -p /opt/pgsql/data && chown -R postgres:postgres /opt/pgsql
  6. 初始化数据库

    shell 复制代码
    # 切换至postgres用户
    su -- postgres
    # 进入pgsql的bin目录
    cd /opt/pgsql/bin
    # 初始化数据库
    ./initdb -D /opt/pgsql/data --locale=en_US.UTF-8 --encoding=UTF8
  7. 修改配置文件

    • /opt/pgsql/data/postgresql.conf 新增内容如下

      tex 复制代码
      listen_addresses = '*' # 允许所有IP连接,默认是仅允许本地连接,此项必须改
      port = 5432       # 默认端口,此项可忽略不增
    • /opt/pgsql/data/ pg_hba.conf 修改内容如下

      tex 复制代码
      # IPv4 local connections:
      # host    all             all             127.0.0.1/32            trust # 注释掉原来的
      host    all             all             0.0.0.0/0            scram-sha-256 # 新增此行,允许所有IP通过密码连接
      # IPv6 local connections:
      # host    all             all             ::1/128                 trust # 注释掉原来的
      host    all             all             ::1/128                 scram-sha-256 # 新增此行,允许所有IP通过密码连接
  8. 新建/etc/systemd/system/postgresql.service服务文件,需用到root用户,请切换到root用户

    shell 复制代码
    su - root
    touch /etc/systemd/system/postgresql.service

    文件内容如下

    tex 复制代码
    [Unit]
    Description=PostgreSQL database server
    After=network.target
    
    [Service]
    User=postgres
    Group=postgres
    Type=notify
    User=postgres
    ExecStart=/opt/pgsql/bin/postgres -D /opt/pgsql/data
    ExecReload=/bin/kill -HUP $MAINPID
    
    [Install]
    WantedBy=multi-user.target

    修改完成后执行

    shell 复制代码
    chown postgres:postgres /etc/systemd/system/postgresql.service
    systemctl daemon-reload
    systemctl start postgresql
    systemctl enable postgresql # 不希望pgsql每次开机自启,请勿执行此行命令
  9. 修改postgresql数据超级用户------postgres的密码,并将postgres用户添加到路径,请先将Linux切换到postgres用户

    shell 复制代码
    su - postgres
    . /opt/pgsql/bin/psql -c "alter user postgres with password '自定义密码';"
    # 添加路径
    echo 'export PATH=$PATH:/opt/pgsql/bin' >> ~/.bash_profile
    echo 'export PGDATA=/opt/pgsql/data' >> ~/.bash_profile
    source ~/.bash_profile
  10. 开启防火墙端口(请先将Linux切换到root用户)

    shell 复制代码
    su - root
    firewall-cmd --add-port=5432/tcp --permanent # 开放端口且永久生效
    firewall-cmd --reload # 重载配置

若远程连接不上,那么请重启服务,用postgres用户或root都行systemctl restart postgresql

相关推荐
黑翼杰克斯25 分钟前
如何裁剪u-boot,保留其必要功能,使体积尽可能小
linux·1024程序员节
cellurw3 小时前
Day69 SQLite3动态库移植 + BMP图像解析显示 + 进度条控件设计与动态文本管理
linux
nono牛3 小时前
Linux基础指令大全(快速上手)
linux·服务器·windows·智能手机
<但凡.3 小时前
Linux修炼:库制作与原理(一)
linux·运维·服务器
Maple_land5 小时前
编译器的“隐形约定”与本地变量:解锁Linux变量体系的关键密码
linux·运维·服务器·c++·centos
深思慎考6 小时前
微服务即时通讯系统(服务端)——Speech 语音模块开发(2)
linux·c++·微服务·云原生·架构·语音识别·聊天室项目
小蜜蜂爱编程6 小时前
Ubuntu无法开机Failed to activate swap /swapfile
linux·运维·ubuntu
阿巴~阿巴~6 小时前
CPU 指令集、权限与用户态内核态机制
linux·运维·服务器·指令集·权限·用户态内核态
小涵7 小时前
企业SRE/DevOps向的精通Linux课程培训课程
linux·运维·devops·1024程序员节
航Hang*7 小时前
第1章:初识Linux系统——第8节:查看/修改权限控制和ACL
linux·运维·服务器·笔记·操作系统