欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

pgpool復(fù)制和負(fù)載均衡操作

 更新時間:2021年01月11日 14:31:32   作者:木訥大叔愛運(yùn)維  
這篇文章主要介紹了pgpool復(fù)制和負(fù)載均衡操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

簡介

pgpool-II是一個位于postgresql數(shù)據(jù)庫和客戶端之間的中間件,可以提供一下幾個功能:

1.連接池

pgpool-II保持已經(jīng)連接到postgresql數(shù)據(jù)庫的連接,并在使用相同參數(shù)連接進(jìn)來時重用他們,減少了連接開銷,并增加了系統(tǒng)的總體吞吐量。

2.復(fù)制

pgpool-II可以管理多個postgresql數(shù)據(jù)庫,激活復(fù)制功能并使在2臺或多臺postgresql節(jié)點中建立一個實時備份稱為可能,這樣,如果其中一臺節(jié)點失效,服務(wù)可以不被終端繼續(xù)運(yùn)行。

3.負(fù)載均衡

如果數(shù)據(jù)庫進(jìn)行了復(fù)制,則在任何一臺服務(wù)器中執(zhí)行一個select查詢將返回相同的結(jié)果。pgpool-II利用了復(fù)制的功能以降低每臺postgresql服務(wù)器的負(fù)載。它通過分發(fā)select查詢到所有可用的服務(wù)器中,增強(qiáng)了系統(tǒng)的整體吞吐量。在理想的狀況下,讀性能應(yīng)該和postgresql數(shù)量成正比。負(fù)載均衡功能在大量用戶同時執(zhí)行很多讀查詢的場景中工作效果最好。

4.限制超過限度的連接

postgresql會限制當(dāng)前的最大連接數(shù),當(dāng)?shù)竭_(dá)這個數(shù)量時,新的連接將被拒絕。增加這個連接數(shù)會增加資源消耗并且對系統(tǒng)的全局性能有一定的負(fù)面影響。pgpool-II也支持限制最大連接數(shù),但她的做法是將連接放入隊列,而不是立即返回一個錯誤。

另外,pgpool-II也支持并行查詢,數(shù)據(jù)被分割到多臺服務(wù)器上,所以一個查詢可以在多臺服務(wù)器上同時執(zhí)行,以減少總體執(zhí)行時間。并行查詢在查詢大規(guī)模數(shù)據(jù)的時候非常有效。

測試環(huán)境

IP 應(yīng)用 版本
10.10.10.56 postgresql 9.2.15
10.10.10.57 postgresql 9.2.15
10.10.10.56 pgpool-II 3.5

環(huán)境說明:兩臺postgresql,pgpool和其中一臺postgresql在一臺服務(wù)器上。

測試需求:測試pgpool實現(xiàn)postgresql的復(fù)制和負(fù)載均衡

安裝pgpool

1.源碼安裝

wget http://www.pgpool.net/download.php?f=pgpool-II-3.5.3.tar.gz
tar -zxvf pgpool-II-3.5.3.tar.gz 
cd pgpool-II-3.5.3
./configure --prefix=/usr/local/pgpool --with-openssl
#報錯configure: error: libpq is not installed or libpq is old
#安裝 yum install postgresql-devel即可
make && make install

2.安裝pgpool-regclass

使用 PostgreSQL 8.0 至 PostgreSQL 9.3,強(qiáng)烈推薦在需要訪問的 PostgreSQL 中安裝 pgpool_regclass 函數(shù),因為它被 pgpool-II 內(nèi)部使用。 如果不這樣做,在不同的 schema 中處理相同的表名會出現(xiàn)問題(臨時表不會出問題);而PostgreSQL 9.4或更高版本則不需要

cd pgpool-II-3.5.3/src/sql/pgpool-regclass
make && make install

-bash-4.2$ psql -f pgpool-regclass.sql template1
或
psql template1
=# CREATE EXTENSION pgpool_regclass;

應(yīng)在每臺通過 pgpool-II 訪問的數(shù)據(jù)庫中執(zhí)行 pgpool-regclass.sql 或者 CREATE EXTENSION。 你不需要在你執(zhí)行“psql -f pgpool-regclass.sql template1” 或者 CREATE EXTENSION 后建立的數(shù)據(jù)庫中這么做, 因為這個模板數(shù)據(jù)庫將被克隆成新建的數(shù)據(jù)庫。

