PostgreSQL环境搭建和主备构建

news/2025/3/14 21:34:45/

目录

  • 1 Windows 上安装 PostgreSQL
  • 2 docker安装PostgreSQL
    • 2.1 检索当前镜像
    • 2.2. 拉取当前镜像
    • 2.3 创建挂载文件夹
    • 2.4 启动镜像
    • 2.5 查看日志
    • 2.7 查看进程
    • 2.8 使用连接
  • 3 postgresql主从主备搭建
    • 3.1 安装好网络源(主1.11、从1.12)
    • 3.2 安装postgresql(主、从)
    • 3.3 创建数据目录(主、从)
    • 3.4 修改systemd管理启动脚本(主)
    • 3.5 修改数据目录属组(主、从)
    • 3.6 初始化数据库(主)
    • 3.7 修改配置文件(主)
    • 3.8 重启数据库(主)
    • 3.9 修改postgres用户密码,创建主从复制用户(主)
    • 3.10 执行主库基础备份(从)
    • 3.11 启动备库(从)


1 Windows 上安装 PostgreSQL

postgreSQL

这里使用 EnterpriseDB 来下载安装,EnterpriseDB 是全球唯一一家提供基于 PostgreSQL 企业级产品与服务的厂商。

下载地址:https://www.enterprisedb.com/downloads/postgres-postgresql-downloads。

img

双击下载安装包,开始安装

img

你可以修改安装路径

img

选择安装组件,不懂的选就是全部勾上:

img

设置数据库路径

img

设置超级用户的密码

img

设置端口号,可以直接用默认就行

img

直接点 Next

img

点 Next

img

去掉勾选,直接点 Finish

img

打开 pgAdmin 4

img

pgAdmin 主页如下

img

点击左侧的 Servers > Postgre SQL 10

img

输入密码,点击 OK 即可

img

控制面板如下

img

打开 SQL Shell(psql)

img

2 docker安装PostgreSQL

2.1 检索当前镜像

$ docker search postgres

20220705152209

列名列描述
NAME镜像名称
DESCRIPTION镜像描述
STARS标星数
OFFICIAL官方的
AUTOMATED自动化

话不多说,肯定选官方提供的镜像,同事它也是标星数量最多的。

2.2. 拉取当前镜像

不带版本号,代表为当前阶段最新的,如果需要指定的版本,请使用 docker pull postgres:${VERSION} 其中 ${VERSION} 代表你需要的版本号。

此处演示需要直接用最新版本。

$ docker pull postgres

pull 镜像后,查看镜像

$ docker images

20220705152846

2.3 创建挂载文件夹

在运行 Docker 的系统中,创建一个可以挂在 PostgreSQL 数据文件的地方,方便后面做数据迁移等工作。

此处演示需要,使用了 /data/postgres 当作挂在文件的目录。

[root@localhost ~]$ cd /data/
[root@localhost data]$ mkdir postgres
[root@localhost postgres]$ pwd
/data/postgres

2.4 启动镜像

docker run --name postgresql --privileged -e POSTGRES_PASSWORD=password -p 15433:5432 -v /data/postgres:/var/lib/postgresql/data -d postgres

2.5 查看日志

20220705155606

PostgreSQL Database directory appears to contain a database; Skipping initialization2022-07-05 07:36:51.259 UTC [1] LOG:  starting PostgreSQL 14.1 (Debian 14.1-1.pgdg110+1) on x86_64-pc-linux-gnu, compiled by gcc (Debian 10.2.1-6) 10.2.1 20210110, 64-bit
2022-07-05 07:36:51.261 UTC [1] LOG:  listening on IPv4 address "0.0.0.0", port 5432
2022-07-05 07:36:51.261 UTC [1] LOG:  listening on IPv6 address "::", port 5432
2022-07-05 07:36:51.264 UTC [1] LOG:  listening on Unix socket "/var/run/postgresql/.s.PGSQL.5432"
2022-07-05 07:36:51.271 UTC [26] LOG:  database system was interrupted; last known up at 2022-07-05 07:24:38 UTC
2022-07-05 07:36:51.292 UTC [26] LOG:  database system was not properly shut down; automatic recovery in progress
2022-07-05 07:36:51.294 UTC [26] LOG:  redo starts at 0/16FAFF0

2.7 查看进程

docker ps -a

20220705154046

2.8 使用连接

测试数据库是否连接成功,用户名为 postgres;密码为: password。

20220705155631

20220705155819

3 postgresql主从主备搭建

3.1 安装好网络源(主1.11、从1.12)

yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm

3.2 安装postgresql(主、从)

yum -y install postgresql13 
yum -y install postgresql13-server

3.3 创建数据目录(主、从)

