1. 先需要下载相应的rpm包

地址

https://pkgs.org/search/?q=postgresql12

一般至少要下载如下四个包

postgresql12-12.3-1PGDG.rhel7.x86_64.rpm
postgresql12-contrib-12.3-1PGDG.rhel7.x86_64.rpm
postgresql12-libs-12.3-1PGDG.rhel7.x86_64.rpm
postgresql12-server-12.3-1PGDG.rhel7.x86_64.rpm

#注意 PGDG 应该是安装资源库的 可以不安装
#contrib 是安装扩展的 没有这个包就没有 ossp-uuid的插件了
#server 是数据库的安装文件
#libs 用来客户端进行连接.
#注意 如果是centos8 的话 选择 rhel8 进行下载就可以了.

根据 搜索下来安装即可

注意现在最新版本是 12.3

2. 进入到linux内的下载目录执行

yum localinstall *.rpm

不需要联网就可以安装成功:

3. 查看数据库服务

注意安装完pg12数据库之后会自动创建一个服务,可以看一下服务的状态. 建完库可能是无法使用的.

[root@CentOS76 PG12]# systemctl status postgresql-12
● postgresql-12.service - PostgreSQL 12 database server
Loaded: loaded (/usr/lib/systemd/system/postgresql-12.service; disabled; vendor preset: disabled)
Active: failed (Result: exit-code) since Tue 2020-05-26 13:15:00 CST; 4min 18s ago
Docs: https://www.postgresql.org/docs/12/static/
Process: 7355 ExecStartPre=/usr/pgsql-12/bin/postgresql-12-check-db-dir ${PGDATA} (code=exited, status=1/FAILURE) May 26 13:15:00 CentOS76 systemd[1]: Starting PostgreSQL 12 database server...
May 26 13:15:00 CentOS76 systemd[1]: postgresql-12.service: control process exited, code=exited status=1
May 26 13:15:00 CentOS76 systemd[1]: Failed to start PostgreSQL 12 database server.
May 26 13:15:00 CentOS76 systemd[1]: Unit postgresql-12.service entered failed state.
May 26 13:15:00 CentOS76 systemd[1]: postgresql-12.service failed.

查看一下上面的 service 文件就可以执行创建库的操作了

注意这个里面的配置信息为:

[Unit]
Description=PostgreSQL 12 database server
Documentation=https://www.postgresql.org/docs/12/static/
After=syslog.target
After=network.target [Service]
Type=notify User=postgres
Group=postgres # Note: avoid inserting whitespace in these Environment= lines, or you may
# break postgresql-setup. # Location of database directory
Environment=PGDATA=/var/lib/pgsql/12/data/ # Where to send early-startup messages from the server (before the logging
# options of postgresql.conf take effect)
# This is normally controlled by the global default set by systemd
# StandardOutput=syslog # Disable OOM kill on the postmaster
OOMScoreAdjust=-1000
Environment=PG_OOM_ADJUST_FILE=/proc/self/oom_score_adj
Environment=PG_OOM_ADJUST_VALUE=0 ExecStartPre=/usr/pgsql-12/bin/postgresql-12-check-db-dir ${PGDATA}
ExecStart=/usr/pgsql-12/bin/postmaster -D ${PGDATA}
ExecReload=/bin/kill -HUP $MAINPID
KillMode=mixed
KillSignal=SIGINT # Do not set any timeout value, so that systemd will not kill postmaster
# during crash recovery.
TimeoutSec=0 [Install]
WantedBy=multi-user.target

注意有两个目录 一个是数据目录, 一个是程序目录

记住这两个目录就可以进行其他操作了.

4. 初始数据库

切换到PG的用户
su - postgres

切换到 PG 的默认程序目录
cd /usr/pgsql-12/bin/

执行初始化数据库的脚本
./initdb -D
/var/lib/pgsql/12/data/

5. 然后退回到 root 用户 打开服务,并且设置服务自动启动操作.

systemctl enable  postgresql-12 && systemctl restart postgresql-12

6.修改数据库密码.

su - postgres
进入postgresql 数据库
执行命令
psql
修改管理员的密码:
alter role postgres with password 'Test1127?!';

7. 修改连接池大小以及设置其他机器可以远程访问.

修改默认配置文件
vim /var/lib/pgsql/12/data/pg_hba.conf
在客户端安全配置的地方增加一行. host all all 0.0.0.0/0 md5
# 注意 trust 就是默认免密, md5 是默认加密.
修改数据库其他配置信息
vim /var/lib/pgsql/12/data/postgresql.conf

# 监听所有地址的请求 注意测试环境可以,开发环境需要与防火墙一同设置, 将listen_addresses 后面的localhost 修改为 * 并且去掉前面的注释.
listen_addresses = '*' 
注意也需要同步将port 前面的注释去掉.

# 修改 连接数 可以将max_connections的数值改大.

max_connections = 1000

8. 重启服务就可以使用了.

systemctl restart  postgresql-12

