centos PG集群搭建

一、安装PG

1、安装之前首先查看软件是否已经安装

rpm -qa | grep postgresql

#若存在,需要卸载使用 yum remove postgresql

2、安装postgresql和postgresql-server

能够访问外网

# 获取源
sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm # 安装
sudo yum install -y postgresql12-server

不能访问外网

# 如果不能访问外网,yum是用不了的,卸载原有的pg也只能通过rpm -e 包名 挨个进行删除

# 离线安装
rpm -Uvh --force --nodeps *

3、环境变量

创建目录,给与权限

cd /data/
mkdir pgdata
chown -R postgres:postgres ./pgdata

修改环境变量

vi /usr/lib/systemd/system/postgresql-12.service

# 修改 Environment
Environment=PGDATA=/data/pgdata/ #PGDATA一般是数据盘 # 重载
systemctl daemon-reload

4、启动数据库

# 初始化数据库
/usr/pgsql-12/bin/postgresql-12-setup initdb # 启动
systemctl start postgresql-12

5、创建用户

su - postgres
psql
# 用于pgpool
create role pgpool with login password 'postgres';
# 用于主从
create role repl login replication encrypted password 'postgres'; # 修改postgres密码
alter user postgres with password 'postgres';

二、配置主从

主节点配置

1、pg_hba.conf

# 修改data(/data/pgdata)下面的配置
vi /data/pgdata/pg_hba.conf # 追加
host all all 0.0.0.0/0 md5
host replication repl 本机ip/32 trust
host replication repl 节点1 ip/32 trust #从节点1
...
host replication repl 节点n ip/32 trust #从节点n host all all 本机ip 最后一位替换为0/24 md5

2、postgresql.conf

# 修改data(/data/pgdata)下面的配置
vi /data/pgdata/postgresql.conf # 修改内容
listen_addresses = '*' #开启后子节点才能访问
archive_mode = on
max_connections = 21000
archive_command = 'cp "%p" "/var/lib/pgsql/archivedir/%f"'
max_wal_senders = 10
max_replication_slots = 10
wal_level = replica
hot_standby = on
wal_log_hints = on

从节点配置

1、拉取主库配置

