實驗環境
創新互聯建站專注為客戶提供全方位的互聯網綜合服務,包含不限于網站制作、做網站、依蘭網絡推廣、小程序定制開發、依蘭網絡營銷、依蘭企業策劃、依蘭品牌公關、搜索引擎seo、人物專訪、企業宣傳片、企業代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們最大的嘉獎;創新互聯建站為所有大學生創業者提供依蘭建站搭建服務,24小時服務熱線:18982081108,官方網址:m.newbst.com
名稱 | IP | 系統 |
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 -y
2.主從配置
2.1 主數據庫配置
啟動master
/etc/init.d/postgresql-9.6 initdb /etc/init.d/postgresql-9.6 start su - postgres psql
授權
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 #可以設置最多幾個流復制鏈接,差不多有幾個從,就設置多少 wal_keep_segments = 10240 #重要配置 wal_send_timeout = 60s max_connections = 512 #從庫的 max_connections要大于主庫 archive_mode = on #允許歸檔 archive_command = 'cp %p /url/path%f' #根據實際情況設置
2.2 從數據庫配置
su - postgres
如果開始為啟動數據庫可忽略下一步
rm -rf /var/lib/pgsql/9.6/data/* #開始沒有啟動從數據庫,這一步可以省略 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' #主從切換時后的觸發文件 recovery_target_timeline = 'latest'
配置postgresql.conf文件
listen_addresses = 172.17.10.189 wal_level = hot_standby max_connections = 1000 #一般從的最大鏈接要大于主的。 hot_standby = on #說明這臺機器不僅僅用于數據歸檔,也用于查詢 max_standby_streaming_delay = 30s wal_receiver_status_interval = 10s #多久向主報告一次從的狀態。 hot_standby_feedback = on #如果有錯誤的數據復制,是否向主進行范例
檢測
select client_addr,sync_state from pg_stat_replication;
查看主從狀態
select * from pg_stat_replication;
腳本監控主從
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 fi
2.3主從切換
主庫查看進程為sender
備庫
停止主庫
查看slave的日志
創建觸發文件,切換主
touch trigger.kenyon
查看slave的日志,面前已經切換為主
使用pg_controldata
備機狀態為: in archive recovery
主庫狀態為:in production
當前題目:Postgresq9.6主從部署
當前地址:http://m.newbst.com/article14/jeicge.html
成都網站建設公司_創新互聯,為您提供電子商務、網站制作、定制網站、域名注冊、外貿建站、品牌網站設計
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