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

postgresql数据库安装过程图解

最近给某电信公司做了个项目,把原oracle库迁移到EnterpriseDB之PPAS上,拿回oracle的dump文件忙乎了一圈,想把安装迁移过程写一下,就从网上把postgresql的各种安装过程搬过来,凑个系列。安装PostgreSQL数据库不一定需要root用户权限,普通用户也可以。安

最近给某电信公司做了个项目,把原oracle库迁移到EnterpriseDB之PPAS上,拿回oracle的dump文件忙乎了一圈,想把安装迁移过程写一下,就从网上把postgresql的各种安装过程搬过来,凑个系列。

安装PostgreSQL数据库不一定需要root用户权限,普通用户也可以。安装方式有多种,一种是编译安装,一种是二进制安装包安装,还有各种linux系统的包安装。

总体流程:

./configure
gmake
su
gmake install
adduser postgres
mkdir /usr/local/pgsql/data
chown postgres /usr/local/pgsql/data
su - postgres
/usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data
/usr/local/pgsql/bin/postgres -D /usr/local/pgsql/data >logfile 2>&1 &
/usr/local/pgsql/bin/createdb test
/usr/local/pgsql/bin/psql test

2.安装的前提条件

要求一:

要求有GNU make,版本要大于等于 3.76.1,检查gmake的方法如下:

gmake --version

编译器要求是兼容ISO/ANSI C 的编译器,遵从C89标准。

如果使用gcc,这两个条件都能支持。而gcc支持大多数的UNIX环境,如Linux、AIX、HPUX、Solaris等。

要求三:

由于源代码包是.tar.gz或.tar.bz2的格式,所以要求平台下有能解压缩源代码包的tar和gzip工具。

要求四(非强制):

PostgreSQL默认是使用GNU Readline库支持在psql的命令行中可以使用光标键(↑↓)翻出历史命令。当然如果没有GNU Readline库的话,需要增加without-readline 选项到./configure命令后,当然这样做后就失去了使用光标键(↑↓)翻出历史命令的功能。也可以使用libedit库(BSD-licensed)提供类似的功能,这时需要在.configure后增加--with-libedit-preferred 选项。常用的Linux发行版本默认安装了时都安装了GNU Readline库。下面的命令检查是否安装了Readline库: [root@osdba /usr/src/postgresql-8.4.3]#rpm -qa |grep readline
readline-5.2-13.fc9.i386

要求五(非强制):

PostgreSQL默认使用zlib压缩库,主要是pg_dump和pg_restore这两个导入导出工具使用zlib压缩库,指定配置选项--without-zlib可以不使用zlib库,当然这样pg_dump和pg_restore就没有了压缩功能了。

要求六(非强制):

主要你需要服务端语言如PL/Perl ,PL/Python PL/Tcl ,当然你需要安装Perl、Python、Tcl。

如果你需要PostgreSQL能提示中文,你需要实现Gettext API。

3.下载PostgreSQL源码包

gunzip postgresql-8.4.3.tar.gz
tar xvf postgresql-8.4.3.tar

如果在Linux下,可以一步解压:

tar zxvf postgresql-8.4.3.tar.gz

如果是.tar.bz2包:

tar jxvf postgresql-8.4.3.tar.bz2

 

 

4.安装过程

⑴ ./configure

后面可以跟我们前面讲过的一些选项,如--with-libedit-preferred :

./configure --with-libedit-preferred

后面可以跟很多的选项,具体可以参见PostgreSQL提供的官方手册,这里介绍几个常用的选项:

--prefix=PREFIX:指定安装PostgreSQL的安装目前,如果没有指定,则安装到/usr/local/pgsql目录下。

--with-pgport=NUMBER:指定PostgreSQL的监听端口,默认为5432

--with-wal-segsize=SEGSIZE: 指定WAL日志文件的大小。

--with-wal-blocksize=BLOCKSIZE:指定WAL日志的块大小。

