首頁 後端開發 php教程 透過Docker Compose、Nginx和MariaDB實現PHP應用程式的資料備份與還原

透過Docker Compose、Nginx和MariaDB實現PHP應用程式的資料備份與還原

Oct 12, 2023 am 11:14 AM
docker 資料備份 資料還原

通过Docker Compose、Nginx和MariaDB实现PHP应用程序的数据备份与还原

透過Docker Compose、Nginx和MariaDB實現PHP應用程式的資料備份與還原

#隨著雲端運算與容器化技術的快速發展,越來越多的應用程式選擇使用Docker來部署和運行。在Docker生態系統中,Docker Compose是一個非常受歡迎的工具,它可以透過一個單一的設定檔來定義和管理多個容器。

本文將介紹如何使用Docker Compose、Nginx和MariaDB實作PHP應用程式的資料備份與還原。我們將使用一個範例專案來演示這個過程。

範例專案結構如下:

.
├── docker-compose.yml
├── nginx
│   └── default.conf
├── mariadb
│   ├── Dockerfile
│   └── init.sql
└── php
    ├── Dockerfile
    └── index.php
登入後複製

首先,我們需要建立一個docker-compose.yml檔案來定義整個專案的容器配置。範例配置如下:

version: '3'
services:
  nginx:
    image: nginx:latest
    ports:
      - 80:80
    volumes:
      - ./nginx:/etc/nginx/conf.d
      - ./php:/var/www/html
    depends_on:
      - php
  mariadb:
    build:
      context: ./mariadb
    environment:
      - MYSQL_ROOT_PASSWORD=123456
      - MYSQL_DATABASE=mydb
    volumes:
      - ./mariadb/data:/var/lib/mysql
    ports:
      - 3306:3306
  php:
    build:
      context: ./php
    volumes:
      - ./php:/var/www/html
登入後複製

在上面的設定中,我們定義了三個服務:Nginx、MariaDB和PHP。 Nginx服務負責處理HTTP請求,將請求轉送到PHP容器上的應用程式;MariaDB服務提供資料庫服務;PHP容器運行PHP應用程式。

接下來,我們需要建立一個Nginx設定檔default.conf,用於將HTTP請求轉送到PHP容器上的應用程式。範例配置如下:

server {
    listen 80;
    server_name localhost;
    root /var/www/html;
    
    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }
    
    location ~ .php$ {
        try_files $uri =404;
        fastcgi_pass php:9000;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }
}
登入後複製

在上面的設定中,我們定義了兩個location區塊。第一個location區塊用於處理靜態檔案請求,例如圖片、CSS和JavaScript檔案;第二個location區塊用於將PHP腳本請求轉送到PHP容器上的FastCGI進程。

然後,我們需要建立一個MariaDB容器的Dockerfile和初始化腳本init.sql。範例Dockerfile如下:

FROM mariadb:latest

COPY init.sql /docker-entrypoint-initdb.d
登入後複製

範例init.sql腳本用於建立一個mydb資料庫和一個users表:

CREATE DATABASE IF NOT EXISTS mydb;
USE mydb;

CREATE TABLE IF NOT EXISTS users (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(100) NOT NULL,
    email VARCHAR(100) NOT NULL
);
登入後複製

最後,我們需要建立一個PHP容器的Dockerfile和一個範例的PHP應用程式index.php。範例Dockerfile如下:

FROM php:7.4-fpm

RUN apt-get update && 
    apt-get install -y 
    zlib1g-dev 
    libzip-dev

RUN docker-php-ext-install zip pdo_mysql

COPY index.php /var/www/html
登入後複製

範例index.php應用程式用於示範資料備份和還原的過程:

<?php

$dbHost = 'mariadb';
$dbUser = 'root';
$dbPass = '123456';
$dbName = 'mydb';

try {
    $pdo = new PDO("mysql:host=$dbHost;dbname=$dbName", $dbUser, $dbPass, [
        PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
        PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC
    ]);

    // 插入数据
    $pdo->exec("INSERT INTO users (name, email) VALUES ('John Doe', 'john@example.com')");

    // 查询数据
    $stmt = $pdo->query("SELECT * FROM users");
    $users = $stmt->fetchAll();

    // 打印数据
    foreach ($users as $user) {
        echo $user['name'] . ' (' . $user['email'] . ')' . PHP_EOL;
    }

} catch (PDOException $e) {
    echo "Error: " . $e->getMessage();
}
登入後複製

現在,我們可以執行docker- compose up指令來啟動整個專案。在瀏覽器中存取http://localhost,應該可以看到插入的資料和列印的結果。

為了實現資料備份,我們可以新增一個Shell腳本來定期執行資料庫備份作業。範例腳本如下:

#!/bin/bash

BACKUP_DIR="/path/to/backup"
DATE=$(date +%Y%m%d%H%M%S)
BACKUP_FILE="$BACKUP_DIR/mydb_$DATE.sql"

docker exec -i CONTAINER_NAME mysqldump -uroot -p123456 mydb > $BACKUP_FILE

if [ $? -eq 0 ]; then
    echo "Backup completed: $BACKUP_FILE"
else
    echo "Backup failed"
fi
登入後複製

上面的腳本首先定義了備份目錄和備份檔案名稱。然後,它使用docker exec命令執行mysqldump指令來匯出資料庫,並將匯出的資料儲存到備份檔案。

