백엔드 개발 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 파일을 생성해야 합니다. 샘플 구성은 다음과 같습니다. 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 execrrreee

위 구성에서는 Nginx, MariaDB 및 PHP의 세 가지 서비스를 정의했습니다. Nginx 서비스는 HTTP 요청을 처리하고 PHP 컨테이너의 애플리케이션에 요청을 전달하는 역할을 합니다. MariaDB 서비스는 PHP 컨테이너가 PHP 애플리케이션을 실행합니다.

다음으로 HTTP 요청을 PHP 컨테이너의 애플리케이션에 전달하기 위한 Nginx 구성 파일 default.conf를 생성해야 합니다. 샘플 구성은 다음과 같습니다. 🎜rrreee🎜위 구성에서는 두 개의 위치 블록을 정의했습니다. 첫 번째 위치 블록은 이미지, CSS 및 JavaScript 파일과 같은 정적 파일 요청을 처리하는 데 사용되며, 두 번째 위치 블록은 PHP 스크립트 요청을 PHP 컨테이너의 FastCGI 프로세스에 전달하는 데 사용됩니다. 🎜🎜그런 다음 MariaDB 컨테이너 Dockerfile과 초기화 스크립트 init.sql을 생성해야 합니다. 샘플 Dockerfile은 다음과 같습니다. 🎜rrreee🎜샘플 init.sql 스크립트는 mydb 데이터베이스와 users 테이블을 생성하는 데 사용됩니다. 🎜 rrreee🎜마지막으로 PHP 컨테이너용 Dockerfile과 샘플 PHP 애플리케이션 index.php를 생성해야 합니다. 샘플 Dockerfile은 다음과 같습니다. 🎜rrreee🎜샘플 index.php 애플리케이션은 데이터 백업 및 복원 프로세스를 보여주는 데 사용됩니다. 🎜rrreee🎜이제 docker-compose를 실행할 수 있습니다. up 명령을 사용하여 전체 프로젝트를 시작합니다. 브라우저에서 http://localhost로 접속하시면 삽입된 데이터와 인쇄된 결과를 보실 수 있습니다. 🎜🎜데이터 백업을 위해 정기적으로 데이터베이스 백업 작업을 수행하는 셸 스크립트를 추가할 수 있습니다. 샘플 스크립트는 다음과 같습니다. 🎜rrreee🎜위 스크립트는 먼저 백업 디렉터리와 백업 파일 이름을 정의합니다. 그런 다음 docker exec 명령을 사용하여 mysqldump 명령을 실행하여 데이터베이스를 내보내고 내보낸 데이터를 백업 파일에 저장합니다. 🎜🎜데이터 복원을 위해 데이터베이스 복원 작업을 수행하는 셸 스크립트를 만들 수 있습니다. 샘플 스크립트는 다음과 같습니다. 🎜rrreee🎜위 스크립트는 docker exec 명령을 사용하여 백업 파일의 데이터를 데이터베이스로 가져옵니다. 🎜🎜위 단계를 통해 Docker Compose, Nginx 및 MariaDB를 사용하여 PHP 애플리케이션의 데이터 백업 및 복원을 성공적으로 구현했습니다. 백업 스크립트를 정기적으로 실행하면 필요할 때 복원할 수 있도록 데이터베이스의 스냅샷을 생성할 수 있습니다. 이는 애플리케이션에 더 높은 가용성과 내결함성을 제공합니다. 🎜

위 내용은 Docker Compose, Nginx 및 MariaDB를 통한 PHP 애플리케이션의 데이터 백업 및 복원의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

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 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PI 노드 교육 : PI 노드 란 무엇입니까? Pi 노드를 설치하고 설정하는 방법은 무엇입니까? PI 노드 교육 : PI 노드 란 무엇입니까? Pi 노드를 설치하고 설정하는 방법은 무엇입니까? Mar 05, 2025 pm 05:57 PM

Pinetwork 노드에 대한 자세한 설명 및 설치 안내서이 기사에서는 Pinetwork Ecosystem을 자세히 소개합니다. Pi 노드, Pinetwork 생태계의 주요 역할을 수행하고 설치 및 구성을위한 전체 단계를 제공합니다. Pinetwork 블록 체인 테스트 네트워크가 출시 된 후, PI 노드는 다가오는 주요 네트워크 릴리스를 준비하여 테스트에 적극적으로 참여하는 많은 개척자들의 중요한 부분이되었습니다. 아직 Pinetwork를 모른다면 Picoin이 무엇인지 참조하십시오. 리스팅 가격은 얼마입니까? PI 사용, 광업 및 보안 분석. Pinetwork 란 무엇입니까? Pinetwork 프로젝트는 2019 년에 시작되었으며 독점적 인 Cryptocurrency Pi Coin을 소유하고 있습니다. 이 프로젝트는 모든 사람이 참여할 수있는 사람을 만드는 것을 목표로합니다.

DeepSeek을 설치하는 방법 DeepSeek을 설치하는 방법 Feb 19, 2025 pm 05:48 PM

