Heim Backend-Entwicklung PHP-Tutorial Datensicherung und Wiederherstellung von PHP-Anwendungen über Docker Compose, Nginx und MariaDB

Datensicherung und Wiederherstellung von PHP-Anwendungen über Docker Compose, Nginx und MariaDB

Oct 12, 2023 am 11:14 AM
docker 数据备份 数据还原

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

Datensicherung und Wiederherstellung von PHP-Anwendungen über Docker Compose, Nginx und MariaDB

Mit der rasanten Entwicklung der Cloud-Computing- und Containerisierungstechnologie entscheiden sich immer mehr Anwendungen für die Verwendung von Docker zur Bereitstellung und Ausführung. Im Docker-Ökosystem ist Docker Compose ein sehr beliebtes Tool, das mehrere Container über eine einzige Konfigurationsdatei definieren und verwalten kann.

In diesem Artikel wird erläutert, wie Sie Docker Compose, Nginx und MariaDB verwenden, um die Datensicherung und -wiederherstellung von PHP-Anwendungen zu implementieren. Wir werden diesen Prozess anhand eines Beispielprojekts demonstrieren.

Die Beispielprojektstruktur sieht wie folgt aus:

.
├── docker-compose.yml
├── nginx
│   └── default.conf
├── mariadb
│   ├── Dockerfile
│   └── init.sql
└── php
    ├── Dockerfile
    └── index.php
Nach dem Login kopieren

Zuerst müssen wir eine docker-compose.yml-Datei erstellen, um die Containerkonfiguration des gesamten Projekts zu definieren. Die Beispielkonfiguration lautet wie folgt: 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
Nach dem Login kopieren

在上面的配置中,我们定义了三个服务: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;
    }
}
Nach dem Login kopieren

在上面的配置中,我们定义了两个location块。第一个location块用于处理静态文件请求,例如图片、CSS和JavaScript文件;第二个location块用于将PHP脚本请求转发到PHP容器上的FastCGI进程。

然后,我们需要创建一个MariaDB容器的Dockerfile和初始化脚本init.sql。示例Dockerfile如下:

FROM mariadb:latest

COPY init.sql /docker-entrypoint-initdb.d
Nach dem Login kopieren

示例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
);
Nach dem Login kopieren

最后,我们需要创建一个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
Nach dem Login kopieren

示例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();
}
Nach dem Login kopieren

现在,我们可以运行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
Nach dem Login kopieren

上面的脚本首先定义了备份目录和备份文件名。然后,它使用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
Nach dem Login kopieren

上述脚本会使用docker execrrreee

In der obigen Konfiguration haben wir drei Dienste definiert: Nginx, MariaDB und PHP. Der Nginx-Dienst ist für die Verarbeitung von HTTP-Anfragen und die Weiterleitung der Anfragen an die Anwendung im PHP-Container verantwortlich. Der MariaDB-Dienst stellt Datenbankdienste bereit.

Als nächstes müssen wir eine Nginx-Konfigurationsdatei default.conf erstellen, um HTTP-Anfragen an die Anwendung im PHP-Container weiterzuleiten. Die Beispielkonfiguration lautet wie folgt: 🎜rrreee🎜In der obigen Konfiguration haben wir zwei Standortblöcke definiert. Der erste Standortblock wird verwendet, um statische Dateianforderungen wie Bilder, CSS- und JavaScript-Dateien zu verarbeiten; der zweite Standortblock wird verwendet, um PHP-Skriptanforderungen an den FastCGI-Prozess im PHP-Container weiterzuleiten. 🎜🎜Dann müssen wir eine MariaDB-Container-Docker-Datei und ein Initialisierungsskript init.sql erstellen. Die Beispiel-Dockerdatei lautet wie folgt: 🎜rrreee🎜Das Beispielskript init.sql wird verwendet, um eine mydb-Datenbank und eine users-Tabelle zu erstellen: 🎜 rrreee🎜Zuletzt müssen wir noch eine Docker-Datei für einen PHP-Container und eine Beispiel-PHP-Anwendung index.php erstellen. Die Beispiel-Dockerdatei lautet wie folgt: 🎜rrreee🎜Die Beispielanwendung index.php wird verwendet, um den Prozess der Datensicherung und -wiederherstellung zu demonstrieren: 🎜rrreee🎜Jetzt können wir den docker-compose ausführen up-Befehl, um das gesamte Projekt zu starten. Besuchen Sie http://localhost im Browser und Sie sollten die eingefügten Daten und gedruckten Ergebnisse sehen können. 🎜🎜Um eine Datensicherung zu erreichen, können wir ein Shell-Skript hinzufügen, um regelmäßig Datenbanksicherungsvorgänge durchzuführen. Das Beispielskript lautet wie folgt: 🎜rrreee🎜Das obige Skript definiert zunächst das Sicherungsverzeichnis und den Namen der Sicherungsdatei. Anschließend wird der Befehl docker exec verwendet, um den Befehl mysqldump zum Exportieren der Datenbank auszuführen und die exportierten Daten in einer Sicherungsdatei zu speichern. 🎜🎜Um eine Datenwiederherstellung zu erreichen, können wir ein Shell-Skript erstellen, um Datenbankwiederherstellungsvorgänge durchzuführen. Das Beispielskript lautet wie folgt: 🎜rrreee🎜Das obige Skript verwendet den Befehl docker exec, um die Daten in der Sicherungsdatei in die Datenbank zu importieren. 🎜🎜Durch die oben genannten Schritte haben wir die Datensicherung und Wiederherstellung von PHP-Anwendungen mit Docker Compose, Nginx und MariaDB erfolgreich implementiert. Durch regelmäßiges Ausführen des Sicherungsskripts können wir einen Snapshot der Datenbank erstellen, damit wir ihn bei Bedarf wiederherstellen können. Dies verleiht unserer Anwendung eine höhere Verfügbarkeit und Fehlertoleranz. 🎜