3.建立insert_lock表

如果你在復(fù)制模式中使用了 insert_lock ,強(qiáng)烈推薦建立 pgpool_catalog.insert_lock 表,用于互斥。 到現(xiàn)在為止,insert_lock 還能夠工作。但是,在這種情況下,pgpool-II 需要鎖定插入的目標(biāo)表。 這種行為和 pgpool-II 2.2 和 2.3 系列類似。由于表鎖與 VACUUM 沖突,所以 INSERT 操作可能因而等待很長時間。

cd pgpool-II-3.5.3/src/sql/
psql -f insert_lock.sql tempalte1

應(yīng)在在每臺通過 pgpool-II 訪問的數(shù)據(jù)庫中執(zhí)行 insert_lock.sql。 你不需要在你執(zhí)行“psql -f insert_lock.sql template1”后建立的數(shù)據(jù)庫中這么做, 因為這個模板數(shù)據(jù)庫將被克隆成新建的數(shù)據(jù)庫。

4.安裝pgpool_recovery

如果你使用在線回復(fù),需要以下一些函數(shù): pgpool_recovery, pgpool_remote_start, pgpool_switch_xlog。

另外,附帶工具pgpoolAdmin 控制 pgpool-II 啟停和重新連接后端的 PostgreSQL 節(jié)點, 它需要函數(shù) pgpool_pgctl;而且 pgpoolAdmin 需要函數(shù) pgpool_pgctl 來對 PostgreSQL 進(jìn)行停止/重啟/重新加載參數(shù)操作。

可以使用和安裝 pgpool_regclass 一樣的方法安裝著四個函數(shù)。 不過和 pgpool_regclass 不同的是,你只需要在 template1 數(shù)據(jù)庫中安裝這些函數(shù)。

cd pgpool-II-3.5.3/src/sql/pgpool-recovery
make && make install
psql -f pgpool-recovery.sql template1
或
psql template1
=# CREATE EXTENSION pgpool_recovery

配置pgpool

1.配置pcp.conf

pgpool提供pcp接口,可以查看,管理pgpool的狀態(tài),并且可以遠(yuǎn)程操作pgpool,pcp.conf用來對pcp相關(guān)命令認(rèn)證的文件

cd /usr/local/pgpool
cp etc/pcp.conf.sample etc/pcp.conf
bin/pg_md5 -m -u pgpool -p
會自動生成pool_passwd
postgres:md533c14731dfdfsdfsdf91e8d10c4bff5
cat etc/pcp.conf
pgpool:md533c14731dfdfsdfsdf91e8d10c4bff5

2.配置pool_hba.conf

通過pool_hba.conf可以進(jìn)行相關(guān)權(quán)限設(shè)置,類似于postgresql的pg_hba.conf

cd /usr/local/pgpool
cp etc/pool_hba.conf.sample etc/pool_hba.conf
bin/pg_md5 -m -u postgres -p
會自動生成pool_passwd
postgres:md533c14731dfdfsdfsdf91e8d10c4bff5

**注意:

1.pool_hba.conf中的加密方式必須和pg_hba.conf中的加密方式一樣,都為mds、trust或其他方式。若不一樣會報錯。

2.pool_hba.conf中的用戶必須在postgresql數(shù)據(jù)庫中存在

**

3.配置pgpool.conf

cd /usr/local/pgpool
cp etc/pgpool.conf.sample etc/pgpool.conf
#創(chuàng)建相關(guān)目錄
mkdir -p /var/run/pgpool
mkdir -p /usr/local/pgpool/logs
vim etc/pgpool.conf
listen_addresses = '*'
port = 9999
socket_dir = '/tmp'
listen_backlog_multiplier = 2
serialize_accept = off
pcp_listen_addresses = '*'
pcp_port = 9898
pcp_socket_dir = '/tmp'
backend_hostname0 = '10.10.10.56'
backend_port0 = 5432
backend_weight0 = 1
backend_data_directory0 = '/data/pgsql/data'
backend_flag0 = 'ALLOW_TO_FAILOVER'
backend_hostname1 = '10.10.10.57'
backend_port1 = 5432
backend_weight1 = 1
backend_data_directory1 = '/data/pgsql/data'
backend_flag1 = 'ALLOW_TO_FAILOVER'
enable_pool_hba = on
pool_passwd = 'pool_passwd'
debug_level = 0
pid_file_name = '/var/run/pgpool/pgpool.pid'
logdir = '/usr/local/pgpool/logs'
replication_mode = on
load_balance_mode = on
master_slave_mode = off