Docker 컨테이너를 사용하여 사전 컴파일 된 패키지 (Windows 사용자의 경우)를 사용하여 소스 (숙련 된 개발자)를 컴파일하는 것을 포함하여 DeepSeek를 설치하는 방법에는 여러 가지가 있습니다. 공식 문서는 신중하게 문서를 작성하고 불필요한 문제를 피하기 위해 완전히 준비합니다.

PHP CI/CD를 사용하여 빠르게 반복하는 방법은 무엇입니까? PHP CI/CD를 사용하여 빠르게 반복하는 방법은 무엇입니까? May 08, 2024 pm 10:15 PM

답변: CI/CD 파이프라인 설정, 자동화된 테스트 및 배포 프로세스를 포함하여 빠른 반복을 달성하려면 PHPCI/CD를 사용하십시오. CI/CD 파이프라인 설정: CI/CD 도구를 선택하고, 코드 저장소를 구성하고, 빌드 파이프라인을 정의합니다. 자동화된 테스트: 단위 및 통합 테스트를 작성하고 테스트 프레임워크를 사용하여 테스트를 단순화합니다. 실제 사례: TravisCI 사용: TravisCI를 설치하고, 파이프라인을 정의하고, 파이프라인을 활성화하고, 결과를 봅니다. 지속적인 전달 구현: 배포 도구를 선택하고, 배포 파이프라인을 정의하고, 배포를 자동화합니다. 이점: 개발 효율성을 높이고 오류를 줄이며 납품 시간을 단축합니다.

Docker 컨테이너를 사용하여 JavaEE 애플리케이션 배포 Docker 컨테이너를 사용하여 JavaEE 애플리케이션 배포 Jun 05, 2024 pm 08:29 PM

Docker 컨테이너를 사용하여 Java EE 애플리케이션 배포: Dockerfile을 생성하여 이미지를 정의하고, 이미지를 빌드하고, 컨테이너를 실행하고, 포트를 매핑한 다음, 브라우저에서 애플리케이션에 액세스합니다. 샘플 JavaEE 애플리케이션: REST API는 Docker를 통해 배포한 후 localhost에서 액세스할 수 있는 데이터베이스와 상호 작용합니다.

vscode에 Docker 확장을 설치하는 방법 vscode에 Docker 확장을 설치하는 단계 vscode에 Docker 확장을 설치하는 방법 vscode에 Docker 확장을 설치하는 단계 May 09, 2024 pm 03:25 PM

1. 먼저 인터페이스를 연 후 왼쪽의 확장 아이콘 버튼을 클릭합니다. 2. 열린 확장 페이지에서 검색창 위치를 찾습니다. 3. 그런 다음 마우스로 Docker라는 단어를 입력하여 확장 플러그인을 찾습니다. 4 마지막으로 대상 플러그인을 선택하고 오른쪽을 클릭합니다. 하단에 있는 설치 버튼을 클릭하면 됩니다.

Docker 환경에서 PECL을 사용하여 확장자를 설치할 때 오류가 발생하는 이유는 무엇입니까? 그것을 해결하는 방법? Docker 환경에서 PECL을 사용하여 확장자를 설치할 때 오류가 발생하는 이유는 무엇입니까? 그것을 해결하는 방법? Apr 01, 2025 pm 03:06 PM

Docker 환경을 사용할 때 Docker 환경에 Extensions를 설치하기 위해 PECL을 사용하여 오류의 원인 및 솔루션. 종종 일부 두통이 발생합니다 ...

PHP 마이크로서비스의 컨테이너화된 배포에 대한 전체 가이드 PHP 마이크로서비스의 컨테이너화된 배포에 대한 전체 가이드 May 08, 2024 pm 05:06 PM

PHP 마이크로서비스의 컨테이너화된 배포에 대한 전체 가이드 소개 마이크로서비스 아키텍처는 애플리케이션을 독립적이고 느슨하게 결합된 서비스로 분해하는 현대 소프트웨어 개발에서 뜨거운 추세가 되었습니다. 컨테이너화는 이러한 마이크로서비스를 배포하고 관리하는 효과적인 방법을 제공합니다. 이 문서에서는 PHPDocker를 사용하여 마이크로서비스를 컨테이너화하고 배포하는 데 도움이 되는 단계별 가이드를 제공합니다. Docker 기본 사항 Docker는 애플리케이션과 해당 종속 항목을 모두 휴대용 컨테이너에 패키징하는 경량 컨테이너화 플랫폼입니다. 다음 단계에서는 Docker 사용 방법을 설명합니다. #Install Dockersudoapt-getupdatesudoapt-getinstalldock

Dockerfile에서 여러 서비스를 효율적으로 시작하는 방법은 무엇입니까? Dockerfile에서 여러 서비스를 효율적으로 시작하는 방법은 무엇입니까? Apr 01, 2025 pm 02:15 PM

Dockerfile에서 CMD 명령의 효율적인 사용에 대해 많은 새로운 Docker 사용자가 CMD를 사용하고 있습니다 ...

See all articles