CentOS的源中自带有PostgreSQL,可以通过 yum list | grep postgresql 查看系统自带的版本,我这边看到的是9.2版本,个人还是比较建议安装更新的版本。
1、安装 yum 源(地址从 http://yum.postgresql.org/repopackages.php 获取)
1
|
yum install https://download.postgresql.org/pub/repos/yum/9.6/redhat/rhel-7-x86_64/pgdg-centos96-9.6-3.noarch.rpm
|
这里选择的是最新的9.6版本,安装完毕后使用 yum update 更新源信息,然后再使用 yum list | grep postgresql ,是否已经有最新版本的postgresql。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
[root@localhost ~]# yum list|grep postgresql
calligra-kexi-driver-postgresql.x86_64 2.9.10-1.el7 epel
collectd-postgresql.x86_64 5.6.0-1.el7 epel
freeradius-postgresql.x86_64 3.0.4-6.el7 base
libreoffice-postgresql.x86_64 1:4.3.7.2-5.el7_2.1 updates
mingw32-postgresql.noarch 9.3.4-2.el7 epel
mingw64-postgresql.noarch 9.3.4-2.el7 epel
opendbx-postgresql.x86_64 1.4.6-6.el7 epel
opensips-postgresql.x86_64 1.10.5-3.el7 epel
owncloud-postgresql.noarch 9.0.4-1.el7 epel
pcp-pmda-postgresql.x86_64 3.10.6-2.el7 base
pdns-backend-postgresql.x86_64 3.4.10-1.el7 epel
perdition-postgresql.x86_64 2.1-5.el7 epel
postgresql.i686 9.2.15-1.el7_2 updates
postgresql.x86_64 9.2.15-1.el7_2 updates
postgresql-contrib.x86_64 9.2.15-1.el7_2 updates
postgresql-devel.i686 9.2.15-1.el7_2 updates
postgresql-devel.x86_64 9.2.15-1.el7_2 updates
postgresql-docs.x86_64 9.2.15-1.el7_2 updates
postgresql-jdbc.noarch 9.4.1212-1.rhel7 pgdg96
postgresql-jdbc-javadoc.noarch 9.4.1212-1.rhel7 pgdg96
postgresql-libs.i686 9.2.15-1.el7_2 updates
postgresql-libs.x86_64 9.2.15-1.el7_2 updates
postgresql-odbc.x86_64 09.03.0100-2.el7 base
postgresql-pgpool-II.x86_64 3.4.6-1.el7 epel
postgresql-pgpool-II-devel.x86_64 3.4.6-1.el7 epel
postgresql-pgpool-II-extensions.x86_64 3.4.6-1.el7 epel
postgresql-plperl.x86_64 9.2.15-1.el7_2 updates
postgresql-plpython.x86_64 9.2.15-1.el7_2 updates
postgresql-plruby.x86_64 0.5.3-13.el7 epel
postgresql-plruby-doc.x86_64 0.5.3-13.el7 epel
postgresql-pltcl.x86_64 9.2.15-1.el7_2 updates
postgresql-server.x86_64 9.2.15-1.el7_2 updates
postgresql-test.x86_64 9.2.15-1.el7_2 updates
postgresql-unit96.x86_64 1.0-1.rhel7 pgdg96
postgresql-unit96-debuginfo.x86_64 1.0-1.rhel7 pgdg96
postgresql-upgrade.x86_64 9.2.15-1.el7_2 updates
postgresql96.x86_64 9.6.1-1PGDG.rhel7 pgdg96
postgresql96-contrib.x86_64 9.6.1-1PGDG.rhel7 pgdg96
postgresql96-debuginfo.x86_64 9.6.1-1PGDG.rhel7 pgdg96
postgresql96-devel.x86_64 9.6.1-1PGDG.rhel7 pgdg96
postgresql96-docs.x86_64 9.6.1-1PGDG.rhel7 pgdg96
postgresql96-libs.x86_64 9.6.1-1PGDG.rhel7 pgdg96
postgresql96-odbc.x86_64 09.05.0400-1PGDG.rhel7 pgdg96
postgresql96-plperl.x86_64 9.6.1-1PGDG.rhel7 pgdg96
postgresql96-plpython.x86_64 9.6.1-1PGDG.rhel7 pgdg96
postgresql96-pltcl.x86_64 9.6.1-1PGDG.rhel7 pgdg96
postgresql96-python.x86_64 4.2-1PGDG.rhel7 pgdg96
postgresql96-python-debuginfo.x86_64 4.2-1PGDG.rhel7 pgdg96
postgresql96-server.x86_64 9.6.1-1PGDG.rhel7 pgdg96
postgresql96-tcl.x86_64 2.1.1-1.rhel7 pgdg96
postgresql96-tcl-debuginfo.x86_64 2.1.1-1.rhel7 pgdg96
postgresql96-test.x86_64 9.6.1-1PGDG.rhel7 pgdg96
proftpd-postgresql.x86_64 1.3.5b-2.el7 epel
python-testing.postgresql.noarch 1.1.0-2.el7 epel
qt-postgresql.i686 1:4.8.5-12.el7_2 updates
qt-postgresql.x86_64 1:4.8.5-12.el7_2 updates
qt5-qtbase-postgresql.x86_64 5.6.1-3.el7 epel
soci-postgresql.x86_64 3.2.3-1.el7 epel
soci-postgresql-devel.x86_64 3.2.3-1.el7 epel
|
2、安装PostgreSQL
这里最核心的是要安装postgresql96-server和postgresql96-contrib,其中”contrib”包里包含了一些常用的组件和方法。
1
|
yum install postgresql96-server postgresql96-contrib
|
安装后,可执行文件在 /usr/pgsql-9.5/bin/
, 数据和配置文件在 /var/lib/pgsql/9.6/data/
3、初始化数据库
1
|
/usr/pgsql-9.6/bin/postgresql96-setup initdb
|
4、默认情况下PostgreSQL不支持密码登录,如需支持需要修改配置文件
1
|
vi /var/lib/pgsql/9.6/data/pg_hba.conf
|
将未注释行中的ident
替换为 md5
1
2
3
4
5
6
7
8
9
10
11
12
13
|
# TYPE DATABASE USER ADDRESS METHOD
# "local" is for Unix domain socket connections only
local all all peer
# IPv4 local connections:
host all all 127.0.0.1/32 ident
# IPv6 local connections:
host all all ::1/128 ident
# Allow replication connections from localhost, by a user with the
# replication privilege.
#local replication postgres peer
#host replication postgres 127.0.0.1/32 ident
#host replication postgres ::1/128 ident
|
如需开启远程访问,可编辑/var/lib/pgsql/9.6/data/postgresql.conf 文件。
将 #listen_addresses = 'localhost' 修改为 listen_addresses='*' (当然,此处‘*’也可以改为任何你想开放的服务器IP)
另外对于特定的IP还可以设置开启信任远程连接,修改/var/lib/pgsql/9.6/data/pg_hba.conf,按下面的格式进行添加设置。
1
2
3
|
# IPv4 local connections:
host all all 127.0.0.1/32 trust
host all all 8.8.8.8/32(需要连接的服务器IP) trust
|
修改完配置以后不要忘了重启服务。
5、管理服务,和其他服务一样还是用systemd进行管理
1
2
3
4
|
systemctl start postgresql-9.6 #启动服务
systemctl restart postgresql-9.6 #重启服务
systemctl stop postgresql-9.6 #停止服务
systemctl enable postgresql-9.6 #自动启动
|
5、登录PostgreSQL
PostgreSQL 安装完成后,会建立一下‘postgres’用户,用于执行PostgreSQL,数据库中也会建立一个’postgres’用户,如果我们要使用PostgreSQL就必须先登录此帐号。
1
|
sudo -i -u postgres
|
执行后提示符会变为 ‘-bash-4.2$’,再运行
同构执行进入 psql 进入postgresql命令行环境。
1
2
3
4
5
6
|
[root@localhost ~]# sudo -i -u postgres
-bash-4.2$ psql
psql (9.6.1)
Type "help" for help.
postgres=#
|
接着可以执行 ALTER USER postgres WITH PASSWORD '123456' 来设置postgres用户密码,可通过 \q 退出数据库。
6、打开防火墙
CentOS 防火墙中内置了PostgreSQL服务,配置文件位置在/usr/lib/firewalld/services/postgresql.xml,只需以服务方式将PostgreSQL服务开放即可。
1
2
|
firewall-cmd --add-service=postgresql --permanent 开放postgresql服务
firewall-cmd --reload 重载防火墙
|