debian

Debian下PostgreSQL集群搭建

小樊
37
2025-07-12 07:46:39
栏目: 云计算

在Debian系统上搭建PostgreSQL集群,通常指的是配置一个高可用的PostgreSQL集群,以确保数据库服务的连续性和数据的一致性。以下是一个基本的步骤指南,用于在Debian上设置一个简单的PostgreSQL集群:

1. 安装PostgreSQL

首先,确保你的Debian系统是最新的,并且已经安装了必要的依赖包。

sudo apt update
sudo apt upgrade
sudo apt install postgresql postgresql-contrib

2. 配置PostgreSQL

编辑PostgreSQL的主配置文件/etc/postgresql/<version>/main/postgresql.confpg_hba.conf

例如,你可以设置监听地址为所有接口:

# /etc/postgresql/<version>/main/postgresql.conf
listen_addresses = '*'

3. 初始化集群

如果你是第一次安装PostgreSQL,可以使用initdb命令初始化一个新的集群。

sudo systemctl stop postgresql
sudo pg_dropcluster <version> main --stop
sudo pg_createcluster <version> main --start

4. 配置复制

PostgreSQL支持多种复制方式,包括流复制、逻辑复制等。这里我们以流复制为例。

主节点配置

编辑主节点的postgresql.conf文件:

# /etc/postgresql/<version>/main/postgresql.conf
wal_level = replica
max_wal_senders = 10
wal_keep_segments = 64
hot_standby = on

编辑pg_hba.conf文件,允许从节点连接:

# /etc/postgresql/<version>/main/pg_hba.conf
host    replication     replicator     <replica_ip>/32    md5

重启主节点服务:

sudo systemctl restart postgresql

从节点配置

在从节点上,停止PostgreSQL服务并初始化数据目录:

sudo systemctl stop postgresql
sudo pg_dropcluster <version> main --stop
sudo mkdir -p /var/lib/postgresql/<version>/main
sudo chown postgres:postgres /var/lib/postgresql/<version>/main
sudo chmod 700 /var/lib/postgresql/<version>/main
sudo su - postgres

使用pg_basebackup命令从主节点备份数据到从节点:

pg_basebackup -h <master_ip> -U replicator -D /var/lib/postgresql/<version>/main -P --wal-method=stream --verbose

编辑从节点的postgresql.conf文件:

# /etc/postgresql/<version>/main/postgresql.conf
hot_standby = on

编辑recovery.conf文件(在较新的PostgreSQL版本中可能是postgresql.auto.conf):

# /var/lib/postgresql/<version>/main/recovery.conf
standby_mode = 'on'
primary_conninfo = 'host=<master_ip> dbname=postgres user=replicator password=<password>'
restore_command = 'cp /var/lib/postgresql/wal_archive/%f %p'

启动从节点服务:

sudo systemctl start postgresql

5. 验证集群

在主节点上创建一个测试数据库和表:

CREATE DATABASE testdb;
CREATE TABLE test (id SERIAL PRIMARY KEY, name VARCHAR(100));
INSERT INTO test (name) VALUES ('Test Data');

在从节点上检查是否同步成功:

SELECT * FROM test;

如果一切正常,你应该能够看到相同的数据。

注意事项

以上步骤提供了一个基本的PostgreSQL集群搭建指南,实际生产环境中可能需要更多的配置和优化。

0
看了该问题的人还看了