热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

LinuxCentOS7安装PostgreSQL9.5.17(源码编译)

近日需要将PostgreSQL数据库从Windows中迁移到Linux中,LinuxCentOS7安装PostgreSQL9.5.17安装过程特此记录。安装环境&#x

近日需要将PostgreSQL数据库从Windows中迁移到Linux中,Linux CentOS 7 安装PostgreSQL 9.5.17 安装过程 特此记录。

安装环境:

数据库:PostgreSQL 9.5.17

Linux:CentOS 7.3

数据库源文件下载:

在postgresql的官方即可找到源码文件目录(地址:https://www.postgresql.org/ftp/source/),在列表中找到需要下载的 9.5.17版本

进入目录,看到文件列表,选择.tar.gz格式文件,点击下载

编译安装:

将下载好的数据库安装文件,上传至服务器的/user/local/目录下,然后进入该目录,解压安装包。

#   tar -zvxf postgresql-9.5.17.tar.gz  

进去解压后的postgresql文件夹,进行编译,并在在编译时指定安装目录

#  ./configure --prefix=/usr/local/postgresql  

编译出错

没有c编译器,安装gcc

#  yum install  gcc  

安装完成后,再次执行编译

编译出错

缺少readline开发包,安装readline-devel包:

#  yum install  readline-devel  

 安装完成后,再次执行编译

 编译出错

缺少zlib开发包,安装zlib开发包:

#  yum install  zlib-devel   

 安装完成后,再次执行编译

编译成功,成功创建创建了config.status配置文件

编译配置完成,开始执行安装:依次执行:

#  make   

 

#  make install   

 

编译安装完成

设置用户权限及环境变量

编译安装成功后,接下来要做的就是创建一个普通用户,因为默认超级用户(root)不能启动postgresql,所以需要创建一个普通用户来启动数据库,执行以下命令创建用户:

#  useradd admin  

 需要设置权限,将postgres的数据目录全部赋权给admin用户(此处我将postgres的数据目录指定在在/usr/local/postgresql/data目录下):

# chown -R admin:admin /usr/local/postgresql/  

设置相关环境变量

此处仅仅设置admin用户的环境变量,所以首先切换到admin用户 

切换用户: #  su - admin   

然后打开.bash_profile文件并追加以下内容:

打开.bash_profile文件 : $   vi .bash_profile   

追加一下内容:

PGHOME=/usr/local/postgresql
export PGHOME
PGDATA
=/usr/local/postgresql/data
export PGDATAPATH
=$PATH:$HOME/.local/bin:$HOME/bin:$PGHOME/bin

修改完成后可以通过 $ source ./.bash_profile  使其立即生效

检验环境变量是否设置正确

切换任意目录输入$  which psql  以及  $  psql -V  即可分别查看psql客户端的路径以及postgresql的数据库版本

初始化数据库

由于配置了环境变量,所以此处我们直接执行initdb命令即可完成db初始化

$  initdb   

初始化成功

进入postgresql的目录可以看到生成的数据目录data以及该目录的相关数据和配置文件:

接下来修改配置文件,pg_hba.confpostgresql.conf。一个是访问控制配置(127.0.0.1改为信任的客户端ip网段使其可以远程访问),一个是postgresql主配置文件(listen_address=localhost改为星号使其监听整个网络)。

进入/usr/local/postgresql/data目录,修改文件,这里将pg_hba.conf的ip地址修改为0.0.0.0/0,而加密方式改为md5,就表示需要密码访问: 

pg_hba.conf文件修改:

修改postgresql.conf文件

listen_address=localhost改为星号使其监听整个网络:

同时需要放开机器的5432端口,这里为了方便起见,直接关闭服务器防火墙:

关闭防火墙:

$ systemctl stop firewalld   

此时为普通用户,关闭防火墙需要root账户权限,需要输入root账户密码获取权限

禁止防火墙开机启动:

$ systemctl disable firewalld   

此时为普通用户,取消防火墙开机启动同样需要root账户权限,需要输入root账户密码获取权限

查看防火墙状态:

$ systemctl status firewalld  

防火墙已经关闭

至此配置相关的内容就全部完成了,最后就是启动并连接数据库了。

启动、连接数据库

在初始化数据库结束时我们已经看到了启动命令

由于之前设置了环境变量,所以已经指定了数据目录PGDATA,-l表示日志文件目录,通常需要指定,所以我们在/usr/local/postgresql根目录下再创建一个log目录用来存放日志文件并赋予可写的权限

进入 /usr/local/postgresql目录

创建文件夹

$ mkdir log  

赋予权限

$ chown -R admin:admin /usr/local/postgresql/log/   
启动数据库

$ pg_ctl start -l /usr/local/postgresql/log/pg_server.log   

启动成功: 

通过postgresql自带的客户端工具psql来进行连接(在连接是需要制定连接数据库,这里直接连接postgres数据库):

 $ psql postgres   

设置admin用户的密码(默认为空),用psql连接成功后直接输入 \password  即会提示输入两次密码,如下图:

 

修改完密码以后,就是最重要的一点就是验证非本地客户端工具的连接了,毕竟我们是要做数据库服务器的,这里我选择的工具是Navicat Premium,在主机(Windows 10)打开Navicat与虚拟机中的postgresql服务器进行连接测试:

可以发现连接成功,同理停止数据库可以使用命令 pg_ctl stop 来关闭postgresql服务,很简单,至此关于源码编译安装postgresql就全部结束了。

转:https://www.cnblogs.com/guoxiangyue/p/10870012.html



推荐阅读
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 本文详细介绍如何在VSCode中配置自定义代码片段,使其具备与IDEA相似的代码生成快捷键功能。通过具体的Java和HTML代码片段示例,展示配置步骤及效果。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • 本文详细介绍了网络存储技术的基本概念、分类及应用场景。通过分析直连式存储(DAS)、网络附加存储(NAS)和存储区域网络(SAN)的特点,帮助读者理解不同存储方式的优势与局限性。 ... [详细]
  • 嵌入式开发环境搭建与文件传输指南
    本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ... [详细]
  • 本文详细介绍了 phpMyAdmin 的安装与配置方法,适用于多个版本的 phpMyAdmin。通过本教程,您将掌握从下载到部署的完整流程,并了解如何根据不同的环境进行必要的配置调整。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • ASP.NET MVC中Area机制的实现与优化
    本文探讨了在ASP.NET MVC框架中,如何通过Area机制有效地组织和管理大规模应用程序的不同功能模块。通过合理的文件夹结构和命名规则,开发人员可以更高效地管理和扩展项目。 ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 本文详细介绍了如何准备和安装 Eclipse 开发环境及其相关插件,包括 JDK、Tomcat、Struts 等组件的安装步骤及配置方法。 ... [详细]
  • 深入解析TCP/IP五层协议
    本文详细介绍了TCP/IP五层协议模型,包括物理层、数据链路层、网络层、传输层和应用层。每层的功能及其相互关系将被逐一解释,帮助读者理解互联网通信的原理。此外,还特别讨论了UDP和TCP协议的特点以及三次握手、四次挥手的过程。 ... [详细]
  • 本文介绍了一种适用于小型创业公司的小规模每日数据备份及健康检查的自动化解决方案。通过简单的Shell脚本实现本地数据库的每日全量备份,并将备份文件上传至中心备份服务器。同时,编写了自动检测脚本来确保备份的完整性和及时性,一旦发现异常,会通过邮件和短信通知相关人员。 ... [详细]
author-avatar
敬炜8965肀
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有