PostgreSQL v12.0在Centos7手动安装

一、官网下载源代码

https://www.postgresql.org/ftp/source/v12.0/

image

二、安装步骤

新建文件夹
mkdir /opt

把源代码  postgresql-12.0.tar.gz   放到/opt 目录下
进入目录
cd /opt
解压
tar -vxzf postgresql-12.0.tar.gz
解压后,有install说明文档
1.安装相关依赖,我电脑没有外网,所以跳过了此步骤,应该是系统自带。
yum install -y readline readline-devel openssl openssl-devel zlib zlib-devel python-devel

注意:安装gcc:yum install gcc*

2.编译前设置,主要是设置安装目录
cd /opt/postgresql-12.0
./configure --prefix=/usr/local/pgsql/ --with-python
3.make
---make(编译)完毕,如果成功,则提示:All of PostgreSQL successfully made. Ready to install.
make命令没有编译./contrib目录下面的各种扩展,后期如果需要使用某个扩展,
那么需要重新运行上面第2步./configure(因为,我之前安装完毕,删除了./configure)
然后cd ./contrib/某扩展目录下,make && make install ——这样就可以安装了这个扩展,不需重启。
4.make install
---make install完毕,如果成功,则提示:PostgreSQL installation complete.
pgsql已经成功安装在  /usr/local/pgsql/  目录下。
5.添加postgres用户,对数据库的所有操作都要在这个用户下
   adduser postgres
#yum安装postgresql,默认会建一个名为”postgres”的系统账号,用于执行PostgreSQL;
#同时数据库中也会生成一个名为”postgres”的数据库用户,且密码已自动生成,需要进入数据库后修改;
#PostgreSQL在数据库用户同名的系统账号下登录免密。
6.添加数据文件目录
    mkdir /usr/local/pgsql/data
    chown -R postgres:postgres /usr/local/pgsql
7.切换成postgres用户登录
     su  postgres
8.初始化数据库并启动
    /usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data
   --初始化数据库成功:Success. You can now start the database server using
    /usr/local/pgsql/bin/pg_ctl -D /usr/local/pgsql/data -l logfile start
9.设置全局环境变量,vi /etc/profile    ----root 权限才可以编辑
export PATH=/usr/local/pgsql/bin:$PATH
export PGDATA=/usr/local/pgsql/data
export PGHOME=/usr/local/pgsql
export PGPORT=5431     #因为gee已经有一个pgsql在运行,端口是5432,所以,这里要用端口5431
10.启动或者停止pgsql服务器 (切换postgres用户)
/usr/local/pgsql/bin/pg_ctl -D /usr/local/pgsql/data start [ stop ]
或者直接运行:pg_ctl start [stop]

三、其它操作

1、配置数据库远程访问

PG默认只能本机访问,但是实际情况中,应用服务器多单独部署,需要开通PG的远程访问权限,且是需要配置用户密码的。
需要修改postgres.conf, pg_hba.conf文件。

文件在哪?

/usr/local/pgsql/data/postgresql.conf
/usr/local/pgsql/data/pg_hba.conf

1.1修改postgresql.conf

主要配置参数详解:

#listen_addresses='localhost'
listen_addresses='*'   --- 修改成'*'全部ip都可以访问改数据库。

其他参数:

Postgresql监听的网卡ip,默认仅仅本地,可以配置多个,使用“,”分割。“*” 代表所有的网卡ip
port=5432  
Postgres服务端口
max_connections=100  
最大服务器连接数
superuser_reserved_connections=3 
为管理员保留的专用连接数,普通用户无法使用这些连接,不能大于max_connections
authentication_timeout=60s  
登录验证超时时间设置
ssl=false
是否使用SSL进行连接
password_encryption=true  
当使用create user、alter user管理用户时,如果没有显示进行加密与否的限定,postgresql服务器是否自动进行密码密
shared_buffers=32m 
共享缓存,非常重要的性能参数,其最小值为(128k,16k*max_connections)
max_prepared_transactions=5
最大并行prepared 事务,如果为0,则禁止使用prepared事务,最大值与max_connections相同
temp_buffers=8m
每个会话可以使用的临时(表)缓存大小
work_mem=1m
指定内部排序、连接、group等等时,postgresql可以使用的内存大小,超过该值,将使用磁盘临时文件; 实际使用的内存该类操作同时执行的数目相乘
maintenance_work_men=16m  
维护语句vacuum、create index等等可以使用的内存大小; 实际使用的内存和该类操作同时执行的数目相乘
fsync=on  
(物理数据)日志必须同步写入磁盘 
可能导致严重的性能损失,却能确保最高的日志数据安全。
synchronous_commit=on
(逻辑事务数据)日志必须同步写入磁盘,如果设为on,会立即调用fsync,相当于设置了fsync=on
full_page_writes=on
写整页
wal_buffers=64K
WAL日志缓存大小
wal_writer_delay=200ms  
将wal日志从wal_buffer中写入磁盘的时间周期
commit_delay=0ms  
事务日志commit后,写入磁盘的延时。这个设置只有在commit_sibings(并行的多个排队事务)在延时内存在是才有效
commit_siblings=5
并行事务数

