加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

PostgreSQL编译安装

发布时间:2020-12-13 18:09:11 所属栏目:百科 来源:网络整理
导读:PostgreSQL编译安装 一、PostgreSQL简介 PostgreSQL是目前功能最强大的开源数据库,支持丰富的数据类型和自定义类型,且它提供了丰富的接口,可以轻易的扩展它的功能。 与其他数据库相比,PostgreSQL有以下优势: ●PostgreSQL是目前功能最强大的开源数据库




PostgreSQL编译安装



一、PostgreSQL简介


PostgreSQL是目前功能最强大的开源数据库,支持丰富的数据类型和自定义类型,且它提供了丰富的接口,可以轻易的扩展它的功能。

与其他数据库相比,PostgreSQL有以下优势:

●PostgreSQL是目前功能最强大的开源数据库

●稳定可靠:PostgreSQL是唯一能做到数据零丢失的开源数据库

●支持广泛:PostgreSQL支持大量的主流开发语言,包括C、C++、Perl、Python、Java、PHP等

●社区活跃:基本上每三个月会推出一个新的补丁版本,这意味着已知BUG很快会被修复


PostgreSQL数据库与MySQL数据库对比,有以下优势:

●功能强大:支持所有主流的多表连接查询的方式(如:Nest loop、hash join等);有丰富的内置函数,并支持大量字段类型

●支持同步复制:从PostgreSQL9.1开始,支持同步复制功能,,通过master和slave之间的复制可以实现零数据丢失的高可用方案





二、PostgreSQL安装与配置


本次安装采用源码编译安装,仅作为学习工作使用,默认选项即可,读者可以自行选择安装的选项。


1、安装前的准备

●源码包

postgresql-9.6.1.tar.gz,可通过如下命令下载

wgethttps://ftp.postgresql.org/pub/source/v9.6.1/postgresql-9.6.1.tar.gz

●创建postgres用户

PostgreSQL不能以root身份运行,而且其默认运行用户为postgres

[root@a~]#useraddpostgres
[root@a~]#passwdpostgres

●创建安装目录及数据目录

[root@a~]#mkdir-p/usr/local/pgsql/data



2、开始安装配置

●解压并进行安装

解压源码包,并进入解压目录,执行配置安装命令

[root@a~]#tar-xzfpostgresql-9.6.1.tar.gz
[root@a~]#cdpostgresql-9.6.1
[root@apostgresql-9.6.1]#./configure--prefix=/usr/local/pgsql
[root@apostgresql-9.6.1]#make&&makeinstall

如果没什么error的话,我们就可以进行配置


●相关配置

1)添加环境变量

方便起见,我们在/etc/init.d/目录下新建一个名为pgsql.sh的文件,内容如下,并使该文件立即生效

[root@a~]#more/etc/profile.d/pgsql.sh
exportPATH=$PATH:/usr/local/pgsql/bin
[root@a~]#source/etc/profile.d/pgsql.sh

2)将数据目录及安装目录属主、属组改为postgres

[root@a~]#chown?Rpostgres.postgres/usr/local/pgsql

3)初始化数据库

切换为postgres用户,初始化postgresql数据库,此时会在/usr/local/pgsql/data目录下生成相应的数据库配置文件

[root@a~]#su?postgres
[postgres@a~]$initdb?D/usr/local/pgsql/data
#需要注意的是:这里的/usr/local/pgsql/data目录必须为空
#现在可以执行如下命令启动postgresql数据库服务
[postgres@a~]$pg_ctl?D/usr/local/pgsql/data?llogfilestart

4)修改配置文件

现在我们的数据库只能用于本地用户访问,我们需要修改配置文件来使远程机器也可以访问

[postgres@a~]$cd/usr/local/pgsql/data
[postgres@adata]$vipostgresql.conf
#在#listen_addresses='localhost'处添加监听地址为所有(*),即添加listen_addresses='*'

[postgres@adata]$vipg_hba.conf
#将host的IP地址改为所需要访问的IP网段地址,认证方式改为md

修改后截图如下:

wKiom1huFO6yu5o9AABorp_60Z8223.png


wKiom1huF5SA356nAADFcYs1WUs075.png


5)复制服务启动脚本到/etc/init.d/目录下,添加pgsqld服务

切换为root用户,复制解压目录下contrib/startscripts/linux到/etc/init.d/pgsqld,并进行简单修改,赋予执行权限

[root@apostgresql-9.6.1]#cpcontrib/start?scripts/linux/etc/init.d/pgsqld
[root@apostgresql-9.6.1]#vi/etc/init.d/pgsqld
##查看该选项是否与自己设定的数据目录相对应,若不对应,则修改
##该选项默认目录为
PGDATA="/usr/local/pgsql/data"

#添加执行权限,并添加服务到开机启动
#chmod+x/etc/init.d/pgsqld
重新启动服务
#servicepgsqldrestart
#添加到开机启动
#chkconfig--addpgsqld
#chkconfigpgsqldon



到此,PostgreSQL安装配置完成,我们可以切换到postgres用户,执行psql命令进入postgres交互模式,进行相关数据库操作。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读