CentOS7 RPM离线安装PG12的办法的更多相关文章

  1. CentOS使用rpm离线安装mariadb

    本文不再更新,可能存在内容过时的情况,实时更新请移步原文地址:CentOS使用rpm离线安装mariadb: 环境: CentOS Linux release 7.6.1810 (Core) mari ...

  2. centos 6.4 mysql rpm 离线安装【备忘】

    离线状态下使用rpm的安装包进行mysql的安装,仅作备忘 准备工作: 官网下载mysql离线rpm安装包(这里就不演示了,拿现成的做演示) =================更新线 2018-01- ...

  3. 【从零开始搭建K8S】【第一篇】CentOS7.6离线安装Docker(手动安装以及基于yum本地源安装)

    下载CentOS7.6以及最小化安装CentOS7.6版本.由于CentOS属于开源软件,在国内也有很多的mirror站点可供下载,我选择的是华为站点进行下载:http://mirrors.huawe ...

  4. CentOS7.6离线安装MySql5.7

    准备好mysql的离线安装文件: MySql官网下载mysql-5.7.25-1.el7.x86_64.rpm-bundle,并复制到/usr/mysql文件夹中. 删除CentOS自带的MariaD ...

  5. centos7.6离线安装mysql5.7(附下载链接)

    本来打算直接用原生yum源安装,但是跨国访问网络太慢,只好采用离线安装的方式,原理就是把所需的rpm下载下来再上传服务器安装. 1.rpm文件下载地址: 目录: http://repo.mysql.c ...

  6. Chrome 离线安装插件的办法

    参考url 学习网址 https://blog.csdn.net/weixin_39068791/article/details/81411938 插件下载地址: http://www.lanfans ...

  7. CentOS7.6离线安装docker

    2019/10/24,docker 摘要:CentOS 7.6中离线安装docker 18.06.3以及docker-compose 1.24.1 在线安装可参照 文档 所需环境 1.CentOS 7 ...

  8. centos7.5 离线安装ntp服务

    安装 #检查rpm包 rpm -qa | grep ntp #从https://pkgs.org/download/ntp 下载rpm包 ntp-4.2.6p5-28.el7.centos.x86_6 ...

  9. Centos7.4 离线安装httpd(解决rpm依赖)

    1.直接下载httpd的rpm安装包,安装失败需要先解决依赖. [root@node06 ~]# rpm -ivh httpd--.el7.centos.x86_64.rpm warning: htt ...

  10. Centos7中离线安装DockerCE最新版

    一.简述 离线在Centos7中部署DockerCE. 二.步骤 (1)在有外网的计算A上执行: 1.配置安装源存放路径 mkdir -p /root/docker-ce-local &&am ...

随机推荐

  1. Spark-submit执行流程,了解一下

    摘要:本文主要是通过Spark代码走读来了解spark-submit的流程. 1.任务命令提交 我们在进行Spark任务提交时,会使用"spark-submit -class .....&q ...

  2. 一起学习ML和DL中常用的几种loss函数

    摘要:本篇内容和大家一起学习下机器学习和深度学习中常用到的几种loss函数. 本文分享自华为云社区<[MindSpore易点通]网络实战之交叉熵类Loss函数>,作者:Skytier . ...

  3. APP违法使用个人信息?不用怕,华为云VSS为你保驾护航

    摘要:华为云VSS漏洞扫描服务移动应用安全检测,为华为云客户提供移动应用的合规检测能力,遵循工信部164号文要求,针对安卓(apk)和鸿蒙(hap)应用进行安全和隐私合规问题检测. 本文分享自华为云社 ...

  4. 操作滚动条小结:scrollIntoView/animate等方法的来龙去脉

    操作滚动条可以通过锚点跳转,JS操作滚动条,与scrollIntoView等方法.对此,我来考古一下. 锚点跳转滚动滚动条 网页中的锚点跳转是HTML早期功能之一,锚点(anchor)跳转是1991年 ...

  5. JS遍历循环方法性能对比:for/while/for in/for of/map/foreach/every

    这周codeReview例会,又遇到map与foreach到底谁问题.单独图方便,我会选择用map一个函数搞定一切.但是从语义的角度来讲,如果只是单纯遍历,还是推荐选择foreach.其实formap ...

  6. html5鼠标拖动排序及resize实现方案分析及实践

    对列表进行拖动排序,尺寸改变.之前一般会使用jQuery-UI.其通过mousedown.mousemove.mouseup这三个事件来实现页面元素被鼠标拖拽的效果.vue-drag-resize v ...

  7. -source 1.5 中不支持静态接口方法调用

    -source 1.5 中不支持静态接口方法调用 (请使用 -source 8 或更高版本以启用静态接口方法调用) File -> Project Structure File -> Se ...

  8. pip 的高阶玩法

    pip 的高阶玩法 pip 应该是大家最熟悉的 Python 包安装与管理工具了,但是除了pip install 这个最常用的命令,还有很多有用的玩法.这里就介绍几个我平时会用到的,希望对大家有所帮助 ...

  9. 命令行状态下切换盘符 cd 跨盘

    这个经常忘记,在这记下来 cd /d d: 就是加上/d参数

  10. Codeforces Round #666 (Div. 2) 题解报告

    https://codeforces.com/contest/1397/problem/A 题意: 给定n个字符串,问重新组合以后是否能构成相同的n个字符串 思路: 直接判断所给的字符串的每种字母是否 ...