1.2 修改pg_hba.conf

[root@pgserver ~]# vi pg_hba.conf
... ...
 
·"local" is for Unix domain socket connections only
local   all             all                                     trust
IPv4 local connections:
host    all             all             127.0.0.1/32            trust
host    all             all             0.0.0.0/0               md5    #-- 添加本行

添加:host  all   all   0.0.0.0/0   md5

意思是:【主机】可以使用 【全部】数据库 , 【全部】 用户,使用IP【0.0.0.0】,通过MD5加密密码访问。
连接数据库是需要密码的。

配置说明:

格式:TYPE DATABASE USER ADDRESS METHOD
参数:
TYPE: 值为local和host, Local值表示为主机Socket连接, host代表允许的主机地址连接
DATABASE: 允许访问的数据库名, all代表允许全部数据库
USER: 表示允许哪个用户访问数据库, all代表所有用户都可以访问
ADDRESS: 表示允许连接的主机信息,可以使用主机IP地址, 也可以使用网段来表示,如192.168.1.0/24表示192.168.1.0网段可以连接
METHOD: 连接方法, 通常使用的值为md5和trust

1.3防火墙设置

查看防火墙状态
firewall-cmd --state

停止firewall
systemctl stop firewalld.service

开启firewall
 firewall-cmd --state

禁止firewall 开机启动
systemctl disable firewalld.service

2、测试数据库

PG模式是不能用root用户访问数据库,使用时需要用su postgres 切换到postgres用户下。
使用psql命令进行测试。

psql命令详解:

-h host, 指定连接的Postgres数据库IP地址
-U username: 指定连接数据库的用户名
-d database: 指定连接的数据库名
-p port: 指定数据库连接的服务端口
-w: 表示不提示用户输入密码
-W : 表示验证数据库用户密码
-l : 表示列出Postgres可用的数据库信息

示例如下:

su - postgres    # -- root 切换到postgres

[postgres@localhost data]$ psql -h localhost -U postgres -d postgres
psql (12.0)
Type "help" for help.

postgres=#

3、修改默认的postgres用户密码

在修改Postgres用户密码时,需要确保以下条件:

配置"pg_hba.conf"时需要确定服务器本地址的验证方法为trust, 即:
host all all 127.0.0.1/32 trust
如果为peer|indent|md5方法时,需要将其修改为trust, 否则登录时会提醒输入用户密码。

切换系统用户为postgres, 通过psql -h localhost -U postgres -d postgres登录Postgres数据库,进入数据后,使用SQL来为用户修改默认密码。

alter user postgres with password 'newpassword'

示例如下:

su - postgres    # -- root 切换到postgres
psql -h localhost -U postgres -d postgres -w
postgres=#  alter user postgres with password 'newpassword';
#ALTER ROLE

4、Postgres日常服务管理

启动数据库:pg_ctl start -D /usr/local/pgsql/data
重启数据库: pg_ctl restart -D /usr/local/pgsql/data
停止数据库:pg_ctl stop -D /usr/local/pgsql/data
强制重启:pg_ctl restart -D /usr/local/pgsql/data
强制停止:pg_ctl stop -D /usr/local/pgsql/data
加载配置:pg_ctl reload -D /usr/local/pgsql/data
显示服务状态:pg_ctl status -D /usr/local/pgsql/data
连接数据库: psql -h 127.0.0.1 -U postgres -p 5432 -d postgres -W

