docker安裝Postgresql數(shù)據(jù)庫及基本操作
單機(jī)
# 創(chuàng)建映射目錄 mkdir /data/postgresql/data # 啟動容器 docker run -d -p 5432:5432 --restart=always -v /data/postgresql/data:/var/lib/postgresql/data -e POSTGRES_PASSWORD=123456 --name postgres postgres:14 # 修改配置文件/data/postgresql/data/postgresql.conf # 設(shè)置時區(qū) timezone = 'Asia/Shanghai' # 連接數(shù) max_connections = 1000
集群
主機(jī)
# 創(chuàng)建映射目錄 mkdir /data/postgresql/data # 啟動容器 docker run -d -p 5432:5432 -v /data/postgresql/data:/var/lib/postgresql/data -e POSTGRES_PASSWORD=123456 --name postgres_master postgres:14 # 修改vi /data/postgresql/data/pg_hba.conf,允許從機(jī)復(fù)制 host replication all 192.168.0.12/32 trust host replication all 193.168.0.13/32 trust # 修改vi /data/postgresql/data/postgresql.conf # 啟用歸檔模式,允許數(shù)據(jù)庫將 WAL(Write-Ahead Logging)日志文件存檔。 archive_mode = on # 連接數(shù) max_connections = 500 # 設(shè)置時區(qū) timezone = 'Asia/Shanghai' # 重啟容器 docker restart postgres_master
從機(jī)
# 啟動容器,注意這里沒有進(jìn)行數(shù)據(jù)卷掛載,因?yàn)楹竺嬉獎h除數(shù)據(jù)將主節(jié)點(diǎn)數(shù)據(jù)同步過來 docker run -d -p 5432:5432 -e POSTGRES_PASSWORD=123456 -v /data/postgresql/data:/var/lib/postgresql/data --name postgres_slave1 postgres:14 # 進(jìn)入容器 docker exec -it postgres_slave1 bash # 刪除數(shù)據(jù),并將主節(jié)點(diǎn)數(shù)據(jù)同步過來(注意-h后面跟著的是主節(jié)點(diǎn)ip,-U后面是主節(jié)點(diǎn)創(chuàng)建的用于復(fù)制的用戶名,需要輸入密碼時就是用于復(fù)制的用戶名的密碼) rm -rf /var/lib/postgresql/data/* && pg_basebackup -h 192.168.0.11 -p 5432 -U postgres -Fp -Xs -Pv -R -D /var/lib/postgresql/data # 數(shù)據(jù)同步后容器會關(guān)閉。再啟動即可 docker restart postgres_slave1 # 修改文件vi /data/postgresql/data/postgresql.conf # 配置主庫ip地址以及端口號,以及用于復(fù)制的用戶名和密碼 primary_conninfo = 'host=192.168.0.11 port=5432 user=postgres password=123456' # 在恢復(fù)期間允許查詢。這是在流復(fù)制過程中,從庫在進(jìn)行 WAL 日志恢復(fù)的同時允許查詢讀取。 # 從機(jī)只讀 hot_standby = on # 設(shè)置恢復(fù)的目標(biāo)時間線。在這里,設(shè)置為 latest 表示從庫將一直嘗試連接到主庫的最新時間線上。 recovery_target_timeline = latest # 必須大于主節(jié)點(diǎn)的連接數(shù)。這確保從庫可以處理主庫發(fā)送的所有連接請求。 max_connections = 1000 # 設(shè)置時區(qū) timezone = 'Asia/Shanghai' # 重啟從庫 docker restart postgres_slave1 # 校驗(yàn),在主機(jī)執(zhí)行sql select * from pg_stat_replication;
從機(jī)2
重復(fù)從機(jī)1的操作
Pgpool
負(fù)載均衡,讀寫分離
docker run -d -p 9999:5432 --name pgpool \ --env PGPOOL_BACKEND_NODES=0:192.168.0.11:5432,1:192.168.0.12:5432,2:192.168.0.13:5432 \ --env PGPOOL_SR_CHECK_USER=postgres \ --env PGPOOL_SR_CHECK_PASSWORD=123456 \ --env PGPOOL_ENABLE_LDAP=no \ --env PGPOOL_POSTGRES_USERNAME=postgres \ --env PGPOOL_POSTGRES_PASSWORD=123456 \ --env PGPOOL_ADMIN_USERNAME=postgres \ --env PGPOOL_ADMIN_PASSWORD=123456 \ --env PGPOOL_USERNAME=postgres \ --env PGPOOL_PASSWORD=123456 \ --env PGPOOL_AUTHENTICATION_METHOD=scram-sha-256 \ pgpool
postgresql角色權(quán)限設(shè)置
-- 創(chuàng)建賬號 CREATE ROLE admin WITH LOGIN PASSWORD '123456' NOSUPERUSER NOCREATEDB NOCREATEROLE; -- 給角色/賬號訪問數(shù)據(jù)庫的權(quán)限 GRANT ALL PRIVILEGES ON DATABASE testDb TO admin; -- 設(shè)置所有schema的訪問權(quán)限 DO $$ DECLARE schema_name TEXT; BEGIN FOR schema_name IN SELECT nspname FROM pg_namespace WHERE nspname NOT IN ('pg_catalog', 'information_schema') LOOP EXECUTE format('GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA %I TO admin;', schema_name); EXECUTE format('GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA %I TO admin;', schema_name); EXECUTE format('GRANT ALL PRIVILEGES ON ALL FUNCTIONS IN SCHEMA %I TO admin;', schema_name); END LOOP; END $$; -- 解綁所有schema的訪問權(quán)限 DO $$ DECLARE schema_name TEXT; BEGIN FOR schema_name IN SELECT nspname FROM pg_namespace WHERE nspname NOT IN ('pg_catalog', 'information_schema') LOOP EXECUTE format('REVOKE ALL PRIVILEGES ON ALL TABLES IN SCHEMA %I FROM admin;', schema_name); EXECUTE format('REVOKE ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA %I FROM admin;', schema_name); EXECUTE format('REVOKE ALL PRIVILEGES ON ALL FUNCTIONS IN SCHEMA %I FROM admin;', schema_name); END LOOP; END $$; -- 設(shè)置默認(rèn)權(quán)限,新創(chuàng)建的表都屬于這個角色/賬號 DO $$ DECLARE schema_name TEXT; BEGIN FOR schema_name IN SELECT nspname FROM pg_namespace WHERE nspname NOT IN ('pg_catalog', 'information_schema') LOOP EXECUTE format('ALTER DEFAULT PRIVILEGES IN SCHEMA %I GRANT ALL ON TABLES TO admin;', schema_name); EXECUTE format('ALTER DEFAULT PRIVILEGES IN SCHEMA %I GRANT ALL ON SEQUENCES TO admin', schema_name); EXECUTE format('ALTER DEFAULT PRIVILEGES IN SCHEMA %I GRANT ALL ON FUNCTIONS TO admin', schema_name); END LOOP; END $$; -- 查詢角色/賬號可以連接的數(shù)據(jù)庫 SELECT datname FROM pg_database WHERE has_database_privilege('admin', datname, 'CONNECT'); -- 解綁連接其他數(shù)據(jù)庫 REVOKE CONNECT ON DATABASE postgres FROM PUBLIC; -- 查詢數(shù)據(jù)庫所綁定的角色/用戶 SELECT datacl FROM pg_database WHERE datname = 'testDb'; -- 刪除角色/賬號 DROP OWNED BY admin;
總結(jié)
到此這篇關(guān)于docker安裝Postgresql數(shù)據(jù)庫及基本操作的文章就介紹到這了,更多相關(guān)docker安裝pg數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 在 Docker 中安裝和運(yùn)行 PostgreSQL的詳細(xì)步驟
- Docker Compose安裝部署PostgreSQL數(shù)據(jù)庫的實(shí)現(xiàn)步驟
- Docker安裝PostgreSQL數(shù)據(jù)庫的詳細(xì)步驟
- Docker如何安裝PostgreSQL
- docker如何安裝帶postgis插件的postgresql數(shù)據(jù)庫
- docker安裝postgresql的圖文教程
- docker安裝并持久化postgresql數(shù)據(jù)庫的操作步驟
- Docker27.3.1中安裝 PostgreSQL16的實(shí)現(xiàn)步驟
相關(guān)文章
解決PostgreSQL服務(wù)啟動后占用100% CPU卡死的問題
前文書說到,今天耗費(fèi)了九牛二虎之力,終于馴服了NTFS權(quán)限安裝好了PostgreSQL,卻不曾想,服務(wù)啟動后,新的狀況又出現(xiàn)了。2009-08-08Postgresql數(shù)據(jù)庫密碼忘記的詳細(xì)解決方法
在使用PostgreSQL數(shù)據(jù)庫時,忘記數(shù)據(jù)庫密碼可能會影響到正常的開發(fā)和維護(hù)工作,這篇文章主要介紹了Postgresql數(shù)據(jù)庫密碼忘記的詳細(xì)解決方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-06-06淺析postgresql 數(shù)據(jù)庫 TimescaleDB 修改分區(qū)時間范圍
這篇文章主要介紹了淺析postgresql 數(shù)據(jù)庫 TimescaleDB 修改分區(qū)時間范圍,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01postgreSql分組統(tǒng)計數(shù)據(jù)的實(shí)現(xiàn)代碼
這篇文章給大家介紹postgreSql的監(jiān)控記錄表里多條不同時間的數(shù)據(jù),只取最新的數(shù)據(jù),并分組統(tǒng)計,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2020-12-12postgresql分頁數(shù)據(jù)重復(fù)問題的深入理解
這篇文章主要給大家介紹了關(guān)于postgresql分頁數(shù)據(jù)重復(fù)問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用postgresql具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04postgresql 切換 log、xlog日志的實(shí)現(xiàn)
這篇文章主要介紹了postgresql 切換 log、xlog日志的實(shí)現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01