• CentOS7 源码安装 PostgreSQL 12


     PostgreSQL 12 源码安装

    1 下载

    官网提供了源码和预安装的版本。 源码需要编译安装,解决依赖包等问题,而预安装的版本要简单很多。只需下载解压, 初始化数据库即可。

    本例以源码安装为例:请至官网 下载源码。

    本例中安装的是PG12. 在 https://www.postgresql.org/ftp/source/v12.0/ 中选择postgresql-12.0.tar.bz2

    请根据需要先择自己需要的版本。

    预安装版本,请至官网下载。

    2 准备环境

    此步骤以root用户执行。 将postgresql的安装包放到/opt 路径。

    # 创建组和用户
    groupadd postgre
    useradd -g postgre -G postgre -d /home/postgresql postgre
    passwd postgre
    # 安装依赖包
    yum install -y bzip2 readline-devel zlib-devel
    # 将安装包放在/opt 路径中并解压
    cd /opt/
    bunzip2 postgresql-12.0.tar.bz2
    tar -xvf ./postgresql-12.0.tar
    

    3 编译安装

    此步骤以postgre 用户操作:

    cd /opt/postgresql-12.0
    ./configure --prefix=/home/postgresql/dbhome
    make && make install
    

    安装后,可执行文件,库文件等都会安装在/home/postgresql/dbhome 中。

    [postgre@boss20 dbhome]$ ls /home/postgresql/dbhome
    bin  include  lib  share
    

    4 设置环境变量

    将以下两行添加至postgre 用户的环境变量文件 .bash_profile 并生效。

    export LD_LBRARY_PATH=$HOME/dbhome/lib:$LD_LIBRARY_PATH
    export PATH=$HOME/dbhome/bin:$PATH
    

    环境变量文件生效方法:

    . .bash_profile
    或者
    source .bash_profile
    

    5 初始化数据库

    此步骤以postgre用户执行。

    • 创建数据存放路径

      mkdir $HOME/data
      

      postgresql 数据库的配置文件,数据文件等都会存放在这个路径下。

    • 初始化数据库

      initdb --locale=C -E UNICODE -D $HOME/data/
      

      示例如下:

        The files belonging to this database system will be owned by user "postgre".
      This user must also own the server process.
      
      The database cluster will be initialized with locale "C".
      The default text search configuration will be set to "english".
      
      Data page checksums are disabled.
      
      fixing permissions on existing directory /home/postgresql/data ... ok
      creating subdirectories ... ok
      selecting dynamic shared memory implementation ... posix
      selecting default max_connections ... 100
      selecting default shared_buffers ... 128MB
      selecting default time zone ... America/New_York
      creating configuration files ... ok
      running bootstrap script ... ok
      performing post-bootstrap initialization ... ok
      syncing data to disk ... ok
      
      initdb: warning: enabling "trust" authentication for local connections
      You can change this by editing pg_hba.conf or using the option -A, or
      --auth-local and --auth-host, the next time you run initdb.
      
      Success. You can now start the database server using:
      
          pg_ctl -D /home/postgresql/data/ -l logfile start
      

    初始化完成后,在最后一行会提示我们启动数据库的方法. 此时我们来查看一下 $HOME/data路径 的内容:

    [postgre@boss20 data]$ ls
    base    pg_commit_ts  pg_hba.conf    pg_logical    pg_notify    pg_serial     pg_stat      pg_subtrans  pg_twophase  pg_wal   postgresql.auto.conf
    global  pg_dynshmem   pg_ident.conf  pg_multixact  pg_replslot  pg_snapshots  pg_stat_tmp  pg_tblspc    PG_VERSION   pg_xact  postgresql.conf
    

    这些路径分别有什么用途,以后再了解。

    6 配置参数文件

    我们主要是配置postgresql.conf 和 pg_hba.conf 这两个。

    • postgresql.conf 针对实例的配置
    • pg_hba.conf 针对数据库访问的控制

    6.1 postgresql.conf

    找到 #port#listener_address 这两个参数。这两个参数是相邻的:

    #listen_addresses = 'localhost'               # what IP address(es) to listen on;
                                            # comma-separated list of addresses;
                                            # defaults to 'localhost'; use '*' for all
                                            # (change requires restart)
    #port = 5432                             # (change requires restart)
    max_connections = 100                  # (change requires restart)
    

    将两行行首的 # 删除,将 localhost 改为当前服务器的IP 。 默认的监听端口是5432,可以自行指定另外一个端口号,*不建议使用默认端口号* 。 顺便再修改一下 max_connections 吧,最大的连接数, 100有点少,特别是业务系统。 可以调整成1000,或者更高。

    6.2 pg_hba.conf

    将以下一行添加至文末。

    host    all             all             10.10.100.0/24          trust
    

    其意义是允许 10.10.100网段的IP 连接此服务器上的PG. 如果想允许所有IP 都可以连接此服务器 则可以配置成如下:

    host    all             all             0.0.0.0/0          trust
    

    7 数据库启动与关闭

     

    7.1 手动

    我们手动启动与关闭数据库是执行pg_ctl命令。在执行时,需要指定 数据路径,格式如下:

    pg_ctl -D <数据存放路径> [ stop | start ]
    

    示例如下:

    [postgre@boss20 data]$ pg_ctl -D /home/postgresql/data/ -l logfile start
    waiting for server to start.... done
    server started
    [postgre@boss20 data]$ pg_ctl -D $HOME/data stop
    waiting for server to shut down.... done
    server stopped
    

    7.2 开机自动启动

    此步骤需要root用户操作。 postgresql 的安装包中提供了数据库启动与关闭的脚本,可以帮助我们简化操作,也可以 用作开机启动的脚本和service/systemctl 控制服务的脚本。 脚本位于:

    <path>/postgresql-12.0/contrib/start-scripts/
    本示例中是:
    /opt/postgresql-12.0/contrib/start-scripts/
    

    设置开机启动:

    cp /opt/postgresql-12.0/contrib/start-scripts/linux /etc/init.d/postgresql
    chkconfig --add postgresql
    chmod 755 /etc/init.d/postgresql
    

    调整配置,主要是脚本中三个变量的值:

    prefix="/home/postgresql/dbhome"
    PGDATA="/home/postgresql/data"
    PGUSER=postgre
    
    • prefix 是软件的安装路径
    • PGDATA 是数据存放路径
    • PGUSER 是启动postgresql服务的用户

    以后可以开机启动和通过service 命令控制启动和关闭了:

    [root@boss20 init.d]# service postgresql start
    Starting PostgreSQL: ok
    [root@boss20 init.d]# service postgresql stop
    Stopping PostgreSQL: ok
    

    Author: halberd.lee

    Created: 2019-10-18 Fri 18:05

    Validate

  • 相关阅读:
    云中树莓派(5):利用 AWS IoT Greengrass 进行 IoT 边缘计算
    乐观锁 与 悲观锁 来解决数据库并发问题
    Python二维数组构造
    一次问题追查----短字符串签名算法引发的bug
    C++ assert 断言使用
    并查集(Union-Find)算法
    linux shell grep/awk/sed 匹配tab
    C++ 变量默认初始值不确定(代码测试)
    linux 查看机器内存方法 (free命令)
    html table奇偶行颜色设置 (CSS选择器)
  • 原文地址:https://www.cnblogs.com/halberd-lee/p/11699694.html
Copyright © 2020-2023  润新知