Home >Backend Development >PHP Tutorial >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.
Before we dive into the details, make sure you have the following tools installed:
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
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
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.
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 );
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.
To stop the containers, run:
docker-compose down
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!