docker安裝Postgresql數(shù)據(jù)庫及基本操作
單機(jī)
# 創(chuàng)建映射目錄 mkdir /data/postgresql/data # 啟動(dòng)容器 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è)置時(shí)區(qū) timezone = 'Asia/Shanghai' # 連接數(shù) max_connections = 1000
集群
主機(jī)
# 創(chuàng)建映射目錄 mkdir /data/postgresql/data # 啟動(dòng)容器 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è)置時(shí)區(qū) timezone = 'Asia/Shanghai' # 重啟容器 docker restart postgres_master
從機(jī)
# 啟動(dòng)容器,注意這里沒有進(jìn)行數(shù)據(jù)卷掛載,因?yàn)楹竺嬉獎(jiǎng)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ù)制的用戶名,需要輸入密碼時(shí)就是用于復(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ù)同步后容器會(huì)關(guān)閉。再啟動(dòng)即可 docker restart postgres_slave1 # 修改文件vi /data/postgresql/data/postgresql.conf # 配置主庫ip地址以及端口號(hào),以及用于復(fù)制的用戶名和密碼 primary_conninfo = 'host=192.168.0.11 port=5432 user=postgres password=123456' # 在恢復(fù)期間允許查詢。這是在流復(fù)制過程中,從庫在進(jìn)行 WAL 日志恢復(fù)的同時(shí)允許查詢讀取。 # 從機(jī)只讀 hot_standby = on # 設(shè)置恢復(fù)的目標(biāo)時(shí)間線。在這里,設(shè)置為 latest 表示從庫將一直嘗試連接到主庫的最新時(shí)間線上。 recovery_target_timeline = latest # 必須大于主節(jié)點(diǎn)的連接數(shù)。這確保從庫可以處理主庫發(fā)送的所有連接請(qǐng)求。 max_connections = 1000 # 設(shè)置時(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)建賬號(hào) CREATE ROLE admin WITH LOGIN PASSWORD '123456' NOSUPERUSER NOCREATEDB NOCREATEROLE; -- 給角色/賬號(hào)訪問數(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)建的表都屬于這個(gè)角色/賬號(hào) 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 $$; -- 查詢角色/賬號(hào)可以連接的數(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'; -- 刪除角色/賬號(hào) DROP OWNED BY admin;
總結(jié)
到此這篇關(guān)于docker安裝Postgresql數(shù)據(jù)庫及基本操作的文章就介紹到這了,更多相關(guān)docker安裝pg數(shù)據(jù)庫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
PostgreSQL數(shù)據(jù)庫命令行執(zhí)行SQL腳本的三種方式
生成環(huán)境中,出于安全性等原因,往往不提供數(shù)據(jù)庫連接工具,所以對(duì)數(shù)據(jù)庫的更新和升級(jí)就得通過命令行來實(shí)現(xiàn),本文總結(jié)了三種命令行執(zhí)行sql腳本的方式,需要的朋友可以參考下2024-02-02PostgreSQL時(shí)間相差天數(shù)代碼實(shí)例
PostgreSQL是一款簡介而又性能強(qiáng)大的數(shù)據(jù)庫應(yīng)用程序,其在日期時(shí)間數(shù)據(jù)方面所支持的功能也都非常給力,這篇文章主要給大家介紹了關(guān)于PostgreSQL時(shí)間相差天數(shù)的相關(guān)資料,需要的朋友可以參考下2023-11-11postgresql 切換 log、xlog日志的實(shí)現(xiàn)
這篇文章主要介紹了postgresql 切換 log、xlog日志的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-01-01postgresql 實(shí)現(xiàn)查詢某時(shí)間區(qū)間的所有日期案例
這篇文章主要介紹了postgresql 實(shí)現(xiàn)查詢某時(shí)間區(qū)間的所有日期案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-01-01PostgreSQL中date_trunc函數(shù)的語法及一些示例
這篇文章主要給大家介紹了關(guān)于PostgreSQL中date_trunc函數(shù)的語法及一些示例的相關(guān)資料,DATE_TRUNC函數(shù)是PostgreSQL數(shù)據(jù)庫中用于截?cái)嗳掌诓糠值暮瘮?shù),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04詳解PostgreSQL中實(shí)現(xiàn)數(shù)據(jù)透視表的三種方法
數(shù)據(jù)透視表(Pivot Table)是進(jìn)行數(shù)據(jù)匯總、分析、瀏覽和展示的強(qiáng)大工具,可以幫助我們了解數(shù)據(jù)中的對(duì)比情況、模式和趨勢(shì),是數(shù)據(jù)分析師和運(yùn)營人員必備技能之一,本給大家介紹PostgreSQL中實(shí)現(xiàn)數(shù)據(jù)透視表的三種方法,需要的朋友可以參考下2024-04-04如何在Neo4j與PostgreSQL間實(shí)現(xiàn)高效數(shù)據(jù)同步
本文詳細(xì)介紹了如何在Neo4j與PostgreSQL兩種數(shù)據(jù)庫之間實(shí)現(xiàn)高效數(shù)據(jù)同步,從基礎(chǔ)概念到全量與增量同步的實(shí)現(xiàn)策略,結(jié)合具體代碼與實(shí)踐案例,為開發(fā)者提供了全面的指導(dǎo),感興趣的朋友跟隨小編一起看看吧2024-12-12基于PostgreSQL pg_hba.conf 配置參數(shù)的使用說明
這篇文章主要介紹了基于PostgreSQL pg_hba.conf 配置參數(shù)的使用說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-01-01postgresql varchar字段regexp_replace正則替換操作
這篇文章主要介紹了postgresql varchar字段regexp_replace正則替換操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-01-01