一、官网下载源代码
https://www.postgresql.org/ftp/source/v12.0/
二、安装步骤
新建文件夹 把源代码 postgresql-12.0.tar.gz 放到/opt 目录下 注意:安装gcc:yum install gcc* 2.编译前设置,主要是设置安装目录 |
三、其它操作
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
查看防火墙状态
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系统上的启动脚本:
将Linux文件复制到 /etc/init.d 目录下,并且将其重名为postgresql
# cp linux /etc/init.d/postgresql
进入 /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
保存退出!
创建pg_log文件夹并设置权限
添加到开机启动
修改文件属性:
# chmod a+x postgresql
添加开机启动:
#将该脚本注册为开机启动
chkconfig --add postgresql
#设置开机启动
chkconfig postgresql on
注意: 如果使用 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 命令把系统自带的数据库卸载即可。
服务正常开启,重启机器测试:
重启之后,开机,服务正常开启:
其它操作
启动postgresql
systemctl start postgresql
查看postgresql状态:
systemctl status postgresql
停止服务:
systemctl stop postgresql
aux|grep java如果出现错误可以使用如下命令查看日志:
journalctl -u postgresql