--enable-thread-safety:允许客户端的库函数是线程安全的。

执行的时候可能报:

configure: error: readline library not found

这是因为readline没有安装,只要安装这个库就可以了,如在ubuntu10.04下可以:

aptitude install libreadline6-dev

 

⑵ 编译源代码

gmake

有可能你的机器的没有gmake命令,而make就是gnu make,这时运行make编译:

make

 

⑶ 安装编译生成的文件

gmake install

 

如果仅安装客户端程序:

"APPLICATION">"FILENAME">"REPLACEABLE">"APPLICATION"> "PRODUCTNAME">"APPLICATION"> "PRODUCTNAME">"USERINPUT">gmake -C src/bin install
gmake -C src/include install
gmake -C src/interfaces install
"USERINPUT">gmake -C doc install

如果是在windows平台,可以注册event log:

regsvr32 pgsql_library_directory/pgevent.dll

 

⑷ 卸载

gmake uninstall

 

 

5.设置环境变量和共享库路径和可执行文件路径

可以把下面的内容添加到UNIX用户的~/.bash_profile或~/.profile文件中,或如果对所有用户生效,可以添加到/etc/profile文件中:

 

在Bourne shells (shkshbashzsh):
"APPLICATION">"FILENAME">"REPLACEABLE">"APPLICATION"> "PRODUCTNAME">"FILENAME">LD_LIBRARY_PATH=/usr/local/pgsql/lib
export LD_LIBRARY_PATH

"APPLICATION">"FILENAME">"REPLACEABLE">"APPLICATION"> "PRODUCTNAME">"FILENAME">PATH=/usr/local/pgsql/bin:$PATH
export PATH

"APPLICATION">"FILENAME">"REPLACEABLE">"APPLICATION"> "PRODUCTNAME">"FILENAME">MANPATH=/usr/local/pgsql/man:$MANPATH
export MANPATH

or in csh or tcsh:

"APPLICATION">"FILENAME">"REPLACEABLE">"APPLICATION"> "PRODUCTNAME">"FILENAME">setenv LD_LIBRARY_PATH /usr/local/pgsql/lib
"APPLICATION">"FILENAME">"REPLACEABLE">"APPLICATION"> "PRODUCTNAME">"FILENAME">set path = ( /usr/local/pgsql/bin $path )
"APPLICATION">"FILENAME">"REPLACEABLE">"APPLICATION"> "PRODUCTNAME">"FILENAME"> 

在BSD/OS, Linux, or SunOS 4平台下,使用root用户执行:

"APPLICATION">"FILENAME">"REPLACEABLE">"REPLACEABLE">/sbin/ldconfig /usr/local/pgsql/lib
"APPLICATION">"FILENAME">"REPLACEABLE">On  "SYSTEMITEM">FreeBSD,  "SYSTEMITEM">NetBSD, and  "SYSTEMITEM">OpenBSD:
"APPLICATION">"FILENAME">"REPLACEABLE">"REPLACEABLE">/sbin/ldconfig -m /usr/local/pgsql/lib

6.安装contrib目录下的一些工具

源代码目录下有一个contrib目录,是一些第三方组织贡献出来的一些工具代码,这些工具在日常维护中也很有用,建议安装上。

cd /usr/src/postgresql-8.4.3/contrib

make

make install

7.创建数据库

建postgres用户:

useradd -m -u 701 postgres

建postgres数据库的目录,假设数据库建在/opt/pgdata目录下:

mkdir /opt/pgdata

chown postgres:postgres /opt/pgdata

在postgres用户下的.bash_profile文件中添加如下内容,方便以后启动数据库和关闭数据库:

export PGDATA=/opt/pgdata
alias pgstart='pg_ctl -D $PGDATA start'
alias pgstop='pg_ctl kill INT `head -1 $PGDATA/postmaster.pid`'

如果你要建utf8的数据库,注意设置LANG环境变量为utf8的,把下面的内容加到.bash_profile文件中:

