Linux 上安装 PostgreSQL

打印 上一主题 下一主题

主题 835|帖子 835|积分 2505

文章目录



  • 前言
  • 一、安装PostgreSQL
  • 二、修改数据库默认数据存储目录


    • 1.自定义数据存放目录
    • 2.修改自定义服务
    • 3.初始化数据库
    • 4.运行数据库

  • 三、设置数据库信息


    • 四、权限

  • 异常处理

前言

提示:本次博客是centos7.9安装PostgreSQL12版本
名称
版本
Centos
7.9
postgresql
12
postgresql端口
5432
postgresql存储路径
/pgsql/12/data/
一、安装PostgreSQL

打开 PostgreSQL 官网
https://www.postgresql.org/download/
具体操作如下图所示:
   Packages and Installers(软件包和安装程序)
Select your operating system family:(选择您的操作体系系列)
Select your Linux distribution:(选择您的 Linux 发行版)
  

选择完以上操作体系系列和操作体系发行版后会自动出现PostgreSQL Yum Repository如下图所示:

   Select version选择要安装的数据库版本)
Select platform:(选择要安装的数据库操作体系)
Select architecture:(选择操作体系架构)
Copy, paste and run the relevant parts of the setup script:(复制、粘贴并运行设置脚本的相干部分)具体阐明如下
  1. #安装PostgreSQL的yum仓库
  2. sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
  3. #安装PostgreSQL 12版本
  4. sudo yum install -y postgresql12-server
  5. #初始化数据库(若要自定义数据库存储目录请先不要初始化数据库,参考后边章节后在初始化数据库)
  6. sudo /usr/pgsql-12/bin/postgresql-12-setup initdb
  7. #设置数据开机自启
  8. sudo systemctl enable postgresql-12
  9. #启动数据库
  10. sudo systemctl start postgresql-12
复制代码
数据库安装后的数据存储目录默认在/var/lib/pgsql/12/data,12为数据库的主版本号
二、修改数据库默认数据存储目录

#默认安装路径Environment=PGDATA=/var/lib/pgsql/15/data/
在没有初始化数据库之前,默认的data目录下是空的

1.自定义数据存放目录

  1. mkdir -p /pgsql/12/data/             #创建自定义数据存储目录
  2. chown -R postgres:postgres /pgsql    #修改目录权限
复制代码
2.修改自定义服务

  1. vi /usr/lib/systemd/system/postgresql-12.service
  2. #修改默认环境变量数据存放路径,找到Environment修改为自己定义的数据存放目录
  3. [Service]
  4. Environment=PGDATA=/pgsql/12/data/   #修改完后保存退出
复制代码

  1. #重新加载systemctl
  2. systemctl daemon-reload
复制代码
3.初始化数据库

  1. #初始化数据库
  2. sudo /usr/pgsql-12/bin/postgresql-12-setup initdb
复制代码

可以看出/pgsql/12/data/目录下有许多文件,证明初始化乐成
4.运行数据库

  1. #设置数据开机自启
  2. sudo systemctl enable postgresql-12
  3. #启动数据库
  4. sudo systemctl start postgresql-12
复制代码
三、设置数据库信息

1.修改暗码
  1. #切换到postgres用户
  2. su postgres
  3. #切换SQL模式
  4. psql
  5. #修改密码
  6. alter user postgres with password 'postgres123';
  7. #创建test用户
  8. create user test with password 'test';
  9. #授权
  10. grant all privileges on database mydb to test;
  11. #退出
  12. q
复制代码

2.设置远程访问
  1. #打开防火墙端口
  2. sudo firewall-cmd --add-port=5432/tcp --permanent
  3. #刷新防火墙
  4. sudo firewall-cmd --reload
复制代码
3.修改设置文件
  1. #此处是修改默认存储路径(默认:/var/lib/pgsql/12/data)
  2. vim /pgsql/12/data/postgresql.conf
  3. #取消监听注释,监听地址改为*
  4. listen_addresses = '*'
复制代码
修改设置文件如下图所示:

允许所有IP访问,即修改 pg_hba.conf 文件
  1. #此处是修改默认存储路径(默认:/var/lib/pgsql/12/data)
  2. vim /pgsql/12/data/pg_hba.conf
  3. #新增一行,若连接不上则将 scram-sha-256修改为trust 信任模式
  4. host    all             all             0.0.0.0/0               trust
  5. 重启服务
  6. sudo systemctl restart postgresql-12
复制代码
修改设置文件如下图所示:

用Navicat连接数据库,连接信息如下图所示:

四、权限

  1. -- 创建一个新的只读用户
  2. CREATE ROLE readonly_user WITH LOGIN PASSWORD 'password';
  3. -- 为用户授予数据库的只读权限
  4. GRANT CONNECT ON DATABASE your_database_name TO readonly_user;
  5. GRANT USAGE ON SCHEMA public TO readonly_user;
  6. GRANT SELECT ON ALL TABLES IN SCHEMA public TO readonly_user;
  7. GRANT SELECT ON ALL SEQUENCES IN SCHEMA public TO readonly_user;
复制代码
异常处理

1)Navicat连接报错 错误代码:authentication method 10 not supported 或 致命错误:用户"postgres" Password 认证失败:
处理方案:在 pg_hba.conf 文件中可将新增的 0.0.0.0/0 的模式改为 trust


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

张春

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表