PostgreSQL编译安装

  






一、PostgreSQL简介


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

,

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

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

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

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

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


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

,●功能强大:支持所有主流的多表连接查询的方式(如:嵌套循环,散列连接等),有丰富的内置函数,并支持大量字段类型

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





二,PostgreSQL安装与配置


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


, 1,安装前的准备

,●源码包

,postgresql-9.6.1.tar。广州,可通过如下命令下载

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

,●创建postgres用户

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

[root@a  ~] #, useradd  postgres   [root@a  ~) #, passwd  postgres

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

[root@a  ~] #, mkdir  -p /usr/地方/pgsql/数据



, 2,开始安装配置

,●解压并进行安装

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

[root@a  ~] #, tar  -xzf  postgresql-9.6.1.tar.gz   (root@a  ~) #, cd  postgresql-9.6.1   [root@a  postgresql-9.6.1] #,。/configure ——prefix=/usr/地方/pgsql   [root@a  postgresql-9.6.1] #, make ,,, make 安装

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


,●相关配置

,,1)添加环境变量

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

[root@a  ~] #, more /etc/profile.d/pgsql.sh   export 路径=$路径:/usr/地方/pgsql/bin   [root@a  ~) #, source /etc/profile.d pgsql.sh

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

[root@a  ~] #, chown 列车R  postgres.postgres /usr/地方/pgsql

,,3)初始化数据库

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

[root@a  ~] #, su 列车postgres   (postgres@a  ~),美元initdb 列车D /usr/地方/pgsql/数据   #,需要注意的是:这里的/usr/地方/pgsql/数据目录必须为空   #,现在可以执行如下命令启动postgresql数据库服务   [postgres@a  ~),美元pg_ctl 列车D /usr/地方/pgsql/data 列车l  logfile 开始

,,4)修改配置文件

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

(postgres@a  ~),美元cd /usr/地方/pgsql/数据   (postgres@a 数据),美元vi  postgresql.conf=#,在# listen_addresses “localhost”处添加监听地址为所有(*),即添加listen_addresses =,‘*’      (postgres@a 数据),美元vi  pg_hba.conf   #,,将主机的IP地址改为所需要访问的IP网段地址,认证方式改为md

,,修改后截图如下:

 PostgreSQL编译安装


 PostgreSQL编译安装


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

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

PostgreSQL编译安装