export LANG=en_US.utf8

初使化数据库目录:

su - postgres
/usr/local/pgsql/bin/initdb -D $PGDATA

修改数据库参数:

按需要修改$PGDATA/postgresql.conf中的参数,如:

logging_collector = on
log_rotation_age = 1d

log_rotation_size = 10MB

启动数据库:
/usr/local/pgsql/bin/pg_ctl -D $PGDATA start

这时就可以进入psql命令行了:
[postgres@pghost pgdata]$ psql
psql (8.4.3)
Type "help" for help.

postgres=#

这时可以创建用户数据库了:

CREATE DATABASE mydb

二. 图形安装:

该部分介绍 PostgreSQL 程序的安装过程。基于 SuperMap 的 SDX+ for PostgreSQL 对 PostgreSQL 8.2版本不支持,建议安装 PostgreSQL 8.3 及以上版本。

安装首页

打开 PostgreSQL 产品的安装目录后,双击“postgresql-9.0.2-1-windows.exe”程序,出现如下图所示的 PostgreSQL 安装首页,单击“Next”按钮继续安装。

图:PostgreSQL 安装首页

指定安装目录

如下图所示,指定 PostgreSQL 的安装目录。然后,单击“Next”按钮继续安装。

图:指定安装目录

安装 PostgreSQL 的分区最好是 NTFS 格式的。PostgreSQL 首要任务是要保证数据的完整性,而 FAT 和 FAT32 文件系统不能提供这样的可靠性保障,而且 FAT 文件系统缺乏安全性保障,无法保证原始数据在未经授权的情况下被更改。此外,PostgreSQL 所使用的"多分点"功能完成表空间的这一特征在FAT文件系统下无法实现。

然而,在某些系统中,只有一种 FAT 分区,这种情况下,可以正常安装 PostgreSQL,但不要进行数据库的初始化工作。安装完成后,在 FAT 分区上手动执行 initdb.exe 程序即可,但不能保证其安全性和可靠性,并且建立表空间也会失败。

指定数据存储目录

如下图所示,为数据库存储区域指定安装区域。然后,单击“Next”按钮继续安装。

图:指定数据存储目录

设置数据库超级用户和服务账户的密码

数据库超级用户是一个非管理员账户,这是为了减少黑客利用在 PostgreSQL 发现的缺陷对系统造成损害,因此需要对数据库超级用户设置密码,如下图所示,安装程序自动建立的服务用户的用户名默认为 postgres。然后,单击“Next”按钮继续安装。

图:设置服务账户的密码

设置服务监听端口

如下图所示,指定数据库服务器的端口,默认是“5432”,用户可根据自己端口的使用情况进行设置。然后,单击“Next”按钮继续安装。

图:设置服务监听端口

选择运行时语言环境

如下图所示,选择数据库存储区域的运行时语言环境。然后,单击“Next”按钮,进入安装进度页面,等待 PostgreSQL 安装完毕。

注意,在选择语言环境时,若选择"default locale"会导致安装不正确;同时,PostgreSQL 不支持 GBK 和 GB18030 作为字符集,如果选择其它四个中文字符集:中文繁体 香港(Chinese[Traditional], Hong Kong S.A.R.)、中文简体 新加坡(Chinese[Simplified], Singapore)、中文繁体 台湾(Chinese[Traditional], Taiwan)和中文繁体 澳门(Chinese[Traditional], Marco S.A.R.),会导致查询结果和排序效果不正确。建议选择"C",即不使用区域。

图:选择运行时语言环境
图:安装进度页面

结束安装

上面的安装步骤执行完成后,会弹出如下图所示的完成对话框。这里可以选择安装完成后是否运行 Stack Builder 向导来安装附加软件,以完善 PostgreSQL 的安装。该操作必须在联网状态下执行。

图:结束安装

三. redhat上包安装:

