亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

單機(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腳本的三種方式

    PostgreSQL數(shù)據(jù)庫命令行執(zhí)行SQL腳本的三種方式

    生成環(huán)境中,出于安全性等原因,往往不提供數(shù)據(jù)庫連接工具,所以對(duì)數(shù)據(jù)庫的更新和升級(jí)就得通過命令行來實(shí)現(xiàn),本文總結(jié)了三種命令行執(zhí)行sql腳本的方式,需要的朋友可以參考下
    2024-02-02
  • PostgreSQL時(shí)間相差天數(shù)代碼實(shí)例

    PostgreSQL時(shí)間相差天數(shù)代碼實(shí)例

    PostgreSQL是一款簡介而又性能強(qiáng)大的數(shù)據(jù)庫應(yīng)用程序,其在日期時(shí)間數(shù)據(jù)方面所支持的功能也都非常給力,這篇文章主要給大家介紹了關(guān)于PostgreSQL時(shí)間相差天數(shù)的相關(guān)資料,需要的朋友可以參考下
    2023-11-11
  • postgresql 切換 log、xlog日志的實(shí)現(xiàn)

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

    這篇文章主要介紹了postgresql 切換 log、xlog日志的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSQL 啟動(dòng)失敗的解決方案

    PostgreSQL 啟動(dòng)失敗的解決方案

    這篇文章主要介紹了PostgreSQL 啟動(dòng)失敗的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • postgresql 實(shí)現(xiàn)查詢某時(shí)間區(qū)間的所有日期案例

    postgresql 實(shí)現(xiàn)查詢某時(shí)間區(qū)間的所有日期案例

    這篇文章主要介紹了postgresql 實(shí)現(xiàn)查詢某時(shí)間區(qū)間的所有日期案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSQL中date_trunc函數(shù)的語法及一些示例

    PostgreSQL中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ù)透視表的三種方法

    詳解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ù)同步

    如何在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ù)的使用說明

    這篇文章主要介紹了基于PostgreSQL pg_hba.conf 配置參數(shù)的使用說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • postgresql varchar字段regexp_replace正則替換操作

    postgresql varchar字段regexp_replace正則替換操作

    這篇文章主要介紹了postgresql varchar字段regexp_replace正則替換操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01

最新評(píng)論