Linux环境下二进制安装PostgreSql

本文档详细介绍了如何在非root权限下安装PostgreSQL数据库,包括下载二进制包、解压、创建安装目录、初始化安装、启动与停止数据库、用户创建与验证,以及远程连接配置。重点讲解了配置文件postgres.conf和pg_hba.conf的修改,以允许远程连接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下载资源

考虑到主机非root用户,权限有限,采用简单的二进制安装包安装

二进制安装包下载地址

在这里插入图片描述


安装

常规的解压:

tar -zxvf postgresql-10.20-2-linux-x64-binaries.tar.gz

(不需要做的备注)也有人单独注册用户组,使用root分配账户软件权限,这里不用这种方式,仅列出来:

groupadd postgres
useradd -g postgres postgres
passwd postgres


构建安装目录

在解压的pgsql目录下 , 新建两个文件夹:datalogs,用于初始化指定:

mkdir data

mkdir logs

初始化安装

在解压的pgsql目录下进入bin目录:

cd bin

./initdb -E utf8 -D /realtime/realtime/tools/postgresql/pgsql/data/

(不需要做的备注)./configure 是检查当前环境能否安装 PG,yum形式的话缺少环境可以用完善:

yum install -y make gcc-c++ readline-devel zlib-devel

初始化后会出现下面的内容,准确的说后面是-l logFile,这里我补充安装目录文件:

Success. You can now start the database server using:

/realtime/realtime/tools/postgresql/pgsql/bin/pg_ctl -D /realtime/realtime/tools/postgresql/pgsql/data/ -l /realtime/realtime/tools/postgresql/pgsql/logs/pgsql_server.log start &

使用该命令代日志后台启动:

在这里插入图片描述


查看日志:

在这里插入图片描述


postgres的登陆和验证

登陆出现数据库不存在

[appuser@host-172-18-194-90 bin]$ ./psql
psql.bin: FATAL: database “appuser” does not exist

其中appuser是当前登陆服务器用户名

在这里插入图片描述


采用临时的库登陆暂时,借此创建用户等操作:

psql -d template1

create user postgres with password 'postgres';

在这里插入图片描述


停止postgres

/realtime/realtime/tools/postgresql/pgsql/bin/pg_ctl stop -D /realtime/realtime/tools/postgresql/pgsql/data/  -m fast

在这里插入图片描述


验证和查看

pgsql下使用fuser *或者

ps -ef | grep pgsql

netstat -nap | grep 查出的port

远程连接配置

这里说明有两个配置文件要配置: postgres.confpg_hba.conf:

postgres.conf

修改 postgres.conf 配置,PostgreSQL安装完成后,默认只接受来自本机localhost的连接请求。远程连不上,telnet ip port 不通。改为:

# - Connection Settings -
listen_addresses = '*'          # what IP address(es) to listen on;

pg_hba.conf

跟windows下的配置一样:

# TYPE  DATABASE        USER            ADDRESS                 (认证)METHOD
# "local" is for Unix domain socket connections only
local   all             all                                     trust
# IPv4 local connections:
host    all             all             127.0.0.1/32            trust
# IPv6 local connections:
host    all             all             ::1/128                 trust

启动后的进程情况应该是:

在这里插入图片描述


数据库工具连接

使用navicat专业版12(最新版本,否则会不显示表):

在这里插入图片描述

postgresql-10.10-2-linux-x64-binaries.tar.gz 安装包 PostgreSQL经历了长时间的演变。该项目最初开始于在加利福尼亚大学伯克利分校的Ingres计划。这个计划的领导者迈克尔·斯通布雷克在1982年离开加利福尼亚大学伯克利分校去推进Ingres的商业化,但最后还是返回了学术界。在1985年返回伯克利之后,斯通布雷克开始了post-Ingres计划,致力于解决在1980年代早期所出现一些数据库系统存在的问题。Postgres和Ingres的代码库开始(并保持)完全分离。 新项目Postgres的目的是通过增加最少的功能来完全支持所需要的类型。这些功能包括类型定义和完整描述数据关系的能力。完整描述数据关系的能力之前虽广为使用但却需要由用户来维护。Postgres的数据库能够"理解"关系,并可以使用一定的规则以自然方式在相关的表中检索信息。 从1986年开始,该项目组发表了一些描述这一系统基本原理的论文,并在1988年实现并运行了一个Demo版本。项目组在1989年六月向少数用户发行了版本1.0,随后在1990年6月发行了带有全新规则系统的版本2.0。1991年的版本3.0再次重写了规则系统,并增加了对多个存储管理器的支持与改进的查询引擎。Postgres在1993年开始拥有大量用户,这些用户提供了大量的功能与优化建议。但是在发行了作为细节修正的版本4.0之后,Postgres计划就终止了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

长臂人猿

客官们众筹请博主喝杯奶茶吧

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值