其中:

replication_mode = on 復(fù)制模式打開,可以在兩臺postgresql數(shù)據(jù)庫上進(jìn)行實時備份

load_balance_mode = on 負(fù)載均衡模式打開,可以實現(xiàn)負(fù)載均衡

3.啟動pgpool

/usr/local/pgpool/bin/pgpool

4.連接pgpool

psql -U postgres -p 9999 -h 10.10.10.56
Password for user postgres: 
psql (9.2.15)
Type "help" for help.
postgres=#

測試

1.創(chuàng)建bench_replication數(shù)據(jù)庫

psql -U postgres -p 9999 -h 10.10.10.56
Password for user postgres: 
psql (9.2.15)
Type "help" for help.
postgres=#create database bench_replication;

我們可以分別登陸56、57上的postgresql進(jìn)行查看

psql -U postgres -p 5432 -h 10.10.10.56
Password for user postgres: 
psql (9.2.15)
Type "help" for help.

postgres=# \list
          List of databases
  Name  | Owner | Encoding | Collate | Ctype | Access privileges 
-------------------+----------+----------+-------------+-------------+-----------------------
 bench_replication | postgres | UTF8  | en_US.UTF-8 | en_US.UTF-8 | 
 postgres   | postgres | UTF8  | en_US.UTF-8 | en_US.UTF-8 | 
 template0   | postgres | UTF8  | en_US.UTF-8 | en_US.UTF-8 | =c/postgres   +
     |   |   |    |    | postgres=CTc/postgres
 template1   | postgres | UTF8  | en_US.UTF-8 | en_US.UTF-8 | =c/postgres   +
     |   |   |    |    | postgres=CTc/postgres
(4 rows)

可以看到兩臺postgresql都創(chuàng)建了bench_replication數(shù)據(jù)庫,因此pgpool的復(fù)制是成功的。

2.pgbench測試

#安裝pgbench
yum install postgresql-contrib
pgbench -i -h 10.10.10.56 -U postgres -p 9999 bench_replication

在所有pgsql節(jié)點中,下面列出的表和數(shù)據(jù)都被建立了,說明復(fù)制運(yùn)行正常。

表名 行數(shù)
branches 1
tellers 10
accounts 100000
history 0

總結(jié)

以上只是簡單介紹了pgpool-II的復(fù)制和負(fù)載均衡作為入門,還有很多功能沒有介紹,需要我們繼續(xù)探索。

補(bǔ)充:pgpool使用中遇到的坑總結(jié)

1,復(fù)制模式可靠性低

最早時候使用的是復(fù)制模式,數(shù)據(jù)到pgpool然后pgpool分別寫入n個postgres.發(fā)現(xiàn)經(jīng)常出現(xiàn)數(shù)據(jù)不一致問題,導(dǎo)致最終只有一個數(shù)據(jù)庫可用

2,online recovery

基于PIRT的online recovery 配置復(fù)雜

3,基于流復(fù)制的主備模式

這個用到postgres9的新特性,前期配置測試都很easy,failover 也很好用,但是當(dāng)服務(wù)連接上pgpool時,事務(wù)往往報錯 postgres error : failed to read kind from backend,這個我在之前的文章中提到過,至今無法解決。

4,連接數(shù)的困擾

num_init_children 原來理解成了一個池的大小,如果超過了會自動擴(kuò)增,但是實際上往往不夠用,確切的說該值也是 pgpool-II 支持的從客戶端發(fā)起的最大并發(fā)連接數(shù)。

所以這個值配的盡量大些,并且對這個值的更改必須重啟pgpool.

5,client_idle_limit不要配置

當(dāng)一個客戶端在執(zhí)行最后一條查詢后如果空閑到了 client_idle_limit 秒數(shù), 到這個客戶端的連接將被斷開.連接不應(yīng)該讓pgpool來斷開,應(yīng)該是應(yīng)用主動去斷開。如果讓pgpool去斷開,會導(dǎo)致客戶端不可用。

