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

docker安裝Postgresql數(shù)據(jù)庫及基本操作

 更新時間:2025年03月29日 13:59:10   作者:無區(qū)新手  
PostgreSQL是一個強(qiáng)大的開源對象-關(guān)系型數(shù)據(jù)庫管理系統(tǒng),以其高可擴(kuò)展性和標(biāo)準(zhǔn)化而著稱,這篇文章主要介紹了docker安裝Postgresql數(shù)據(jù)庫及基本操作的相關(guān)資料,需要的朋友可以參考下

單機(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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決PostgreSQL服務(wù)啟動后占用100% CPU卡死的問題

    解決PostgreSQL服務(wù)啟動后占用100% CPU卡死的問題

    前文書說到,今天耗費(fèi)了九牛二虎之力,終于馴服了NTFS權(quán)限安裝好了PostgreSQL,卻不曾想,服務(wù)啟動后,新的狀況又出現(xiàn)了。
    2009-08-08
  • Postgresql數(shù)據(jù)庫密碼忘記的詳細(xì)解決方法

    Postgresql數(shù)據(jù)庫密碼忘記的詳細(xì)解決方法

    在使用PostgreSQL數(shù)據(jù)庫時,忘記數(shù)據(jù)庫密碼可能會影響到正常的開發(fā)和維護(hù)工作,這篇文章主要介紹了Postgresql數(shù)據(jù)庫密碼忘記的詳細(xì)解決方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2025-06-06
  • postgresql重置序列起始值的操作

    postgresql重置序列起始值的操作

    這篇文章主要介紹了postgresql重置序列起始值,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSql中pg_ctl命令示例代碼

    PostgreSql中pg_ctl命令示例代碼

    這篇文章主要介紹了PostgreSql中pg_ctl命令的相關(guān)資料,pg_ctl是PostgreSQL服務(wù)管理工具,支持啟動/停止/重啟等操作,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2025-06-06
  • 淺析postgresql 數(shù)據(jù)庫 TimescaleDB 修改分區(qū)時間范圍

    淺析postgresql 數(shù)據(jù)庫 TimescaleDB 修改分區(qū)時間范圍

    這篇文章主要介紹了淺析postgresql 數(shù)據(jù)庫 TimescaleDB 修改分區(qū)時間范圍,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • postgreSql分組統(tǒng)計數(shù)據(jù)的實(shí)現(xiàn)代碼

    postgreSql分組統(tǒng)計數(shù)據(jù)的實(shí)現(xiàn)代碼

    這篇文章給大家介紹postgreSql的監(jiān)控記錄表里多條不同時間的數(shù)據(jù),只取最新的數(shù)據(jù),并分組統(tǒng)計,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2020-12-12
  • postgresql分頁數(shù)據(jù)重復(fù)問題的深入理解

    postgresql分頁數(shù)據(jù)重復(fù)問題的深入理解

    這篇文章主要給大家介紹了關(guān)于postgresql分頁數(shù)據(jù)重復(fù)問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用postgresql具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • postgresql 切換 log、xlog日志的實(shí)現(xiàn)

    postgresql 切換 log、xlog日志的實(shí)現(xiàn)

    這篇文章主要介紹了postgresql 切換 log、xlog日志的實(shí)現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSQL 字符串拆分與合并案例

    PostgreSQL 字符串拆分與合并案例

    這篇文章主要介紹了PostgreSQL 字符串拆分與合并案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • 查詢PostgreSQL占多大內(nèi)存的操作

    查詢PostgreSQL占多大內(nèi)存的操作

    這篇文章主要介紹了查詢PostgreSQL占多大內(nèi)存的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01

最新評論