CentOS 7 源码编译安装 PostgreSQL 11.2

举报
DrugAI 发表于 2021/07/15 04:05:37 2021/07/15
5.5k+ 0 0
【摘要】 环境 系统版本 Centos7.6 工具:xshell6 PostgreSql: postgresql-11.2.tar.gz   安装部署 安装前准备 官网下载PostgreSQL 11.2源码地址:https://www.postgresql.org/ftp/source/v11.2/ 选择postgresql-11.2.tar.gz...

环境

系统版本 Centos7.6

工具:xshell6

PostgreSql: postgresql-11.2.tar.gz

安装部署


安装前准备

官网下载PostgreSQL 11.2源码地址:https://www.postgresql.org/ftp/source/v11.2/

选择postgresql-11.2.tar.gz

编译安装


      tar -zxvf postgresql-11.2.tar.gz
      cd postgresql-11.2
      ./configure --prefix=/usr/local/postgresql --without-readline
      make && make install
  
 

 进入安装后的目录,查看目录结构

cd /usr/local/postgresql/
 

 安装服务器端包

yum -y install postgresql11
 

创建目录 data、log


      mkdir /usr/local/postgresql/data
      mkdir /usr/local/postgresql/log
      chmod -R 775 /usr/local/postgresql/data
  
 

配置环境变量

vim /etc/profile


      PGHOME=/usr/local/postgresql
      export PGHOME
      PGDATA=/usr/local/postgresql/data
      export PGDATA
      PATH=$PATH:$HOME/.local/bin:$HOME/bin:$PGHOME/bin
      export PATH
  
 

使配置文件生效

source /etc/profile

创建用户

useradd postgres
 

将pg的数据目录全部赋给postgres用户,执行以下命令:

chown -R postgres:postgres /usr/local/postgresql/
 

初始化数据库

切换到postgres用户,执行如下命令:


      su - postgres
      /usr/local/postgresql/bin/initdb -D /usr/local/postgresql/data/
  
 

 

启动数据库

/usr/local/postgresql/bin/pg_ctl -D /usr/local/postgresql/data/ -l logfile start
 

查看数据库版本

psql -V

 

psql (PostgreSQL) 11.2
 

连接数据库

psql -U postgres -d postgres
 

配置文件

目录/usr/local/postgresql/data/下,pg_hba.conf和postgresql.conf两个文件。

vi /usr/local/postgresql/data/pg_hba.conf
 

vi /usr/local/postgresql/data/postgresql.conf
 

 修改listen_addresses = ‘*’;

登录数据库

psql -U postgres -d postgres
 

设置防火墙规则


      firewall-cmd --zone=public --add-port=8432/tcp --permanent
      firewall-cmd --reload
  
 

初始化 database

/usr/pgsql-11/bin/postgresql-11-setup initdb
 

重启数据库

systemctl restart postgresql-11
 

设置开机启动


      自动启动
      systemctl enable postgresql-11.service
      启动
      systemctl start postgresql-11.service
      停止某服务
      systemctl stop postgresql-11.service
      不自动启动
      systemctl disable postgresql-11.service
      检查服务状态(服务详细信息)
      systemctl status postgresql-11.service
      检查服务状态(仅显示是否Active)
      systemctl is-active postgresql-11.service
      显示所有已启动的服务
      systemctl list-units --type=service
  
 

参考

https://yq.aliyun.com/articles/715609

https://blog.csdn.net/llwy1428/article/details/95444151

文章来源: drugai.blog.csdn.net,作者:DrugAI,版权归原作者所有,如需转载,请联系作者。

原文链接:drugai.blog.csdn.net/article/details/102971632

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。