yum安装配置postgresql

本文详细介绍在CentOS7.7系统中如何从YUM源安装PostgreSQL10,包括初始化数据库、配置网络访问权限、设置防火墙、调整监听地址及访问控制,以及如何创建用户和数据库进行权限管理。

环境说明

OS版本:CentOS Linux release 7.7.1908

1.根据yum源安装postgresql

查看:https://www.postgresql.org/download/linux/redhat/

选择合适的yum源头,这里我们选择安装postgresql10。

sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
sudo yum install -y postgresql10-server

2.初始化数据库并启动数据库

sudo /usr/pgsql-10/bin/postgresql-10-setup initdb
sudo systemctl enable postgresql-10
sudo systemctl start postgresql-10

3.配置数据库服务网络访问权限

打开防火墙默认端口

sudo firewall-cmd --permanent --zone=public --add-port=5432/tcp
sudo service firewalld restart

配置监听和访问控制

echo "listen_addresses = '*'"  >> /var/lib/pgsql/10/data/postgresql.conf
echo "host all all 192.168.0.0/16 md5"  >> /var/lib/pgsql/10/data/pg_hba.conf

重启数据库服务

sudo systemctl restart postgresql-10

4.数据库管理配置

安装完成之后会自动创建一个postgres用户,切换到该用户可以直接进行一系列管理员操作。

su - postgres

进入psql命令行,重新设置postgres管理员密码

psql -U postgres
postgres=# ALTER USER postgres WITH PASSWORD '******';

创建普通用户和数据库,并退出

postgres=# CREATE USER devuser WITH PASSWORD '******';
CREATE ROLE
postgres=# CREATE DATABASE devdb OWNER devuser ENCODING = 'UTF8';
CREATE DATABASE
postgres=# \q

使用普通用户登录,并进行SQL测试

psql -U devuser --password devdb
devdb=> create table test(sid int,mm varchar(12));
devdb=> insert into test values(1,'aaa');
devdb=> select * from test;
devdb=> \q
### 如何在 CentOS 7 上使用 yum 安装 PostgreSQL #### 准备工作 确保系统已经配置好基础的 `yum` 源。如果缺少 Base 源,可以通过阿里云镜像获取并保存到 `/etc/yum.repos.d/` 目录下[^2]。 ```bash curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo ``` #### 添加 PostgreSQL YUM 源 为了获得最新的版本和支持,建议先添加官方的 PostgreSQLYUM 源: ```bash sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm ``` 这一步骤会安装来自 PostgreSQL Global Development Group (PGDG) 提供的仓库文件,从而允许访问更多更新版本的软件包[^1]。 #### 安装 PostgreSQL 及其扩展组件 接着执行命令来安装服务器端程序以及一些有用的工具和库: ```bash sudo yum install -y postgresql12-server postgresql-contrib ``` 这里选择了特定版本 (`postgresql12`) 来进行安装;当然也可以选择其他可用版本,具体取决于需求和个人偏好[^3]。 #### 初始化数据库集群 完成上述操作之后,需要初始化一个新的数据库实例: ```bash postgresql-setup initdb ``` 此过程会在默认位置建立必要的目录结构,并设置初始参数以便后续正常使用。 #### 设置开机自启和服务启动 为了让 PostgreSQL 随着系统的启动而自动运行,需将其加入到系统的服务列表中去: ```bash sudo systemctl enable postgresql sudo systemctl start postgresql ``` 最后确认服务已成功开启: ```bash sudo systemctl status postgresql ``` 以上就是完整的基于 `yum` 工具链,在 CentOS 7 平台上部署 PostgreSQL 数据库管理系统的过程概述[^4]。 #### 访问新安装PostgreSQL 实例 通常情况下,默认创建了一个名为 `postgres` 的操作系统账户用于管理 PostgreSQL。要进入交互式的 SQL shell (即 psql),可按如下方式切换身份并连接至本地主机上的默认实例: ```bash su - postgres psql -U postgres ``` 这样就可以开始探索或构建自己的应用程序逻辑了!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值