DEV Community

Ehtesham Ali
Ehtesham Ali

Posted on • Edited on

2 - Dockerize Your PHP and MySQL Application: A Step-by-Step Guide to Multi-Container Apps

In the world of modern software development, containerization has become a cornerstone of efficient deployment and scalability. Docker makes it easy to package applications and their dependencies into portable containers. In this blog, we’ll walk you through creating a multi-container PHP and MySQL application using Docker Compose.

Why Use Docker for PHP and MySQL?

Consistency: Run your app in the same environment across all stages of development and production.
Isolation: Keep services like PHP and MySQL in separate containers for modular and maintainable setups.
Ease of Scaling: Add or remove containers easily as the app grows.

Project Structure

Your project directory should look like this:

project/
│
├── php-app/
│   ├── Dockerfile
│   └── index.php
│
└── docker-compose.yml
Enter fullscreen mode Exit fullscreen mode

Docker Compose File

Here’s the docker-compose.yml file:

version: '3.8'

services:
  php-app:
    build: ./php-app  # Builds the PHP app Docker image from the ./php-app directory
    ports:
      - "8080:80"  # Maps port 8080 on the host to port 80 in the container
    depends_on:
      - mysql  # Ensures MySQL starts before the PHP app

  mysql:
    image: mysql:8.0  # Uses the official MySQL image
    ports:
      - "3306:3306"  # Maps port 3306 on the host to port 3306 in the container
    environment:
      MYSQL_ROOT_PASSWORD: root  # Root password for MySQL
      MYSQL_DATABASE: mydb  # Initial database to create
    volumes:
      - mysql-data:/var/lib/mysql  # Persists MySQL data in a named volume

volumes:
  mysql-data:  # Declares a named volume for MySQL data persistence
Enter fullscreen mode Exit fullscreen mode

PHP Application Code

The index.php file connects to the MySQL container:

<?php
$servername = "mysql";  // Service name defined in docker-compose.yml
$username = "root";
$password = "root";
$database = "mydb";

try {
    // Create connection
    $conn = new PDO("mysql:host=$servername;dbname=$database", $username, $password);

    // Set PDO error mode to exception
    $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

    echo "Connected to MySQL successfully!";
} catch (PDOException $e) {
    echo "Connection failed: " . $e->getMessage();
}
?>
Enter fullscreen mode Exit fullscreen mode

Dockerfile for PHP App

The Dockerfile builds the PHP container with required dependencies:

# Use the official PHP image
FROM php:8.2-apache

# Install PDO MySQL extension
RUN docker-php-ext-install pdo pdo_mysql

# Set the working directory
WORKDIR /var/www/html

# Copy the application code
COPY index.php .

# Expose port 80
EXPOSE 80
Enter fullscreen mode Exit fullscreen mode

Steps to Build and Run

Create the Directory Structure

  • Place Dockerfile and index.php in the php-app folder.
  • Place docker-compose.yml in the root project folder.

Build and Start the Containers Open a terminal in the project directory and run:

docker-compose up --build
Enter fullscreen mode Exit fullscreen mode

Access the PHP Application Visit http://localhost:8080 in your browser. If everything is set up correctly, you should see:

Connected to MySQL successfully!
Enter fullscreen mode Exit fullscreen mode

Verify the MySQL Database

Use a MySQL client or MySQL Workbench.
Connect to localhost:3306 with:
Username: root
Password: root
Verify the database mydb is created.

Key Features of This Setup

Service Dependency Management: depends_on ensures MySQL starts before the PHP application.
Data Persistence: The mysql-data volume stores MySQL data, preventing loss across container restarts.
Port Mapping: Easily access services through ports mapped to the host machine.

Extending the Setup

Add more services like Nginx or Redis to the Compose file.
Use .env files to manage sensitive configurations.
Scale services using Docker Compose’s scale option for horizontal scaling.

Conclusion

With this setup, you've built a scalable, modular PHP and MySQL application using Docker Compose. Containerization simplifies environment management and prepares your app for cloud deployments. Whether you’re a beginner or a seasoned developer, Docker is an indispensable tool for modern application development.

Ready to take your setup to the next level? Try integrating this with CI/CD pipelines or Kubernetes for a production-grade environment.

For more similar articles:

Top comments (0)