Docker Compose安裝部署PostgreSQL數(shù)據(jù)庫的實現(xiàn)步驟
以下是一個完整的 PostgreSQL Docker Compose 部署教程,包括配置和部署詳細步驟。本文將指導您如何在 Linux 服務器上使用 Docker Compose 來部署 PostgreSQL,并將數(shù)據(jù)持久化到指定路徑。
1. 環(huán)境準備
確保您的系統(tǒng)上已經(jīng)安裝了以下軟件:
- Docker:用于容器化應用程序。參考 Docker 官方文檔 進行安裝。
- Docker Compose:用于定義和運行多容器 Docker 應用程序。參考 Docker Compose 官方文檔 進行安裝。
驗證安裝是否成功:
docker --version docker-compose --version
2. 創(chuàng)建所需的目錄
為了確保數(shù)據(jù)持久化存儲,先創(chuàng)建工作目錄和持久化數(shù)據(jù)目錄。
執(zhí)行以下命令:
# 創(chuàng)建工作目錄 mkdir -p /opt/postgresql # 創(chuàng)建持久化目錄 mkdir -p /opt/docker-data/postgresql && chmod 777 /opt/docker-data/postgresql
說明:
/opt/postgresql
是用于存放項目文件的工作目錄。/opt/docker-data/postgresql
是持久化 PostgreSQL 數(shù)據(jù)的目錄,設置權限為777
確保容器可以讀寫。
3. 創(chuàng)建 docker-compose.yml 文件
進入工作目錄 /opt/postgresql
,然后創(chuàng)建 docker-compose.yml
文件:
cd /opt/postgresql touch docker-compose.yml
編輯 docker-compose.yml
文件,內(nèi)容如下:
version: '3.8' services: postgres: image: postgres:15 # 使用 PostgreSQL 15 鏡像 container_name: postgres_db # 容器名稱 environment: POSTGRES_USER: root # 設置用戶名為 'root' POSTGRES_PASSWORD: 123456 # 設置密碼為 '123456' POSTGRES_DB: demo # 設置數(shù)據(jù)庫名為 'demo' ports: - "5433:5432" # 將容器的 5432 端口映射到主機的 5433 端口 volumes: - /opt/docker-data/postgresql:/var/lib/postgresql/data # 數(shù)據(jù)映射到主機指定路徑 volumes: postgres_data:
文件解釋:
- services: 定義了 PostgreSQL 服務。
- image: 使用官方 PostgreSQL 15 鏡像。
- container_name: 給容器命名為
postgres_db
。 - environment: 設置數(shù)據(jù)庫的環(huán)境變量,包括用戶名、密碼和默認數(shù)據(jù)庫名稱。
- ports: 將容器的默認 PostgreSQL 端口
5432
映射到主機的5433
端口。 - volumes: 將容器的數(shù)據(jù)目錄
/var/lib/postgresql/data
映射到主機的/opt/docker-data/postgresql
,實現(xiàn)數(shù)據(jù)持久化。
4. 啟動 PostgreSQL 服務
在 docker-compose.yml
文件所在的目錄中,執(zhí)行以下命令來啟動服務:
docker-compose up -d
說明:
-d
選項表示以“后臺模式”運行容器。- 此時,PostgreSQL 容器將啟動,數(shù)據(jù)將持久化到
/opt/docker-data/postgresql
目錄。
5. 驗證 PostgreSQL 部署
檢查容器狀態(tài):
docker-compose ps
您應該會看到類似如下的輸出,表示 PostgreSQL 容器正在運行:
Name Command State Ports ------------------------------------------------------------------------- postgres_db docker-entrypoint.sh postgres Up 0.0.0.0:5433->5432/tcp
登錄到 PostgreSQL 容器進行驗證:
docker exec -it postgres_db psql -U root -d demo
命令解釋:
docker exec -it postgres_db
:進入名為postgres_db
的容器。psql -U root -d demo
:使用root
用戶登錄到demo
數(shù)據(jù)庫。
6. 連接 PostgreSQL 數(shù)據(jù)庫
您可以使用任意數(shù)據(jù)庫客戶端連接 PostgreSQL。連接參數(shù)如下:
- 主機:
localhost
或 Docker 主機 IP - 端口:
5433
- 用戶名:
root
- 密碼:
123456
- 數(shù)據(jù)庫:
demo
示例命令行連接:
psql -h localhost -p 5433 -U root -d demo
7. 停止和刪除 PostgreSQL 容器
如需停止和刪除容器,可以執(zhí)行以下命令:
docker-compose down
該命令將停止容器并刪除網(wǎng)絡配置,但不會刪除持久化的數(shù)據(jù)(數(shù)據(jù)保存在 /opt/docker-data/postgresql
目錄下)。
8. 備份與恢復數(shù)據(jù)
備份數(shù)據(jù)庫
您可以使用以下命令來備份數(shù)據(jù)庫:
docker exec -t postgres_db pg_dump -U root demo > /opt/docker-data/postgresql/backup.sql
恢復數(shù)據(jù)庫
如果您需要從備份中恢復數(shù)據(jù),可以執(zhí)行以下命令:
docker exec -i postgres_db psql -U root -d demo < /opt/docker-data/postgresql/backup.sql
結束語
通過以上步驟,您已經(jīng)成功使用 Docker Compose 部署了 PostgreSQL,并且數(shù)據(jù)已經(jīng)持久化到指定的路徑 /opt/docker-data/postgresql
。這個部署方案方便了數(shù)據(jù)庫的管理和備份,適合在開發(fā)和生產(chǎn)環(huán)境中使用。
到此這篇關于Docker Compose安裝部署PostgreSQL數(shù)據(jù)庫的實現(xiàn)步驟的文章就介紹到這了,更多相關Docker Compose安裝部署PostgreSQL內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
借助Docker搭建JMeter+Grafana+Influxdb監(jiān)控平臺的詳細教程
這篇文章主要介紹了借助Docker搭建JMeter+Grafana+Influxdb監(jiān)控平臺,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01