


The perfect combination of Docker Compose, Nginx and MariaDB: best practices for deploying PHP applications
The perfect combination of Docker Compose, Nginx and MariaDB: Best practices for deploying PHP applications
Introduction:
In modern web application development, use Containerization technology has become a trend. Containerization technology can package an application and its dependencies into a single container, so that the application can run in any environment that supports containerization technology. Docker is currently the most popular containerization technology, which can simplify the deployment, management and expansion of applications.
For web applications developed using PHP, we can use Docker Compose to manage multiple containers, including Nginx, PHP, and databases. This article will introduce how to use Docker Compose, Nginx and MariaDB to deploy and manage a PHP application, and provide specific code examples.
-
Install Docker and Docker Compose
First, we need to install Docker and Docker Compose on the host. You can visit the Docker official website (https://www.docker.com/) to download and install. After the installation is complete, we can confirm whether Docker is installed correctly by running the following command:docker --version docker-compose --version
Copy after login Create a Docker Compose file
Create a file named docker-compose in the root directory of the project .yml file used to define the application's services and corresponding configuration. The following is an example of a simple docker-compose.yml file:version: '3' services: web: build: context: . dockerfile: Dockerfile ports: - 80:80 volumes: - ./src:/var/www/html depends_on: - db db: image: mariadb environment: MYSQL_ROOT_PASSWORD: 123456 MYSQL_DATABASE: mydb MYSQL_USER: user MYSQL_PASSWORD: password volumes: - db-data:/var/lib/mysql volumes: db-data:
Copy after loginThe above docker-compose.yml file defines two services, one is a web service for running Nginx and PHP, and the other is a db Service for running MariaDB. The web service exposes port 80 to the external host and maps the src folder in the project directory to the /var/www/html directory in the container. The db service sets MariaDB's environment variables and data volumes for persistent storage of database data.
Create Dockerfile
In order to build the custom image required for the web service, we need to create a file named Dockerfile in the project directory. The following is an example of a simple Dockerfile:FROM php:7.4-fpm RUN docker-php-ext-install pdo_mysql WORKDIR /var/www/html
Copy after loginThe above Dockerfile is based on the official php:7.4-fpm image, has the pdo_mysql extension installed, and sets the working directory to /var/www/html.
Start the container
Execute the following command in the root directory of the project to start the container:docker-compose up -d
Copy after loginBy running the above command, Docker will follow the docker-compose.yml file The configuration in starts the web and db services. The -d parameter indicates running the container in background mode.
Configuring Nginx
In order for Nginx to correctly forward requests to the PHP application in the web service, we need to add the following configuration items to the Nginx configuration:server { listen 80; server_name localhost; root /var/www/html; index index.php index.html; location / { try_files $uri $uri/ /index.php?$query_string; } location ~ .php$ { fastcgi_pass web:9000; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } }
Copy after loginThe above configuration file forwards the request to the PHP-FPM process running in the web service and passes PHP-related environment variables to PHP-FPM.
Write PHP application
Write PHP application code in the src folder under the project directory. Here we take a simple Hello World program as an example:<?php echo "Hello World!";
Copy after login- Access the application
You can view the running PHP application in the browser by accessing http://localhost.
Summary:
By using a combination of Docker Compose, Nginx and MariaDB, we can easily deploy and manage PHP applications. Docker Compose provides a simple and powerful way to define and run multiple containers, Nginx as a web server can handle a large number of concurrent requests, and MariaDB provides a stable and reliable database service. We hope that through the introduction and examples in this article, readers can better understand and apply these technologies and benefit from them in actual projects.
The above is the detailed content of The perfect combination of Docker Compose, Nginx and MariaDB: best practices for deploying PHP applications. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



The steps to update a Docker image are as follows: Pull the latest image tag New image Delete the old image for a specific tag (optional) Restart the container (if needed)

Steps to create a Docker image: Write a Dockerfile that contains the build instructions. Build the image in the terminal, using the docker build command. Tag the image and assign names and tags using the docker tag command.

How to use Docker Desktop? Docker Desktop is a tool for running Docker containers on local machines. The steps to use include: 1. Install Docker Desktop; 2. Start Docker Desktop; 3. Create Docker image (using Dockerfile); 4. Build Docker image (using docker build); 5. Run Docker container (using docker run).

To save the image in Docker, you can use the docker commit command to create a new image, containing the current state of the specified container, syntax: docker commit [Options] Container ID Image name. To save the image to the repository, you can use the docker push command, syntax: docker push image name [: tag]. To import saved images, you can use the docker pull command, syntax: docker pull image name [: tag].

Troubleshooting steps for failed Docker image build: Check Dockerfile syntax and dependency version. Check if the build context contains the required source code and dependencies. View the build log for error details. Use the --target option to build a hierarchical phase to identify failure points. Make sure to use the latest version of Docker engine. Build the image with --t [image-name]:debug mode to debug the problem. Check disk space and make sure it is sufficient. Disable SELinux to prevent interference with the build process. Ask community platforms for help, provide Dockerfiles and build log descriptions for more specific suggestions.

Methods for copying files to external hosts in Docker: Use the docker cp command: Execute docker cp [Options] <Container Path> <Host Path>. Using data volumes: Create a directory on the host, and use the -v parameter to mount the directory into the container when creating the container to achieve bidirectional file synchronization.

Four ways to exit Docker container: Use Ctrl D in the container terminal Enter exit command in the container terminal Use docker stop <container_name> Command Use docker kill <container_name> command in the host terminal (force exit)

You can query the Docker container name by following the steps: List all containers (docker ps). Filter the container list (using the grep command). Gets the container name (located in the "NAMES" column).