四、PG开机自启动

1、根据centos特性制作开机启动(不推荐)

       不推荐原因:在安装好PostGIS后,创建扩展报错:ERROR:  could not load library "/usr/local/pgsql/lib/postgis-3.so": libgeos_c.so.1: cannot open shared object file: No such file or directory

建立服务文件
vi /lib/systemd/system/postgres.service
[Unit]  
    Description=PostgreSQL database server
    After=remote-fs.target nss-lookup.target  
    After=network.target sshd.service
    After=proc-fs-nfsd.mount
    After=network.target local-fs.target
    After=nfs-config.service
    After=nfs-mountd.service
    After=nfs-blkmap.service
    After=nfs-client.target
    After=nfs-config.service
    After=nfs-idmapd.service
    After=nfs-idmap.service
    After=nfs-lock.service
    After=nfslock.service
    After=nfs-mountd.service
    After=nfs-secure-server.service
    After=nfs-secure.service
    After=nfs.service
    After=nfs-utils.service
[Service]  
    Type=forking  
    User=postgres
    Group=postgres
    Environment=PGPORT=5432
    Environment=PGDATA=/usr/local/pgsql/data
    ExecStart=/usr/local/pgsql/bin/pg_ctl start -D ${PGDATA} -s -o "-p ${PGPORT}" -w -t 300
    ExecStop=/usr/local/pqsql/bin/pg_ctl stop -D ${PGDATA} -s -m fast
    ExecReload=/usr/local/pgsql/bin/pg_ctl reload -D ${PGDATA} -s  
    TimeoutSec=300  
[Install]  
WantedBy=remote-fs.target
设置开机自启动
systemctl enable postgres.service

2、PostgreSQL自带的开机自启动脚本(强烈推荐)

  • PostgreSQL的开机自启动脚本位于PostgreSQL源码目录的contrib/start-scripts路径下,linux文件即为linux系统上的启动脚本:

image

  • 将Linux文件复制到 /etc/init.d 目录下,并且将其重名为postgresql

# cp linux /etc/init.d/postgresql
image
  • 进入 /etc/init.d 目录下,修改postgresql文件

# cd /etc/init.d/

# vi postgresql

  • 然后做以下修改:

将prefix设置为postgresql的安装路径:/usr/local/pgsql

将PGDATA设置为postgresql的数据目录路径:/usr/local/pgsql/data

将PGUSER设置为postgresql的用户:postgres

将PGLOG 设置为 postgresql 的数据目录的日志文件夹下:$PGDATA/pg_log/serverlog

image

保存退出!

  • 创建pg_log文件夹并设置权限

image

  • 添加到开机启动

修改文件属性:

# chmod a+x postgresql

添加开机启动:

#将该脚本注册为开机启动
chkconfig --add postgresql
#设置开机启动
chkconfig postgresql on

image

注意: 如果使用 systemctl start postgresql 命令启动失败,查看状态时出现以下错误,有可能是在安装centos系统默认安装了postgresql数据库。

[root@localhost ~]# systemctl status postgresql
● postgresql.service - SYSV: PostgreSQL RDBMS
   Loaded: loaded (/etc/rc.d/init.d/postgresql; bad; vendor preset: disabled)
   Active: failed (Result: exit-code) since 五 2021-07-23 11:14:46 CST; 4min 13s ago
     Docs: man:systemd-sysv-generator(8)

7月 23 11:14:46 localhost.localdomain systemd[1]: Starting PostgreSQL database server...
7月 23 11:14:46 localhost.localdomain systemd[1]: postgresql.service: control process exited, code=exited status=1
7月 23 11:14:46 localhost.localdomain systemd[1]: Failed to start PostgreSQL database server.
7月 23 11:14:46 localhost.localdomain systemd[1]: Unit postgresql.service entered failed state.
7月 23 11:14:46 localhost.localdomain systemd[1]: postgresql.service failed.

解决办法:使用  yum remove postgresql  命令把系统自带的数据库卸载即可。

  • 服务正常开启,重启机器测试:

重启之后,开机,服务正常开启:

image

其它操作

启动postgresql

systemctl start postgresql 查看postgresql状态: systemctl status postgresql 停止服务: systemctl stop postgresql aux|grep java如果出现错误可以使用如下命令查看日志: journalctl -u postgresql

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值