dockerpgsql: 將PostgreSQL資料庫運行在Docker容器內

一、使用dockerpgsql的好處

1、便於管理和部署:通過使用dockerpgsql,管理員可以很方便地管理和部署PostgreSQL資料庫,無需考慮在操作系統上進行安裝和配置的問題。

2、可靠性和安全性:通過容器化PostgreSQL資料庫,它們可以隔離在容器內,避免不同數據所帶來的安全隱患。同時,每個容器都有獨立的文件系統,可以防止容器之間的數據干擾和相互影響。

3、易於擴展:使用dockerpgsql,管理員可以很容易地為正在運行的PostgreSQL容器添加新的資源。這樣可以實現動態的資源分配,在高峰時段自動擴展容器來滿足請求。

二、在dockerpgsql容器中運行PostgreSQL資料庫

要在dockerpgsql容器中運行PostgreSQL,需要進行以下步驟:

1、創建dockerpgsql鏡像:

FROM postgres:11.2
RUN mkdir -p /etc/postgresql \
    && mkdir -p /var/run/postgresql \
    && chown -R postgres:postgres /etc/postgresql /var/run/postgresql
COPY postgresql.conf /etc/postgresql/
COPY pg_hba.conf /etc/postgresql/
EXPOSE 5432
CMD ["postgres", "-c", "config_file=/etc/postgresql/postgresql.conf"]

2、創建docker-compose.yml文件:

version: '3'
services:
  db:
    image: my-postgres
    environment:
      POSTGRES_PASSWORD: mysecretpassword
  pgadmin:
    image: dpage/pgadmin4
    environment:
      PGADMIN_DEFAULT_EMAIL: pgadmin4@pgadmin.org
      PGADMIN_DEFAULT_PASSWORD: admin

3、運行docker-compose命令:

docker-compose up

三、數據的掛載和備份

在PostgreSQL容器中,數據是存儲在容器內的。要將數據掛載到宿主機上,需要進行以下步驟:

1、創建一個磁碟卷:

docker volume create pgdata

2、在docker-compose.yml文件中指定掛載路徑:

version: '3'
services:
  db:
    image: my-postgres
    environment:
      POSTGRES_PASSWORD: mysecretpassword
    volumes:
      - pgdata:/var/lib/postgresql/data/pgdata
  pgadmin:
    image: dpage/pgadmin4
    environment:
      PGADMIN_DEFAULT_EMAIL: pgadmin4@pgadmin.org
      PGADMIN_DEFAULT_PASSWORD: admin
volumes:
  pgdata:

3、使用pg_dump進行備份:

pg_dump -U postgres -F c my_db > my_db.dump

四、網路配置和埠映射

在默認情況下,PostgreSQL容器運行在自己的網路命名空間中,並且只能通過容器的IP地址訪問。要通過其他主機訪問容器運行的PostgreSQL資料庫,需要進行以下步驟:

1、指定容器中PostgreSQL資料庫使用的埠(默認5432):

version: '3'
services:
  db:
    image: my-postgres
    environment:
      POSTGRES_PASSWORD: mysecretpassword
    ports:
      - "5432:5432"

2、使用宿主機網路:

version: '3'
services:
  db:
    image: my-postgres
    environment:
      POSTGRES_PASSWORD: mysecretpassword
    network_mode: host

五、Docker Compose的使用技巧

1、使用Docker網路進行容器之間的通信:

在一個Docker Compose項目中,可以創建多個容器。如果這些容器需要相互通信,可以使用Docker網路進行連接。在docker-compose.yml文件的頂部指定網路名稱:

version: '3'
services:
  db:
    image: my-postgres
    environment:
      POSTGRES_PASSWORD: mysecretpassword
    networks:
      - mynetwork
  pgadmin:
    image: dpage/pgadmin4
    environment:
      PGADMIN_DEFAULT_EMAIL: pgadmin4@pgadmin.org
      PGADMIN_DEFAULT_PASSWORD: admin
    networks:
      - mynetwork
networks:
  mynetwork:

2、使用環境變數:

在docker-compose.yml文件中,可以使用環境變數來設置服務配置。這樣可以避免在修改配置時對docker-compose.yml文件進行頻繁的修改。例如:

version: '3'
services:
  db:
    image: my-postgres
    environment:
      POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}

在運行時,可以通過設置環境變數來傳遞值:

export POSTGRES_PASSWORD=123456
docker-compose up

原創文章,作者:AYOZU,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/333531.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
AYOZU的頭像AYOZU
上一篇 2025-02-01 13:34
下一篇 2025-02-01 13:34

相關推薦

  • Python 常用資料庫有哪些?

    在Python編程中,資料庫是不可或缺的一部分。隨著互聯網應用的不斷擴大,處理海量數據已成為一種趨勢。Python有許多成熟的資料庫管理系統,接下來我們將從多個方面介紹Python…

    編程 2025-04-29
  • openeuler安裝資料庫方案

    本文將介紹在openeuler操作系統中安裝資料庫的方案,並提供代碼示例。 一、安裝MariaDB 下面介紹如何在openeuler中安裝MariaDB。 1、更新軟體源 sudo…

    編程 2025-04-29
  • 資料庫第三範式會有刪除插入異常

    如果沒有正確設計資料庫,第三範式可能導致刪除和插入異常。以下是詳細解釋: 一、什麼是第三範式和範式理論? 範式理論是關係資料庫中的一個規範化過程。第三範式是範式理論中的一種常見形式…

    編程 2025-04-29
  • leveldb和unqlite:兩個高性能的資料庫存儲引擎

    本文將介紹兩款高性能的資料庫存儲引擎:leveldb和unqlite,並從多個方面對它們進行詳細的闡述。 一、leveldb:輕量級的鍵值存儲引擎 1、leveldb概述: lev…

    編程 2025-04-28
  • Python怎麼導入資料庫

    Python是一種高級編程語言。它具有簡單、易讀的語法和廣泛的庫,讓它成為一個靈活和強大的工具。Python的資料庫連接類型可以多種多樣,其中包括MySQL、Oracle、Post…

    編程 2025-04-28
  • Think-ORM數據模型及資料庫核心操作

    本文主要介紹Think-ORM數據模型建立和資料庫核心操作。 一、模型定義 Think-ORM是一個開源的ORM框架,用於簡化在PHP應用中(特別是ThinkPHP)與關係資料庫之…

    編程 2025-04-27
  • 如何使用Python將CSV文件導入到資料庫

    CSV(Comma Separated Values)是一種可讀性高、易於編輯與導入導出的文件格式,常用於存儲表格數據。在數據處理過程中,我們有時需要將CSV文件導入到資料庫中進行…

    編程 2025-04-27
  • Python批量導入資料庫

    本文將介紹Python中如何批量導入資料庫。首先,對於數據分析和挖掘領域,資料庫中批量導入數據是一個必不可少的過程。這種高效的導入方式可以極大地提高數據挖掘、機器學習等任務的效率。…

    編程 2025-04-27
  • Activiti 6自動部署後不生成資料庫act_hi_*的解決方法

    本文將從多個方面詳細闡述Activiti 6自動部署後不生成資料庫act_hi_*的問題,並提供對應的代碼示例。 一、問題分析 在使用Activiti 6部署流程後,我們發現act…

    編程 2025-04-27
  • Python更新資料庫數據

    Python更新資料庫數據是一個非常實用的功能。在工作中,我們經常需要從外部獲取數據,然後將這些數據保存到資料庫中,或者對現有資料庫中的數據進行更新。Python提供了許多庫和框架…

    編程 2025-04-27

發表回復

登錄後才能評論