Home >Backend Development >PHP Tutorial >Dockerize CodeIgniter A Step-by-Step Guide

Dockerize CodeIgniter A Step-by-Step Guide

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-12-06 12:57:111058browse

Dockerize CodeIgniter A Step-by-Step Guide

In this blog post, we will walk through how to Dockerize a CodeIgniter 3 application. By the end of this guide, you'll have a containerized application running with Apache, PHP, and MySQL, all managed via Docker Compose. This approach will streamline your development environment and ensure consistent setups across multiple systems.

Prerequisites

Before we dive into the details, make sure you have the following tools installed:

  • Docker: To containerize the application and its dependencies.
  • Docker Compose: To manage multi-container Docker applications.
  • CodeIgniter 3: Your existing CodeIgniter 3 project.

Step 1: Setting Up Dockerfile:

The Dockerfile defines the environment in which your application will run. Here’s how to set it up:

# Use an official PHP image with Apache
FROM php:8.2-apache

# Enable Apache mod_rewrite for CodeIgniter
RUN a2enmod rewrite

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

# Copy project files into the container
COPY . /var/www/html

# Install necessary PHP extensions
RUN docker-php-ext-install mysqli

# Set proper permissions for Apache to access files
RUN chown -R www-data:www-data /var/www/html && chmod -R 755 /var/www/html

# Expose port 80
EXPOSE 80

Step 2: Setting Up Docker Compose

Now let’s define a docker-compose.yml file, which will configure and run multiple containers for both your web application and the database.

version: '3.8'

services:
  app:
    build:
      context: .
      dockerfile: Dockerfile
    container_name: ci3-docker  # Set the container name here
    ports:
      - "8080:80"  # Map port 80 of the container to port 8080 on the host
    volumes:
      - .:/var/www/html  # Mount current directory to /var/www/html inside the container
    depends_on:
      - db  # Ensure the database is up before starting the application

  db:
    image: mysql:8.0  # Uses the official MySQL image
    container_name: mysql
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: root  # Root password for MySQL
      MYSQL_DATABASE: ci3docker  # Initial database to create
    ports:
      - "3306:3306"  # Expose port 3306 for database connections
    volumes:
      - db_data:/var/lib/mysql  # Persist MySQL data

volumes:
  db_data:
    name: ci3-docker  # Name the volume for MySQL data persistence

Step 3: Build and Run the Containers

Once your Dockerfile and docker-compose.yml files are ready, it’s time to build and run the containers. In your project root, open a terminal and run the following commands:
Build the Docker images:

docker-compose build

Start the containers:

docker-compose up

This will start both the CodeIgniter application and the MySQL database. The app container will be accessible at http://localhost:8080, while the MySQL database will run on port 3306.

Step 4: Update CodeIgniter Database Configuration

Now, let’s ensure that CodeIgniter can connect to the MySQL database inside the container. Open your application/config/database.php and update the database connection settings:

$db['default'] = array(
    'dsn'   => '',
    'hostname' => 'db',  // Service name from Docker Compose
    'username' => 'root',
    'password' => 'root',  // Password set in docker-compose.yml
    'database' => 'ci3docker',  // Database name set in docker-compose.yml
    'dbdriver' => 'mysqli',
    'dbprefix' => '',
    'pconnect' => FALSE,
    'db_debug' => (ENVIRONMENT !== 'production'),
    'cache_on' => FALSE,
    'cachedir' => '',
    'char_set' => 'utf8',
    'dbcollat' => 'utf8_general_ci',
    'swap_pre' => '',
    'encrypt' => FALSE,
    'compress' => FALSE,
    'stricton' => FALSE,
    'failover' => array(),
    'save_queries' => TRUE
);

Step 5: Access the Application

Once the containers are up, visit http://localhost:8080 in your web browser. If everything is set up correctly, your CodeIgniter 3 application should be running smoothly inside a Docker container.

Step 6: Managing Docker Containers

To stop the containers, run:

docker-compose down

Conclusion

In this guide, we successfully Dockerized a CodeIgniter 3 application, making it portable and easy to manage. Docker Compose allows us to define and run multi-container applications with ease, making it perfect for development and production environments.

By using Docker, you ensure a consistent environment for all developers and easily deploy your application to various systems without worrying about dependencies. If you’re looking to scale your application or run it in a cloud environment, Docker makes it incredibly simple to manage.

The above is the detailed content of Dockerize CodeIgniter A Step-by-Step Guide. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn