Maison développement back-end tutoriel php Sauvegarde des données et restauration des applications PHP via Docker Compose, Nginx et MariaDB

Sauvegarde des données et restauration des applications PHP via Docker Compose, Nginx et MariaDB

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

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

Sauvegarde des données et restauration des applications PHP via Docker Compose, Nginx et MariaDB

Avec le développement rapide de la technologie de cloud computing et de conteneurisation, de plus en plus d'applications choisissent d'utiliser Docker pour se déployer et s'exécuter. Dans l'écosystème Docker, Docker Compose est un outil très populaire capable de définir et de gérer plusieurs conteneurs via un seul fichier de configuration.

Cet article expliquera comment utiliser Docker Compose, Nginx et MariaDB pour implémenter la sauvegarde des données et la restauration des applications PHP. Nous utiliserons un exemple de projet pour démontrer ce processus.

L'exemple de structure de projet est la suivante :

.
├── docker-compose.yml
├── nginx
│   └── default.conf
├── mariadb
│   ├── Dockerfile
│   └── init.sql
└── php
    ├── Dockerfile
    └── index.php
Copier après la connexion

Tout d'abord, nous devons créer un fichier docker-compose.yml pour définir la configuration du conteneur de l'ensemble du projet. L'exemple de configuration est le suivant : 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
Copier après la connexion

在上面的配置中,我们定义了三个服务: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;
    }
}
Copier après la connexion

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

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

FROM mariadb:latest

COPY init.sql /docker-entrypoint-initdb.d
Copier après la connexion

示例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
);
Copier après la connexion

最后,我们需要创建一个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
Copier après la connexion

示例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();
}
Copier après la connexion

现在,我们可以运行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
Copier après la connexion

上面的脚本首先定义了备份目录和备份文件名。然后,它使用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
Copier après la connexion

上述脚本会使用docker execrrreee

Dans la configuration ci-dessus, nous avons défini trois services : Nginx, MariaDB et PHP. Le service Nginx est responsable du traitement des requêtes HTTP et de la transmission des requêtes à l'application sur le conteneur PHP ; le service MariaDB fournit des services de base de données ; le conteneur PHP exécute l'application PHP.

Ensuite, nous devons créer un fichier de configuration Nginx default.conf pour transmettre les requêtes HTTP à l'application sur le conteneur PHP. L'exemple de configuration est le suivant : 🎜rrreee🎜Dans la configuration ci-dessus, nous avons défini deux blocs d'emplacement. Le premier bloc d'emplacement est utilisé pour gérer les requêtes de fichiers statiques, tels que les images, les fichiers CSS et JavaScript ; le deuxième bloc d'emplacement est utilisé pour transmettre les requêtes de script PHP au processus FastCGI sur le conteneur PHP. 🎜🎜Ensuite, nous devons créer un Dockerfile de conteneur MariaDB et un script d'initialisation init.sql. L'exemple de Dockerfile est le suivant : 🎜rrreee🎜L'exemple de script init.sql est utilisé pour créer une base de données mydb et une table users : 🎜 rrreee🎜Enfin, nous devons créer un Dockerfile pour un conteneur PHP et un exemple d'application PHP index.php. L'exemple de Dockerfile est le suivant : 🎜rrreee🎜L'exemple d'application index.php est utilisé pour démontrer le processus de sauvegarde et de restauration des données : 🎜rrreee🎜Maintenant, nous pouvons exécuter le docker-compose up pour démarrer l'ensemble du projet. Visitez http://localhost dans le navigateur et vous devriez pouvoir voir les données insérées et les résultats imprimés. 🎜🎜Afin de réaliser une sauvegarde des données, nous pouvons ajouter un script Shell pour effectuer régulièrement des opérations de sauvegarde de base de données. L'exemple de script est le suivant : 🎜rrreee🎜Le script ci-dessus définit d'abord le répertoire de sauvegarde et le nom du fichier de sauvegarde. Il utilise ensuite la commande docker exec pour exécuter la commande mysqldump pour exporter la base de données et enregistre les données exportées dans un fichier de sauvegarde. 🎜🎜Afin de réaliser la restauration des données, nous pouvons créer un script Shell pour effectuer des opérations de restauration de base de données. L'exemple de script est le suivant : 🎜rrreee🎜Le script ci-dessus utilisera la commande docker exec pour importer les données du fichier de sauvegarde dans la base de données. 🎜🎜Grâce aux étapes ci-dessus, nous avons mis en œuvre avec succès la sauvegarde des données et la restauration des applications PHP à l'aide de Docker Compose, Nginx et MariaDB. En exécutant régulièrement le script de sauvegarde, nous pouvons créer un instantané de la base de données afin de pouvoir la restaurer en cas de besoin. Cela confère à notre application une disponibilité et une tolérance aux pannes plus élevées. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment empaqueter un projet avec pycharm Comment empaqueter un projet avec pycharm Apr 25, 2024 am 03:54 AM

Il existe quatre façons de regrouper un projet dans PyCharm : Emballer sous forme de fichier exécutable distinct : Exporter au format de fichier unique EXE. Emballé sous forme de programme d'installation : générez le Makefile et compilez les outils de configuration. Packagez en tant qu'image Docker : spécifiez un nom d'image, ajustez les options de construction et construisez. Package en tant que conteneur : spécifiez l'image à créer, ajustez les options d'exécution et démarrez le conteneur.

