實(shí)驗(yàn)環(huán)境
成都創(chuàng)新互聯(lián)公司專注于企業(yè)成都全網(wǎng)營(yíng)銷、網(wǎng)站重做改版、南城網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5高端網(wǎng)站建設(shè)、商城網(wǎng)站制作、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)營(yíng)銷網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為南城等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。名稱 | IP | 系統(tǒng) |
Master | 172.17.10.190 | Centos 6.5 |
Slave | 172.17.10.189 | Centos 6.5 |
1.yun安裝
rpm -ivh https://download.postgresql.org/pub/repos/yum/9.6/redhat/rhel-6-x86_64/pgdg-centos96-9.6-3.noarch.rpm yum install postgresql96.x86_64 postgresql96-server.x86_64 -y2.主從配置
2.1 主數(shù)據(jù)庫(kù)配置
啟動(dòng)master
/etc/init.d/postgresql-9.6 initdb /etc/init.d/postgresql-9.6 start su - postgres psql授權(quán)
create role repl login replication encrypted password '51idc.com';編輯hba文件
/var/lib/pgsql/9.6/data/pg_hba.conf
新增
host replication repl 172.17.10.0/24 md5 host all repl 172.17.10.0/24 trust編輯配置文件
/var/lib/pgsql/9.6/data/postgresql.conf
listen_addresses = 172.17.10.190 wal_level = hot_standby #熱備模式 max_wal_senders= 6 #可以設(shè)置最多幾個(gè)流復(fù)制鏈接,差不多有幾個(gè)從,就設(shè)置多少 wal_keep_segments = 10240 #重要配置 wal_send_timeout = 60s max_connections = 512 #從庫(kù)的 max_connections要大于主庫(kù) archive_mode = on #允許歸檔 archive_command = 'cp %p /url/path%f' #根據(jù)實(shí)際情況設(shè)置2.2 從數(shù)據(jù)庫(kù)配置
su - postgres如果開始為啟動(dòng)數(shù)據(jù)庫(kù)可忽略下一步
rm -rf /var/lib/pgsql/9.6/data/* #開始沒有啟動(dòng)從數(shù)據(jù)庫(kù),這一步可以省略 pg_basebackup -h 172.17.10.190 -U repl -D /var/lib/pgsql/9.6/data -X stream -P cp /usr/pgsql-9.6/share/recovery.conf.sample /var/lib/pgsql/9.6/data/recovery.conf修改配置文件recovery.conf
standby_mode = on primary_conninfo = 'host=172.17.10.190 port=5432 user=repl password=51idc.com' trigger_file = '/var/lib/pgsql/9.6/data/trigger.kenyon' #主從切換時(shí)后的觸發(fā)文件 recovery_target_timeline = 'latest'配置postgresql.conf文件
listen_addresses = 172.17.10.189 wal_level = hot_standby max_connections = 1000 #一般從的大鏈接要大于主的。 hot_standby = on #說明這臺(tái)機(jī)器不僅僅用于數(shù)據(jù)歸檔,也用于查詢 max_standby_streaming_delay = 30s wal_receiver_status_interval = 10s #多久向主報(bào)告一次從的狀態(tài)。 hot_standby_feedback = on #如果有錯(cuò)誤的數(shù)據(jù)復(fù)制,是否向主進(jìn)行范例檢測(cè)
select client_addr,sync_state from pg_stat_replication;查看主從狀態(tài)
select * from pg_stat_replication;腳本監(jiān)控主從
github地址
#!/bin/bash # mail xuel@51idc.com data=`date +%Y-%M-%d" "%H:%m` netstat -lntup|grep 5432 && ps -ef|grep postmaster if [ $? -eq 0 ];then for IP in 172.17.10.188 172.17.10.189 do /usr/bin/psql -h 172.17.10.190 -p 5432 -U repl -d postgres --command "select * from pg_stat_replication"|grep $IP if [ "$?" != "0" ];then echo "postgresql master-slave status is error! please login check!"|mail -r "xuel@51idc.com" -s "postgresql master-slave status is error" xuel@51idc.com \ && echo "$data postgresql postgresql master-slave status is error!">>/var/log/postgresql-error.log fi done else echo "postgresql master-slave status is error! please login check!"|mail -r "xuel@51idc.com" -s "postgresql master-slave status is error" xuel@51idc.com \ && echo "$data postgresql postgresql master-slave status is error!">>/var/log/postgresql-error.log fi2.3主從切換
主庫(kù)查看進(jìn)程為sender
備庫(kù)
停止主庫(kù)
查看slave的日志
創(chuàng)建觸發(fā)文件,切換主
touch trigger.kenyon查看slave的日志,面前已經(jīng)切換為主
使用pg_controldata
備機(jī)狀態(tài)為: in archive recovery
主庫(kù)狀態(tài)為:in production
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。