當(dāng)然pgpool也有一個好處,能夠快速找到連接的應(yīng)用。因為每個連接都是單獨的進(jìn)程,所以啟動后會有num_init_children 個進(jìn)程可以接受連接

使用# ps -ef |grep pgpool 可以看到

pgpool: wait for connection request 的進(jìn)程是空進(jìn)程,等待連接。

pgpool: postgres dbtest 10.115.53.167(51883) idle 這些進(jìn)程是使用中的進(jìn)程,并且可以看到是來自哪臺機(jī)器,什么用戶,連接的是什么數(shù)據(jù)庫。

當(dāng)然使用select * from pg_stat_activity 也能查到 連接情況

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • postgresql多選功能實現(xiàn)代碼

    postgresql多選功能實現(xiàn)代碼

    這篇文章主要介紹了postgresql多選功能實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • PGSQL 實現(xiàn)查詢今天,昨天的數(shù)據(jù),一個月之內(nèi)的數(shù)據(jù)

    PGSQL 實現(xiàn)查詢今天,昨天的數(shù)據(jù),一個月之內(nèi)的數(shù)據(jù)

    這篇文章主要介紹了PGSQL 實現(xiàn)查詢今天,昨天的數(shù)據(jù),一個月之內(nèi)的數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • 初識PostgreSQL存儲過程

    初識PostgreSQL存儲過程

    這篇文章主要介紹了初識PostgreSQL存儲過程,本文講解了PostgreSQL中存儲過程的語法,并給出了一個操作實例,需要的朋友可以參考下
    2015-01-01
  • 淺談PostgreSQL和SQLServer的一些差異

    淺談PostgreSQL和SQLServer的一些差異

    這篇文章主要介紹了淺談PostgreSQL和SQLServer的一些差異,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • postgresql運(yùn)維之遠(yuǎn)程遷移操作

    postgresql運(yùn)維之遠(yuǎn)程遷移操作

    這篇文章主要介紹了postgresql運(yùn)維之遠(yuǎn)程遷移操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSQL limit的神奇作用詳解

    PostgreSQL limit的神奇作用詳解

    這篇文章主要介紹了PostgreSQL limit的神奇作用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-09-09
  • Debian中PostgreSQL數(shù)據(jù)庫安裝配置實例

    Debian中PostgreSQL數(shù)據(jù)庫安裝配置實例

    這篇文章主要介紹了Debian中PostgreSQL數(shù)據(jù)庫安裝配置實例,一個簡明教程,需要的朋友可以參考下
    2014-06-06
  • PostgreSQL如何修改默認(rèn)端口號

    PostgreSQL如何修改默認(rèn)端口號

    文章主要內(nèi)容是關(guān)于在升級PostgreSQL過程中遇到的問題,以及解決這些問題的方法,升級過程中,由于端口號設(shè)置不正確,導(dǎo)致psql連接到舊版本的服務(wù)器,從而引發(fā)語法錯誤,解決方法是在連接數(shù)據(jù)庫時指定正確的端口號,或者修改默認(rèn)端口號
    2024-12-12
  • PostgreSQL中調(diào)用存儲過程并返回數(shù)據(jù)集實例

    PostgreSQL中調(diào)用存儲過程并返回數(shù)據(jù)集實例

    這篇文章主要介紹了PostgreSQL中調(diào)用存儲過程并返回數(shù)據(jù)集實例,本文給出一創(chuàng)建數(shù)據(jù)表、插入測試數(shù)據(jù)、創(chuàng)建存儲過程、調(diào)用創(chuàng)建存儲過程和運(yùn)行效果完整例子,需要的朋友可以參考下
    2015-01-01
  • PostgreSQL查詢修改max_connections(最大連接數(shù))及其它配置詳解

    PostgreSQL查詢修改max_connections(最大連接數(shù))及其它配置詳解

    postgresql數(shù)據(jù)庫最大連接數(shù)是系統(tǒng)允許的最大連接數(shù),當(dāng)數(shù)據(jù)庫并發(fā)用戶超過該連接數(shù)后,會導(dǎo)致新連接無法建立或者連接超時,這篇文章主要給大家介紹了關(guān)于PostgreSQL查詢修改max_connections(最大連接數(shù))及其它配置的相關(guān)資料,需要的朋友可以參考下
    2024-01-01

最新評論