在Debian系统上搭建PostgreSQL集群,通常指的是配置一个高可用的PostgreSQL集群,以确保数据库服务的连续性和数据的一致性。以下是一个基本的步骤指南,用于在Debian上设置一个简单的PostgreSQL集群:
首先,确保你的Debian系统是最新的,并且已经安装了必要的依赖包。
sudo apt update
sudo apt upgrade
sudo apt install postgresql postgresql-contrib
编辑PostgreSQL的主配置文件/etc/postgresql/<version>/main/postgresql.conf
和pg_hba.conf
。
postgresql.conf
:配置数据库服务器的基本参数。pg_hba.conf
:配置客户端认证。例如,你可以设置监听地址为所有接口:
# /etc/postgresql/<version>/main/postgresql.conf
listen_addresses = '*'
如果你是第一次安装PostgreSQL,可以使用initdb
命令初始化一个新的集群。
sudo systemctl stop postgresql
sudo pg_dropcluster <version> main --stop
sudo pg_createcluster <version> main --start
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
在主节点上创建一个测试数据库和表:
CREATE DATABASE testdb;
CREATE TABLE test (id SERIAL PRIMARY KEY, name VARCHAR(100));
INSERT INTO test (name) VALUES ('Test Data');
在从节点上检查是否同步成功:
SELECT * FROM test;
如果一切正常,你应该能够看到相同的数据。
以上步骤提供了一个基本的PostgreSQL集群搭建指南,实际生产环境中可能需要更多的配置和优化。