PostgreSQL v12.0在Centos7手动安装
一、官网下载源代码
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
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析