pgpool安装配置

安装环境:

系统debian-6.0.4

数据库:postgresql-9.3

pgpool:pgpool-II-3.3.1

pgpool机器

pgpool ip:172.16.2.150

pgpool ip:172.16.2.151

两台流复制机器

Mast:172.16.2.151

slave:172.16.2.152

中文手册:http://www.pgpool.net/docs/latest/pgpool-zh_cn.html

#########################################################################################

安装postgresql-9.3

vi /etc/apt/sources.list.d/pgdg.list

deb http://apt.postgresql.org/pub/repos/apt/ squeeze-pgdg main

vi /etc/apt/sources.list

deb-src http://ftp.debian.org/debian/ squeeze-updates main

deb http://ftp.tw.debian.org/debian wheezy main

wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | apt-key add -

apt-get update

过程中会报错

W: There is no public key available for the following key IDs:

8B48AD6246925553

解决: gpg --keyserver subkeys.pgp.net --recv 8B48AD6246925553

gpg --export --armor 8B48AD6246925553 | apt-key add -

apt-get update

aptitude install postgresql-9.3

#########################################################################################

安装pgpool-II-3.3.1

安装编译环境

aptitude install build-essential

tar -zxvf pgpool-II-3.3.1.tar.gz

cd pgpool-II-3.3.1

./configure

make

make install

#########################################################################################

编译过程中会报没有postgresql-server-dev-X.Y错误

aptitude install flex

aptitude install postgresql-server-dev-9.3

aptitude install postgresql-contrib-9.3

#########################################################################################

master配置

vi /etc/postgresql/9.3/main/postgresql.conf

listen_addresses = '*'

vi /etc/postgresql/9.3/main/pg_hba.conf 加入以下

host all all 127.0.0.1/32 trust

host all all 172.16.2.0/32 trust

host all all 172.16.2.152/32 trust

host all all 172.16.2.151/32 trust

host all all 172.16.2.150/32 trust

cp /usr/local/etc/pgpool.conf.sample /usr/local/etc/pgpool.conf

cd /usr/local/etc

vi pgpool.conf

修改如下

listen_addresses = '*'

parallel_mode = off

load_balance_mode = on

socket_dir = '/var/run/postgresql'

pcp_socket_dir = '/var/run/postgresql'

pid_file_name = '/var/run/postgresql/pgpool.pid'

backend_hostname0 = '172.16.2.151'

backend_port0 = 5432

backend_weight0 = 9

backend_data_directory0 = '/var/lib/postgresql/9.3/main/'

backend_hostname1 = '172.16.2.152'

backend_port1 = 5432

backend_weight1 = 9

backend_data_directory1 = '/var/lib/postgresql/9.3/main/'

backend_flag1 = 'ALLOW_TO_FAILOVER'

#########################################################################################

cp pool_hba.conf.sample pool_hba.conf

vi pool_hba.conf

# IPv4 local connections:

host all all 127.0.0.1/32 trust

host all all 172.16.2.0/32 trust

host all all 172.16.2.152/32 trust

host all all 172.16.2.151/32 trust

host all all 172.16.2.150/32 trust

#########################################################################################

su postgres

createuser -p 5432 pgpool

createdb -p 5432 -O pgpool pgpool

cp pcp.conf.sample pcp.conf

/usr/local/bin/pg_md5 postgres

vi pcp.conf

加入如下:

postgres:e8a48653851e28c69d0506508fb27fc5

#########################################################################################

pgpool看门狗配置

172.16.2.150上的配置采用心跳模式(查询模式则注释掉)

vi pgpool.conf

需要修改的地方如下

use_watchdog = on

trusted_servers = '172.16.2.151,172.16.2.152'

wd_hostname = '172.16.2.150'

# - Virtual IP control Setting -

delegate_IP = '172.16.2.153'(虚拟ip,也就是两台pgpool对外的ip地址)

# -- heartbeat mode --

heartbeat_destination0 = '172.16.2.150'

heartbeat_destination1 = '172.16.2.151'

# -- query mode --

此模式下注释掉

# - Other pgpool Connection Settings -

other_pgpool_hostname1 = '172.16.2.151'(指定需要监控的 pgpool-II 服务器主机)

other_wd_port1 = 9000

172.16.2.151上配置同样采用心跳模式

需要修改的地方如下

vi pgpool.conf

use_watchdog = on

trusted_servers = '172.16.2.151,172.16.2.152'

wd_hostname = '172.16.2.151'

# - Virtual IP control Setting -

delegate_IP = '172.16.2.153'(虚拟ip,也就是两台pgpool对外的ip地址)

# -- heartbeat mode --

heartbeat_destination0 = '172.16.2.150'

heartbeat_destination1 = '172.16.2.151'

# -- query mode --

此模式下注释掉

# - Other pgpool Connection Settings -

other_pgpool_hostname0 = '172.16.2.150'(指定需要监控的 pgpool-II 服务器主机)

other_wd_port0 = 9000

#########################################################################################

启动pgpool

在此过程中先启动的则会成为主,另一台作为备机启动没有先后顺序

/usr/local/bin/pgpool -dn -f /usr/local/etc/pgpool.conf -a /usr/local/etc/pool_hba.conf -F /usr/local/etc/pcp.conf