為了實現資料還原,我們可以建立一個Shell腳本來執行資料庫還原作業。範例腳本如下:

#!/bin/bash

BACKUP_FILE="/path/to/backup/mydb_20210101120000.sql"

docker exec -i CONTAINER_NAME mysql -uroot -p123456 mydb < $BACKUP_FILE

if [ $? -eq 0 ]; then
    echo "Restore completed"
else
    echo "Restore failed"
fi
登入後複製

上述腳本會使用docker exec指令將備份檔案中的資料匯入到資料庫中。

透過上述步驟,我們成功地使用Docker Compose、Nginx和MariaDB實現了PHP應用程式的資料備份與還原。透過定期執行備份腳本,我們可以建立資料庫的快照,以便在需要時進行還原。這為我們的應用程式提供了更高的可用性和容錯性。

以上是透過Docker Compose、Nginx和MariaDB實現PHP應用程式的資料備份與還原的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PHP 微服務容器化的敏捷開發與維 PHP 微服務容器化的敏捷開發與維 May 08, 2024 pm 02:21 PM

答案:PHP微服務採用HelmCharts部署進行敏捷開發,並使用DockerContainer容器化以實現隔離和可擴展性。詳細描述:使用HelmCharts自動​​部署PHP微服務,實現敏捷開發。 Docker映像允許對微服務進行快速迭代和版本控制。 DockerContainer標準隔離微服務,而Kubernetes負責管理容器的可用性和可擴充性。利用Prometheus和Grafana監控微服務效能和健康狀況,並創建警告和自動修復機制。

Pi Node教學:什麼是Pi節點?如何安裝和設定Pi Node? Pi Node教學:什麼是Pi節點?如何安裝和設定Pi Node? Mar 05, 2025 pm 05:57 PM

PiNetwork節點詳解及安裝指南本文將詳細介紹PiNetwork生態系統中的關鍵角色——Pi節點,並提供安裝和配置的完整步驟。 Pi節點在PiNetwork區塊鏈測試網推出後,成為眾多先鋒積極參與測試的重要環節,為即將到來的主網發布做準備。如果您還不了解PiNetwork,請參考Pi幣是什麼?上市價格多少? Pi用途、挖礦及安全性分析。什麼是PiNetwork? PiNetwork項目始於2019年,擁有其專屬加密貨幣Pi幣。該項目旨在創建一個人人可參與

deepseek怎麼安裝 deepseek怎麼安裝 Feb 19, 2025 pm 05:48 PM

DeepSeek的安裝方法有多種,包括:從源碼編譯(適用於經驗豐富的開發者)使用預編譯包(適用於Windows用戶)使用Docker容器(最便捷,無需擔心兼容性)無論選擇哪種方法,請仔細閱讀官方文檔並充分準備,避免不必要的麻煩。

如何使用 PHP CI/CD 實現快速迭代? 如何使用 PHP CI/CD 實現快速迭代? May 08, 2024 pm 10:15 PM

答:利用PHPCI/CD實現快速迭代,包括設定CI/CD管道、自動化測試和部署流程。設定CI/CD管道:選擇CI/CD工具,配置程式碼儲存庫,定義建置管道。自動化測試:編寫單元和整合測試,使用測試框架簡化測試。實戰案例:使用TravisCI:安裝TravisCI,定義管道,啟用管道,查看結果。實現持續交付:選擇部署工具,定義部署管道,自動化部署。效益:提高開發效率、減少錯誤、縮短交貨時間。

使用Docker Container部署JavaEE應用程式 使用Docker Container部署JavaEE應用程式 Jun 05, 2024 pm 08:29 PM

使用Docker容器部署JavaEE應用程式:建立Dockerfile定義映像、建置映像、運行容器並映射端口,然後在瀏覽器中存取應用程式。範例JavaEE應用程式:RESTAPI與資料庫交互,透過Docker部署後可在localhost存取。

PHP 企業級應用微服務架構設計問答 PHP 企業級應用微服務架構設計問答 May 07, 2024 am 09:36 AM

微服務架構使用PHP框架(如Symfony和Laravel)來實現微服務,並遵循RESTful原則和標準資料格式來設計API。微服務透過訊息佇列、HTTP請求或gRPC進行通信,並使用工具(如Prometheus和ELKStack)進行監控和故障排除。

vscode怎麼安裝Docker擴充 vscode安裝Docker擴充的步驟 vscode怎麼安裝Docker擴充 vscode安裝Docker擴充的步驟 May 09, 2024 pm 03:25 PM

1.首先,開啟介面後,點選左側的擴充圖示按鈕2.隨後,在開啟的擴充頁面中找到搜尋欄位置3.接著,滑鼠輸入Docker字眼尋找擴充插件4.最後,選取目標插件,點選右下角的安裝按鈕即可

PHP 微服務容器化監控與日誌管理實戰 PHP 微服務容器化監控與日誌管理實戰 May 08, 2024 pm 12:06 PM

PHP微服務容器化監控與日誌管理監控:使用Prometheus和Grafana監控資源使用情況、請求數和延遲。日誌管理:使用ELKStack(ElasticSearch、Logstash、Kibana)收集、解析和視覺化日誌。部署Filebeat代理將日誌傳送到ElasticSearch。

See all articles