一.安装postgresql
   需要包:
       1. rpm -ivh postgresql-libs
       2. rpm -ivh postgresql
       3. rpm -ivh postgresql-server
       4. rpm -ivh postgresql-contrib
       5. rpm -ivh postgresql-devel
二.建立postgresql用户
   useradd postgres
   passwd postgres
三.建立postgresql数据文件存放目录并设置postgresql用户访问权限
   mkdir postgresql
   cd postgresql
   mkdir data
   chown -R postgresql:postgresql /postgresql
   chmod -R 775 /postgresql
四.设置环境postgresql环境变量
   # vi ~postgresql/.bash_profile
   添加:

   PGLIB=/usr/pgsql-版本号/lib
   PGDATA=/postgresql/data
   PATH=/usr/pgsql-版本号/bin:$PATH
   MANPATH=$MANPATH:/usr/pgsql-版本号
   export PGLIB PGDATA PATH MANPATH
五.启动数据库引擎
   1.进入postgresql
    su - postgresql
   2.启动数据库引擎
    initdb  

----------------------------------------------数据库创建成功时提示--------------------------------------
[postgresql@datatest ~]$ initdb
属于此数据库系统的文件宿主为用户 "postgresql".
此用户也必须为服务器进程的宿主.
数据库簇将带有 locale zh_CN.UTF-8 初始化.
默认的数据库编码已经相应的设置为 UTF8.

修复已存在目录 /postgresql/data 的权限 ... 成功
创建目录 /postgresql/data/global ... 成功
创建目录 /postgresql/data/pg_xlog ... 成功
创建目录 /postgresql/data/pg_xlog/archive_status ... 成功
创建目录 /postgresql/data/pg_clog ... 成功
创建目录 /postgresql/data/pg_subtrans ... 成功
创建目录 /postgresql/data/pg_twophase ... 成功
创建目录 /postgresql/data/pg_multixact/members ... 成功
创建目录 /postgresql/data/pg_multixact/offsets ... 成功
创建目录 /postgresql/data/base ... 成功
创建目录 /postgresql/data/base/1 ... 成功
创建目录 /postgresql/data/pg_tblspc ... 成功
选择默认最大联接数 (max_connections) ... 100
选择默认共享缓冲区大小 (shared_buffers) ... 1000
创建配置文件 ... 成功
在 /postgresql/data/base/1 中创建 template1 数据库 ... 成功
initializing pg_authid ... 成功
启动不限制系统表行大小 ... 成功
initializing dependencies ... 成功
创建系统视图 ... 成功
加载 pg_description ... 成功
创建字符集转换 ... 成功
对内建对象设置权限 ... 成功
创建信息模式 ... 成功
清理数据库 template1 ... 成功
拷贝 template1 到 template0 ... 成功
copying template1 to postgres ... 成功

警告: 为本地连接启动了 "trust" 认证.
你可以通过编辑 pg_hba.conf 更改或你下
次运行 initdb 时使用 -A 选项.

Success. You can now start the database server using:

    postmaster -D /postgresql/data
or
    pg_ctl -D /postgresql/data -l logfile start

六.启动数据库
   1.root用户下运行
如在root用户下启动则需要将启动文件中默认的PGDATA和PGPORT变量值修改。
    /etc/init.d/postgresql-版本号 start
   2.postgres用户下运行
   pg_ctl -D /postgresql/data -l logfile start

七.建立数据库

   createdb MTPS
八.进入pssql交互工具

   psql MTPS

九.执行数据库操作
   create table test(i varchar(10));

十.退出pssql
  \q

十一.设置外端连接
   1)修改postgresql.conf配置文件
   vi /postgresql/data/postgresql.conf
将#listen_addresses=’localhost’修改为listen_addresses=‘*’
   启用默认端口

   2)在pg_hba.conf中设置可连接客户端IP
   vi /postgresql/datapg_hba.conf
   添加host  all   all  192.168.10.0/24   true
   3)重启数据库