mkdir /postgres_data

3.4 修改systemd管理启动脚本(主)

vim /usr/lib/systemd/system/postgresql-13.service

将PGDATA修改为创建的数据目录

img

3.5 修改数据目录属组(主、从)

chown postgres:postgres  /postgtes_data

3.6 初始化数据库(主)

su - postgres
/usr/pgsql-13/bin/initdb -D /postgres_data

3.7 修改配置文件(主)

vim /postgres_data/postgresql.conf#修改以下配置信息listen_addresses = '*' port = 5432max_connections = 100 max_wal_size = 1GBmin_wal_size = 80MBlog_timezone = 'Asia/Shanghai'wal_level = replicamax_wal_senders = 10wal_sender_timeout = 60shot_standby = on
vim /postgres_data/pg_hba.conf#添加以下配置host    all             all             0.0.0.0/0               md5host    replication    replica           192.168.1.12/32         md5

img

3.8 重启数据库(主)

systemctl restart postgresql-13

3.9 修改postgres用户密码,创建主从复制用户(主)

su - postgres
psql
postgres=# ALTER USER postgres ENCRYPTED PASSWORD '123456';
create user replica replication login connection limit 3 encrypted password '123456';

img

3.10 执行主库基础备份(从)

su - postgres
/usr/pgsql-13/bin/pg_basebackup -h 192.168.1.11 -p 5432 -U replica -P -X stream -D /postgres_data -R

3.11 启动备库(从)

su - postgres
/usr/pgsql-13/bin/pg_ctl -D /postgres_data start 

http://www.ppmy.cn/news/48127.html

相关文章

Python OpenCV 3.x 示例:1~5

原文:OpenCV 3.x with Python By Example 协议:CC BY-NC-SA 4.0 译者:飞龙 本文来自【ApacheCN 计算机视觉 译文集】,采用译后编辑(MTPE)流程来尽可能提升效率。 当别人说你没有底线的时候,你最…

一定要会的算法复杂度分析

本文首发自「慕课网」,想了解更多IT干货内容,程序员圈内热闻,欢迎关注"慕课网"! 原作者:s09g|慕课网讲师 我们知道面对同一道问题时可能有多种解决方案。自然地,我们会将多种方法进行比较。那么…

同样是测试,朋友到了30k,我才12K,这份测试面试8股文确实牛

程序猿在世人眼里已经成为高薪、为人忠诚的代名词。 然而,小编要说的是,不是所有的程序员工资都是一样的。 世人所不知的是同为程序猿,薪资的差别还是很大的。 众所周知,目前互联网行业是众多行业中薪资待遇最好的,…

Leetcode33.搜索旋转排列数组

搜索旋转排列数组 一、题目描述&#xff1a;二、解决思路和代码1. 解决思路2. 代码 一、题目描述&#xff1a; 整数数组 nums 按升序排列&#xff0c;数组中的值 互不相同 。 在传递给函数之前&#xff0c;nums 在预先未知的某个下标 k&#xff08;0 < k < nums.length…

【Unity VR开发】结合VRTK4.0:添加遮蔽追踪器

语录&#xff1a; 恋爱应该是双方扶持对方共同完成自己的目标&#xff0c;而不是虚幻的思想、肤浅的物质、和纸醉金迷的生活。 前言&#xff1a; 遮蔽追踪器&#xff08;Trackers.ObscuranceTracker&#xff09;是基于游戏对象存在或不可见之间切换对象的状态&#xff0c;从而遮…

Ajax超详解(新手入门指南)

文章目录 1. AJAX简介2. 前后端交互3. XHR3.1 XMLHttpRequest对象3.2 获取模拟的后端数据3.3 获取网络数据3.4 使用json-server模拟服务器3.4.1 安装node.js3.4.2 安装并使用json-server 3.5 常见的请求方式3.5.1 GET请求3.5.2 POST请求3.5.3 PUT请求3.5.4 PATCH请求3.5.5 DELE…

面试题30天打卡-day10

1、String 和 StringBuffer、StringBuilder 的区别是什么&#xff1f; String、StringBuffer、StringBuilder主要的区别在于执行效率和线程安全上。 String&#xff1a;String字符串常量&#xff0c;意味着它是不可变的&#xff0c;导致每次对String都会生成新的String对象&a…

网络工程师经常搞混的路由策略和策略路由,两者到底有啥区别?

当涉及到网络路由时&#xff0c;两个术语经常被混淆&#xff1a;策略路由和路由策略。虽然这些术语听起来很相似&#xff0c;但它们实际上有着不同的含义和用途。在本文中&#xff0c;我们将详细介绍这两个术语的区别和应用。 一、路由策略 路由策略是指一组规则&#xff0c;用…