#删除从库data目录下文件
rm ‐rf data/* # 拉取主库配置,主库记得开5432端口
pg_basebackup -h 主节点ip -U repl -D /data/pgdata -X stream -P # 开通端口
iptables -I INPUT -p tcp --dport 5432 -j ACCEPT

2、修改配置文件

# postgresql.conf修改内容
primary_conninfo = 'host=主节点ip port=5432 user=repl(主节点对应账号) password=密码'
recovery_target_timeline = latest
hot_standby = on
max_standby_streaming_delay = 30s
wal_receiver_status_interval = 10s
hot_standby_feedback = on # 12以上版本配置上有些变化
# 1.将recovery.conf文件里的配置合并到主配置文件postgresql.conf中
# 2.设置启用备库参数standby_mode,12之后废弃了这个参数,切换到备库建立空文件standby.signal进行触发。 # standby.signal修改内容
standby_mode = on

3、重启服务

#重启
systemctl restart postgresql-12 #也可以stop再start
systemctl stop postgresql-12
systemctl start postgresql-12

三、验证

# 进入主库
su - postgres
# 进入sql
psql # 查询同步状态,完成的话显示n行
select client_addr,usename,backend_start,application_name,sync_state,sync_priority FROM pg_stat_replication; # 添加数据库
CREATE DATABASE test; # 进入从库查看,发现新的库test
# 执行新建操作,警告only-read

四、其他

# 备份数据库
pg_dump dbname > outfile
# 导入数据库
psql dbname < infile
# 可用于测试主从是否完成
# 添加数据库
CREATE DATABASE test;
# 删除数据库
DROP DATABASE test;
# 查看已安装的软件包
rpm -qa | grep postgresql
# 离线删除软件包
rpm -e 包名

PG集群(PostgreSql环境)搭建的更多相关文章

  1. centos 8 集群Linux环境搭建

    一.集群Linux环境搭建 1. 注意事项 1.1 windows系统确认所有的关于VmWare的服务都已经启动 打开任务管理器->服务,查看五个VM选项是否打开. 1.2 确认好VmWare生 ...

  2. 部署k8s集群之环境搭建和etcd单节点安装

    环境搭建以及etcd 单节点安装过程 安装之前的环境搭建 在进行k8s安装之前先把虚拟机准备好,这里准备的是三台虚拟机 主机名 ip地址 角色 master 172.16.163.131 master ...

  3. hadoop学习笔记(六):hadoop全分布式集群的环境搭建

    本文原创,如需转载,请注明作者以及原文链接! 一.前期准备: 1.jdk安装        不要用centos7自带的openJDK2.hostname    配置       配置位置:/etc/s ...

  4. Dream------spark--spark集群的环境搭建

    1.下载安装scala http://www.scala-lang.org/download/2.11.6.html   2.解压下载后的文件,配置环境变量:编辑/etc/profile文件,添加如下 ...

  5. Hadoop入门(五) Hadoop2.7.5集群分布式环境搭建

    本文接上文内容继续: server01 192.168.8.118 jdk.www.fengshen157.com/ hadoop NameNode.DFSZKFailoverController(z ...

  6. 性能测试:k8s集群监控环境搭建(kube-prometheus)

    选择kube-prometheus版本 k8s集群版本是1.22.x 5个节点 说明:如果你电脑配置低,也可以1个master节点,2个node节点 3个节点 Kube-Prometheus地址:ht ...

  7. MQ集群测试环境搭建(多节点负载均衡,共享一个kahaDB文件(nas方式))

    1. os ubuntu12.04 基础环境准备 干掉不好用的vim重新装 sudo apt-get remove vim-common sudo apt-get install vim 如果需要使用 ...

  8. vagrant+docker搭建consul集群开发环境

    HashiCorp 公司推出的Consul是一款分布式高可用服务治理与服务配置的工具.关于其配置与使用可以参考这篇文章 consul 简介与配置说明. 一般,我们会在多台主机上安装并启动 consul ...

  9. 如何基于Jupyter notebook搭建Spark集群开发环境

    摘要:本文介绍如何基于Jupyter notebook搭建Spark集群开发环境. 本文分享自华为云社区<基于Jupyter Notebook 搭建Spark集群开发环境>,作者:apr鹏 ...

随机推荐

  1. mybaits源码分析--自定义插件(七)

    一.MyBatis插件 插件是一种常见的扩展方式,大多数开源框架也都支持用户通过添加自定义插件的方式来扩展或者改变原有的功能,MyBatis中也提供的有插件,虽然叫插件,但是实际上是通过拦截器(Int ...

  2. ucosii操作系统内核源码学习第一篇

    根据书本理论介绍以及实际看内核源代码得出: 1. 操作系统默认定义了64个TCB块(为全局变量,编译时候以及分配了,创建一个任务就使用一个,删除一个任务就归还一个)(为什么最大只支持64个任务呢,我们 ...

  3. Django——cookie保持登录

    普通登录时,无法保持登录的状态,每一次请求时都需要重新登录. 而在登录时,生成cookie并保存在浏览器中,这样每次登录就会携带登录信息,就可以保持登录状态了. 操作cookie语法: # (1) 设 ...

  4. 关闭Redis服务

    方式1: 方式2:

  5. java 集合特性面试必备

    collection 集合体系 数据结构栈和队列栈结构 :先进后出队列结构 :先进先出 数据结构之数组和链表数组结构:查询快.增删慢队列结构 :查询慢.增删快 List集合概述有序集合(也称为序列), ...

  6. [第十四篇]——Docker Machine之Spring Cloud直播商城 b2b2c电子商务技术总结

    Docker Machine 简介 Docker Machine 是一种可以让您在虚拟主机上安装 Docker 的工具,并可以使用 docker-machine 命令来管理主机. Docker Mac ...

  7. vue-cli3 创建多页面应用项目

    1.创建vue项目 cmd命令执行  vue create ruc-continuing  创建vue项目,项目名称:ruc-continuing 选择一个 preset(预置项),或自定义: 选择自 ...

  8. Spring Cloud Hystrix 学习(二)熔断与降级

    今天来看下Hystrix的熔断与降级. 首先什么是降级?当请求超时.资源不足等情况发生时进行服务降级处理,不调用真实服务逻辑,而是使用快速失败(fallback)方式直接返回一个托底数据,保证服务链条 ...

  9. PHP中的IMAP扩展简单入门

    对于邮件处理来说,大家比较熟悉的应该是 POP3 . SMTP 这类的协议,而今天我们介绍的 IMAP 其实也是非常常用的一种邮件处理协议.它和 POP3 比较类似,都是以接收处理邮件为主.不过相对于 ...

  10. Java基础系列(37)- 数组下标越界及小结

    数组的四个基本特点 其长度是确定的,数组一旦被创建,它的大小就是不可以改变的 其元素必须是相同类型,不允许出现混合类型 数组中的元素可以是任何数据类型,包括基本类型和引用类型 数组变量属于引用类型,数 ...