Das obige ist der detaillierte Inhalt vonDatensicherung und Wiederherstellung von PHP-Anwendungen über Docker Compose, Nginx und MariaDB. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So verlassen Sie den Container mit Docker So verlassen Sie den Container mit Docker Apr 15, 2025 pm 12:15 PM

Vier Möglichkeiten zum Beenden von Docker Container: Verwenden Sie Strg D im Befehl Container Terminal ENGEBOT IM Container Terminal verwenden Sie Docker Stop & lt; container_name & gt; Befehl verwenden Sie Docker Kill & lt; container_name & gt; Befehl im Host -Terminal (Force Exit)

So kopieren Sie Dateien in Docker nach außen So kopieren Sie Dateien in Docker nach außen Apr 15, 2025 pm 12:12 PM

Methoden zum Kopieren von Dateien in externen Hosts in Docker: Verwenden Sie den Befehl Docker CP: Docker CP [Optionen] & lt; Containerpfad & gt; & lt; Host -Pfad & gt;. Verwenden von Datenvolumina: Erstellen Sie ein Verzeichnis auf dem Host und verwenden Sie den Parameter -V, um das Verzeichnis in den Container zu montieren, um den Container zu erstellen, um eine bidirektionale Dateisynchronisation zu erreichen.

So aktualisieren Sie das Bild von Docker So aktualisieren Sie das Bild von Docker Apr 15, 2025 pm 12:03 PM

Die Schritte zur Aktualisierung eines Docker -Images sind wie folgt: Ziehen Sie das neueste Bild -Tag. Neues Bild Löschen Sie das alte Bild für ein bestimmtes Tag (optional) den Container neu (falls erforderlich) neu starten Sie neu (falls erforderlich).

So überprüfen Sie den Namen des Docker -Containers So überprüfen Sie den Namen des Docker -Containers Apr 15, 2025 pm 12:21 PM

Sie können den Namen des Docker -Containers abfragen, indem Sie den Schritten folgen: Alle Container auflisten (Docker PS). Filtern Sie die Containerliste (unter Verwendung des GREP -Befehls). Ruft den Containernamen ab (befindet sich in der Spalte "Namen").

So starten Sie Docker neu So starten Sie Docker neu Apr 15, 2025 pm 12:06 PM

So starten Sie den Docker -Container neu: Holen Sie sich die Container -ID (Docker PS); Stop den Container (Docker Stop & lt; Container_id & gt;); Starten Sie den Container (Docker start & lt; container_id & gt;); Stellen Sie sicher, dass der Neustart erfolgreich ist (Docker PS). Andere Methoden: Docker Compose (Docker-Compose Neustart) oder Docker-API (siehe Docker-Dokumentation).

So starten Sie MySQL von Docker So starten Sie MySQL von Docker Apr 15, 2025 pm 12:09 PM

Der Prozess des Startens von MySQL in Docker besteht aus den folgenden Schritten: Ziehen Sie das MySQL -Image zum Erstellen und Starten des Containers an, setzen

So sehen Sie den Docker -Prozess So sehen Sie den Docker -Prozess Apr 15, 2025 am 11:48 AM

Docker Process Viewing -Methode: 1. Docker Cli -Befehl: Docker PS; 2. SYSTEMD CLI -Befehl: SystemCTL Status Docker; 3.. Docker Compose CLI Command: Docker-Compose PS; 4. Process Explorer (Windows); 5. /proc -Verzeichnis (Linux).

So verwenden Sie Docker Desktop So verwenden Sie Docker Desktop Apr 15, 2025 am 11:45 AM

Wie benutze ich Docker Desktop? Docker Desktop ist ein Werkzeug zum Ausführen von Docker -Containern auf lokalen Maschinen. Zu den zu verwendenden Schritten gehören: 1.. Docker Desktop installieren; 2. Start Docker Desktop; 3.. Erstellen Sie das Docker -Bild (mit Dockerfile); 4. Build Docker Image (mit Docker Build); 5. Docker -Container ausführen (mit Docker Run).

See all articles