四. ubantu上包安装:

安装环境:

      Ubuntu 10.04-desktop-i386

      PostgreSQL 8.4

1. 安装PostgreSQL

  输入如下命令

 sudo apt-get install postgresql

系统会提示安装所需磁盘空间,输入"y",安装程序会自动完成。 安装完毕后,系统会创建一个数据库超级用户“postgres”, 密码为空。这个用户既是不可登录的操作系统用户,也是数据库用户。

2. 修改Linux用户postgres的密码

  输入如下命令

 sudo passwd postgres

3. 修改数据库超级用户postgres的密码

1) 切换到Linux下postgres用户

 sudo su postgres

2) 登录postgres数据库

psql postgres

这样你会看到postgres提示信息如下:

psql (8.4.4)

Type "help" for help.

并出现postgres的命令行提示符号:

postgres=#

3) 输入如下命令

 ALTER USER postgres with PASSWORD 'password'

 键入“exit”返回到Linux命令行。

4. 添加自己定义的用户和数据库

1) 添加新用户

 createuser -drSP fedoraAdmin

   按照提示输入该用户的密码。

2) 创建一个属于自定义用户fedoraAdmin的数据库

 createdb -O fedoraAdmin mydb

通过如上设置,可以在Java中通过以下配置来连接PostgresSQL数据库

user:fedoraAdmin

password: your password

url: jdbc:postgresql://localhost:5432/mydb

5. 安装pgAdmin3

1) 键入如下命令安装pgAdmin3

 sudo apt-get install pgadmin3

2) 键入如下命令运行pgAdmin3 

 pgadmin3

 你就会看到pgAdmin3的主界面如下所示:

添加相应的参数以创建一个到PostgreSql的连接:

6. 设置其它机器上对postgres的访问

修改/etc/postgresql/8.4/main/pg_hba.conf:

host all all 0.0.0.0/0 md5  #0.0.0.0为地址段,0为多少二进制位

例如:192.168.0.0/16代表192.168.0.1-192.168.255.254

修改/etc/postgresql/8.4/main/postgresql.conf

listen_address = '*'

重启数据库

sudo /etc/init.d/postgresql-8.4 restart


推荐阅读
  • 恶意软件分析的最佳编程语言及其应用
    本文介绍了学习恶意软件分析和逆向工程领域时最适合的编程语言,并重点讨论了Python的优点。Python是一种解释型、多用途的语言,具有可读性高、可快速开发、易于学习的特点。作者分享了在本地恶意软件分析中使用Python的经验,包括快速复制恶意软件组件以更好地理解其工作。此外,作者还提到了Python的跨平台优势,使得在不同操作系统上运行代码变得更加方便。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 树状笔记软件for linux,Ubuntu 14.04安装开源树状笔记管理软件 WikidPad 2.2
    WikidPad是一款开源免费的wiki风格的树状笔记管理软件,类似于Notepad。基于Python,支持Windows、Mac、Linux等平台。W ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • Python语法上的区别及注意事项
    本文介绍了Python2x和Python3x在语法上的区别,包括print语句的变化、除法运算结果的不同、raw_input函数的替代、class写法的变化等。同时还介绍了Python脚本的解释程序的指定方法,以及在不同版本的Python中如何执行脚本。对于想要学习Python的人来说,本文提供了一些注意事项和技巧。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • Postgresql备份和恢复的方法及命令行操作步骤
    本文介绍了使用Postgresql进行备份和恢复的方法及命令行操作步骤。通过使用pg_dump命令进行备份,pg_restore命令进行恢复,并设置-h localhost选项,可以完成数据的备份和恢复操作。此外,本文还提供了参考链接以获取更多详细信息。 ... [详细]
  • 【技术分享】一个 ELF 蠕虫分析
    【技术分享】一个 ELF 蠕虫分析 ... [详细]
author-avatar
永远的菜鸟
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有