如何进行postgre安装,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

1实验目的

PostgreSQL数据库安装、初始化及可用性测试。

2环境介绍

操作系统: RedHat 6.5

数据库软件:PostgreSQL version9.5

3PostgreSQL数据库介绍

PostgresQL是以加州大学伯克利分校计算机系开发的POSTGRES,现在已经更名为PostgreSQL,版本4.2为基础的对象关系型数据库管理系统(ORDBMS)。PostgreSQL支持大部分SQL标准并且提供了许多其他现代特性:复杂查询、外键、触发器、视图、事务完整性、MVCC。同样,PostgreSQL可以用许多方法扩展,比如, 通过增加新的数据类型、函数、操作符、聚集函数、索引。免费使用、修改、和分发PostgreSQL,不管是私用、商用、还是学术研究使用。

4软件获取

官方下载地址:https://yum.postgresql.org/rpmchart.php

官方文档:https://www.postgresql.org/docs/

注:建议大家学习任何软件,从阅读官方文档开始。

5安装方式

方法一:yum安装

Thesedistributions all include PostgreSQL by default. To install PostgreSQL fromthese repositories, use theyumcommand on RHEL 5,6 and 7, ordnfcommandon Fedora 22+:

yum installpostgresql-server

dnf installpostgresql-server

Which version ofPostgreSQL you get will depend on the version of the distribution:

Distribution

Version

RHEL/CentOS/SL/OL 7

9.2(also supplies package rh-postgresql95 and rh-postgresql94 via SCL)

RHEL/CentOS/SL/OL 6

8.4(also supplies package postgresql92)

RHEL/CentOS/SL/OL 5

8.1 (also supplies package postgresql84)

Fedora 24

9.5

Fedora 23

9.4

方法二:直接下载RPM安装

方法三:源码包安装

6安装实践6.1检查PostgreSQL 是否已经安装

[root@mhapp1 ~]# rpm -qa|grep postgres

postgresql-8.4.18-1.el6_4.x86_64

postgresql-libs-8.4.18-1.el6_4.x86_64

postgresql-devel-8.4.18-1.el6_4.x86_64

若已安装使用rpm –e卸载。注:请确认是练习库!!!

6.2安装PostgreSQL,注意安装顺序

[root@mhapp1 rpm]# rpm-ivh postgresql95-libs-9.5.6-2PGDG.rhel6.x86_64.rpm

warning:postgresql95-libs-9.5.6-2PGDG.rhel6.x86_64.rpm: Header V4 DSA/SHA1 Signature,key ID 442df0f8: NOKEY

Preparing...########################################### [100%]

1:postgresql95-libs########################################### [100%]

[root@mhapp1 rpm]#rpm -ivh postgresql95-9.5.6-2PGDG.rhel6.x86_64.rpm

warning:postgresql95-9.5.6-2PGDG.rhel6.x86_64.rpm: Header V4 DSA/SHA1 Signature, key ID442df0f8: NOKEY

Preparing...########################################### [100%]

1:postgresql95########################################### [100%]

[root@mhapp1 rpm]#rpm -ivh postgresql95-server-9.5.6-2PGDG.rhel6.x86_64.rpm

warning: postgresql95-server-9.5.6-2PGDG.rhel6.x86_64.rpm:Header V4 DSA/SHA1 Signature, key ID 442df0f8: NOKEY

Preparing...########################################### [100%]

1:postgresql95-server########################################### [100%]

[root@mhapp1 rpm]# rpm-ivh postgresql95-contrib-9.5.6-2PGDG.rhel6.x86_64.rpm

warning:postgresql95-contrib-9.5.6-2PGDG.rhel6.x86_64.rpm: Header V4 DSA/SHA1Signature, key ID 442df0f8: NOKEY

Preparing...########################################### [100%]

1:postgresql95-contrib########################################### [100%]

6.3初始化PostgreSQL

[root@mhapp1 rpm]#/etc/init.d/postgresql-9.5 start

/var/lib/pgsql/9.5/data is missing. Use"service postgresql-9.5 initdb" to initialize the cluster first.

[root@mhapp1 rpm]# service postgresql-9.5initdb

Initializing database: [ OK ]

6.4启动服务

[root@mhapp1 rpm]# service postgresql-9.5start

Starting postgresql-9.5 service: [ OK ]

6.5把PostgreSQL服务加入到启动列表

[root@mhapp1 rpm]# chkconfig postgresql-9.5on

[root@mhapp1 rpm]# chkconfig --list|greppostgres

postgresql-9.5 0:off 1:off 2:on 3:on 4:on 5:on 6:off

6.6修改PostgreSQL数据库用户postgres的密码

PostgreSQL数据库默认会创建一个postgres的数据库用户作为数据库的管理员,默认密码为空,我们需要修改为指定的密码

[root@mhapp1 rpm]# su - postgres

$ id

uid=26(postgres) gid=26(postgres)groups=26(postgres)

$ psql

psql (9.5.6)

Type "help" for help.

postgres=# alter user postgres withpassword'orastar';

ALTER ROLE

postgres=# select * from pg_shadow;

usename| usesysid | usecreatedb | usesuper | userepl | usebypassrls | passwd | valuntil | useconfig

----------+----------+-------------+----------+---------+--------------+-------------------------------------+----------+----------

-

postgres | 10 | t | t | t | t |md53175bce1d3201d16594cebf9d7eb3f9d ||

(1 row)

7测试数据库7.1创建测试数据库

postgres=#

postgres=# create database htdb;

CREATE DATABASE

7.2切换到htdb数据库

postgres=# \c htdb

You are now connected to database"htdb" as user "postgres".

7.3创建测试表

htdb=# create table test(id integer,nametext);

CREATE TABLE

7.4插入测试数据

htdb=# insert into test values(1,'ht');

INSERT 0 1

7.5查询数据

htdb=# select * from test;

id |name

----+------

1 |ht

(1 row)

htdb=#

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。