PostgreSQL编译安装
admin
2023-05-28 19:01:22
0




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,可通过如下命令下载

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

  ●创建postgres用户

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

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

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

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



 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/local/pgsql
[root@a postgresql-9.6.1]# make && make install

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


  ●相关配置

   1)添加环境变量

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

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

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

[root@a ~]# chown ‐R postgres.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 ‐l logfile start

   4)修改配置文件

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

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

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

    修改后截图如下:

PostgreSQL编译安装


PostgreSQL编译安装


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

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

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

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



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

相关内容

热门资讯

海关总署发布支持大湾区建设若干... 今天(21日),海关总署举行新闻发布会,就近日出台的《海关支持粤港澳大湾区建设若干措施》进行解读,从...
(经济观察)从三个“更”看中国... 中新社北京5月20日电 题:从三个“更”看中国有力护航民企“轻装上阵”中新社记者  刘亮5月20日是...
油价上调!加满一箱油将多花3元 快科技5月21日消息,今晚24时,国内成品油价格将迎来新一轮调整,为年内第八次上调,也是今年以来第1...
“光+AI”跨界融合促产业链全... (来源:经济日报) 转自:经济日报 5月18日,第二十一届“中国光谷”国际光电子博览会(以下简称“本...
原创 四... 5月21日行业人士“RD观测”给出了,2026年4月国内智能手机排名。用一句话来讲四月份的排既在预料...
摩尔线程推出“云边端”全栈智算... 5月18日,摩尔线程在北京举办主题为“词元时代,万物智能”的年度产品发布会。在Agentic AI驱...
特斯拉最后一批Model S/... 【大河财立方消息】 北京时间5月21日午间,特斯拉公司副总裁陶琳发文称,刚刚在加州弗里蒙特工厂,马斯...
违规收集个人信息、窗口乱跳转,... 【大河财立方消息】 5月21日,工业和信息化部信息通信管理局发布关于侵害用户权益行为的APP(SDK...
我国电动汽车充电基础设施(枪)... 【大河财立方消息】5月21日,国家能源局发布2026年4月全国电动汽车充电设施数据。根据国家充电设施...
司法部推出四项措施治理乱罚款:... 【大河财立方消息】5月21日,国新办就规范涉企行政执法专项行动有关情况举行新闻发布会。司法部行政执法...