Enseignement du nœud PI: Qu'est-ce qu'un nœud PI? Comment installer et configurer le nœud PI? Enseignement du nœud PI: Qu'est-ce qu'un nœud PI? Comment installer et configurer le nœud PI? Mar 05, 2025 pm 05:57 PM

Explication détaillée et guide d'installation pour les nœuds de pignon Cet article introduira l'écosystème de pignon en détail - nœuds PI, un rôle clé dans l'écosystème de pignon et fournir des étapes complètes pour l'installation et la configuration. Après le lancement du réseau de test de la blockchain pèse, les nœuds PI sont devenus une partie importante de nombreux pionniers participant activement aux tests, se préparant à la prochaine version du réseau principal. Si vous ne connaissez pas encore Pinetwork, veuillez vous référer à ce qu'est Picoin? Quel est le prix de l'inscription? PI Utilisation, exploitation minière et sécurité. Qu'est-ce que Pinetwork? Le projet Pinetwork a commencé en 2019 et possède sa pièce exclusive de crypto-monnaie PI. Le projet vise à en créer un que tout le monde peut participer

Développement et exploitation agiles de la conteneurisation de microservices PHP Développement et exploitation agiles de la conteneurisation de microservices PHP May 08, 2024 pm 02:21 PM

Réponse : Les microservices PHP sont déployés avec HelmCharts pour un développement agile et conteneurisés avec DockerContainer pour l'isolation et l'évolutivité. Description détaillée : utilisez HelmCharts pour déployer automatiquement des microservices PHP afin de réaliser un développement agile. Les images Docker permettent une itération rapide et un contrôle de version des microservices. Le standard DockerContainer isole les microservices et Kubernetes gère la disponibilité et l'évolutivité des conteneurs. Utilisez Prometheus et Grafana pour surveiller les performances et l'état des microservices, et créer des alarmes et des mécanismes de réparation automatiques.

Docker achève le déploiement local du grand modèle open source LLama3 en trois minutes Docker achève le déploiement local du grand modèle open source LLama3 en trois minutes Apr 26, 2024 am 10:19 AM

LLaMA-3 (LargeLanguageModelMetaAI3) est un modèle d'intelligence artificielle générative open source à grande échelle développé par Meta Company. Il ne présente aucun changement majeur dans la structure du modèle par rapport à la génération précédente LLaMA-2. Le modèle LLaMA-3 est divisé en différentes versions, notamment petite, moyenne et grande, pour répondre aux différents besoins d'application et ressources informatiques. La taille des paramètres des petits modèles est de 8B, la taille des paramètres des modèles moyens est de 70B et la taille des paramètres des grands modèles atteint 400B. Cependant, lors de la formation, l'objectif est d'atteindre une fonctionnalité multimodale et multilingue, et les résultats devraient être comparables à GPT4/GPT4V. Installer OllamaOllama est un grand modèle de langage open source (LL

Comment démarrer le programme Golang Comment démarrer le programme Golang Apr 21, 2024 am 12:47 AM

Il existe quatre façons de démarrer un programme Go : À l'aide de la ligne de commande : go run main.go Démarrage via le menu "Exécuter" ou "Debug" de l'EDI Démarrage d'un conteneur à l'aide d'un outil d'orchestration de conteneur (tel que Docker ou Kubernetes) À l'aide de systemd ou superviseur sur les systèmes Unix Exécuté en tant que service système

Comment installer Deepseek Comment installer Deepseek Feb 19, 2025 pm 05:48 PM

Il existe de nombreuses façons d'installer Deepseek, notamment: Compiler à partir de Source (pour les développeurs expérimentés) en utilisant des packages précompilés (pour les utilisateurs de Windows) à l'aide de conteneurs Docker (pour le plus pratique, pas besoin de s'inquiéter de la compatibilité), quelle que soit la méthode que vous choisissez, veuillez lire Les documents officiels documentent soigneusement et les préparent pleinement à éviter des problèmes inutiles.

Architecture et pratique du système distribué PHP Architecture et pratique du système distribué PHP May 04, 2024 am 10:33 AM

L'architecture système distribuée PHP atteint l'évolutivité, les performances et la tolérance aux pannes en distribuant différents composants sur les machines connectées au réseau. L'architecture comprend des serveurs d'applications, des files d'attente de messages, des bases de données, des caches et des équilibreurs de charge. Les étapes de migration des applications PHP vers une architecture distribuée comprennent : Identifier les limites des services Sélectionner un système de file d'attente de messages Adopter un cadre de microservices Déploiement vers la gestion de conteneurs Découverte de services

Comment optimiser les performances des fonctions Java grâce à la conteneurisation ? Comment optimiser les performances des fonctions Java grâce à la conteneurisation ? Apr 29, 2024 pm 03:09 PM

La conteneurisation améliore les performances des fonctions Java des manières suivantes : Isolation des ressources : garantit un environnement informatique isolé et évite les conflits de ressources. Léger - consomme moins de ressources système et améliore les performances d'exécution. Démarrage rapide - réduit les délais d'exécution des fonctions. Cohérence : dissociez les applications et l'infrastructure pour garantir un comportement cohérent dans tous les environnements.

See all articles