postgresql流复制配置

前端之家收集整理的这篇文章主要介绍了postgresql流复制配置前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

流复制搭建

一、配置环境:

示例环境

主机名

IP

角色

系统版本

数据目录

pg版本

db1

192.168.128.128

主库

RedHat5.3

/app/postgresql/data

9.1.7

db2

192.168.129.129

备库

RedHat5.3

/app/postgresql/data

9.1.7

二、postgresql安装(略)

主库完全安装。备库安装只需要到makeinstall即可不需要initdb。

三、主库配置(在192.168.128.128操作配置)

1、创建复制角色

postgres=#createuserrepreplicationloginconnectionlimit100encryptedpassword'rep123';

CREATEROLE

2、配置pg_hba.conf

hostreplicationrep192.168.128.129/32md5

hostallall192.168.128.1/32trust

3、配置postgresql.conf

wal_level=hot_standby

archive_mode=on

archive_command='/bin/date'

wal_keep_segments=256

max_wal_senders=32

max_standby_archive_delay=300s

max_standby_streaming_delay=300s

wal_receiver_status_interval=10s

hot_standby_Feedback=on

hot_standby=on

/app/postgresql/bin/pg_ctlrestart

/app/postgresql/bin/pg_ctlreload-D/app/postgresql/data

四、备库配置(在192.168.128.129)上进行操作

1、创建目录

创建于主库相同的目录并授权如data目录以及后来创建的表空间目录

2、创建密码文件

[postgres@db2~]$vi.pgpass

192.168.128.128:5432:replication:rep:rep123

[postgres@db2~]$chmod0600.pgpass

3pg_basebackup

[postgres@db2~]$/app/postgresql/bin/pg_basebackup-Fp-D/app/postgresql/data-h192.168.128.128-p5432-Urep

[postgres@db2data]$cp/app/postgresql/share/postgresql/recovery.conf.samplerecovery.conf

4修改recovery.conf配置

standby_mode=on

primary_conninfo='host=192.168.128.128port=5432user=rep'

trigger_file='/app/postgresql/data/postgresql.trigger.5432'

五、启动服务

/app/postgresql/bin/pg_ctlstart-D/app/postgresql/data

1、主库进程

[postgres@db1~]$ps-ef|greppostgres

postgres1117413893004:13?00:00:00postgres:walsenderprocessrep192.168.128.129(49028)streaming0/30001D0

postgres1118713984004:16pts/100:00:00ps-ef

postgres1118813984004:16pts/100:00:00greppostgres

postgres138931003:46pts/100:00:00/app/postgresql/bin/postgres

postgres1389513893003:46?00:00:00postgres:writerprocess

postgres1389613893003:46?00:00:00postgres:walwriterprocess

postgres1389713893003:46?00:00:00postgres:autovacuumlauncherprocess

postgres1389813893003:46?00:00:00postgres:archiverprocesslastwas000000010000000000000002.00000020.backup

postgres1389913893003:46?00:00:00postgres:statscollectorprocess

root1392113890002:10pts/100:00:00su-postgres

postgres1392213921002:10pts/100:00:00-bash

root1398313951002:11pts/100:00:00su-postgres

postgres1398413983002:11pts/100:00:00-bash

2、备库进程

[postgres@db2~]$ps-ef|greppostgres

postgres108551004:10pts/100:00:00/app/postgresql/bin/postgres-D/app/postgresql/data

postgres1085610855004:10?00:00:00postgres:startupprocessrecovering000000010000000000000003

postgres1085710855004:10?00:00:01postgres:walreceiverprocessstreaming0/3000260

postgres1085810855004:10?00:00:00postgres:writerprocess

postgres1085910855004:10?00:00:00postgres:statscollectorprocess

postgres1086913863004:15pts/100:00:00ps-ef

postgres1087013863004:15pts/100:00:00greppostgres

root138623671002:14pts/100:00:00su-postgres

postgres1386313862002:14pts/100:00:00-bash

六、测试

1主库建表插入数据

[postgres@db1~]$/app/postgresql/bin/psql

psql(9.1.7)

Type"help"forhelp.

^

postgres=#createtabletest(idinteger);

CREATETABLE

^

postgres=#insertintotestvalues(1);

INSERT01

postgres=#select*fromtest;

id

----

1

(1row)

2备库查看数据是否传输。

[postgres@db2~]$/app/postgresql/bin/psql

psql(9.1.7)

Type"help"forhelp.

postgres=#select*fromtest;

id

----

1

(1row)

postgres=#

猜你在找的Postgre SQL相关文章