Do not speak Portuguese? Translate this site with Google or Bing Translator
Setting Up a Laravel Development Environment with Docker

Posted on: July 30, 2024 04:39 PM

Posted by: Renato

Categories: Laravel

Views: 135

Setting Up a Laravel Development Environment with Docker and Docker Compose: A Step-by-Step Tutorial

Laravel, the PHP web application framework, and Docker, the containerization platform, are a match made in heaven for developers seeking scalability, efficiency, and ease of deployment. In this extensive guide, we’ll delve deep into the integration of Laravel with Docker, exploring the intricacies of setting up a robust environment and establishing seamless communication between two Laravel projects.

Here’s a list of the services we’ll be creating in our Docker environment —
- PHP — 8.2-fpm-alpine
- Nginx — nginx:stable-alpine
- MySQL — mysql:8.0.1
- Mailhog
- PhpMyAdmin

Step 1 — Download & Install Docker

Prerequisites:
Before you begin, ensure that your system meets the following requirements:
• A compatible operating system (Linux, macOS, or Windows)
• Administrative privileges (for installation)
• Internet connection to download Docker

Download Docker:
Visit the official Docker website to download the Docker Desktop application. Navigate to https://www.docker.com/get-started and click on the “Download for [Your OS]” button.

Install Docker:
Once the download is complete, follow these steps for your specific operating system:

For Windows:
• Run the installer you downloaded.
• Follow the on-screen instructions to install Docker Desktop.
• During installation, you may be asked to enable Hyper-V. Allow this to ensure proper functioning of Docker containers on Windows.

For macOS:
• Open the downloaded .dmg file.
• Drag the Docker icon to the Applications folder.
• Open Docker from the Applications folder and follow any additional prompts to complete the installation.

For Linux:
• Refer to the Docker documentation for instructions tailored to your Linux distribution: https://docs.docker.com/install/

Verify Installation:

After the installation is complete, verify that Docker is running correctly:
• Open a terminal or command prompt.
• Type the following command and press Enter:

Docker --version

This should display the installed Docker version, confirming a successful installation.
• To ensure Docker is running, enter:

Docker run hello-world

If everything is set up correctly, you will see a message indicating that your Docker installation is working.

Step 2 — Setting Up Laravel Projects in Docker File

Docker Compose Configuration

Start by creating a Dockerfile in the root directory of your Laravel project. This file will contain instructions for building a Docker image.

Configure the Nginx Server in DockerFile

services:
server:
build:
context: .
dockerfile: dockerfiles/nginx.dockerfile
ports:
- 8080:80
volumes:
- ./src:/var/www/html
- ./nginx/default.conf:/etc/nginx/conf.d/default.conf:ro
depends_on:
- php
- redis
- mysql
- mailhog
container_name: laravel_enviroment_server
networks:
- laravel_enviroment

These settings do the following:

build: This configuration tells Docker Compose to build a local image for the app service, using the specified path (context) and Dockerfile for instructions. The arguments user and uid are injected into the Dockerfile to customize user creation commands at build time.

image: The name that will be used for the image being built..

ports: Defines a port redirection that will allow external access through port 8000 to the web server running on port 80, inside the container.

volumes: Creates a shared volume that will synchronize contents from the current directory to /var/www/html inside the container. Notice that this is not your document root, since that will live in the nginx container.

networks: Sets up this service to use a networkname mysql_laravel_enviroment.

Setting /nginx/default.conf
FROM nginx:stable-alpine

WORKDIR /etc/nginx/conf.d

COPY nginx/default.conf .

RUN mv default.conf default.conf

WORKDIR /var/www/html

COPY src .

Setting nginx.conf

server {
listen 80;
index index.php index.html;
server_name localhost;
root /var/www/html/public;
location / {
try_files $uri $uri/ /index.php?$query_string;
}
location ~ \.php$ {
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass php:9000;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
}
}

These settings do the following:

listen: This directive defines the port on which the server will listen to incoming requests.
root: This directive sets the root folder path, forming the complete path to any requested file on the local file system.

Setting PHP

php:
build:
context: .
dockerfile: dockerfiles/php.dockerfile
volumes:
- ./src:/var/www/html:delegated
container_name: php_laravel_enviroment
networks:
- laravel_enviroment

Setting php.dockerfile

FROM php:8.2-fpm-alpine

WORKDIR /var/www/html

COPY src .
# Instalando extensões necessárias do PHP
RUN apk add --no-cache mysql-client msmtp perl wget procps shadow libzip libpng libjpeg-turbo libwebp freetype icu

RUN apk add --no-cache --virtual build-essentials \
icu-dev icu-libs zlib-dev g++ make automake autoconf libzip-dev \
libpng-dev libwebp-dev libjpeg-turbo-dev freetype-dev && \
docker-php-ext-configure gd --enable-gd --with-freetype --with-jpeg --with-webp && \
docker-php-ext-install gd && \
docker-php-ext-install mysqli && \
docker-php-ext-install pdo_mysql && \
docker-php-ext-install intl && \
docker-php-ext-install bcmath && \
docker-php-ext-install opcache && \
docker-php-ext-install exif && \
docker-php-ext-install zip && \
apk del build-essentials && rm -rf /usr/src/php*

RUN apk add --no-cache pcre-dev $PHPIZE_DEPS \
&& pecl install redis \
&& docker-php-ext-enable redis.so

RUN addgroup -g 1000 laravel && adduser -G laravel -g laravel -s /bin/sh -D laravel

RUN chown -R laravel /var/www/html

USER laravel
first the Dockerfile creates an image on top of the php:8.2-fpm-alpine .

The file also installs the prerequisite packages for Laravel: pdo_mysql, mbstring, mcrypt , gd, mysqli , and imagick with composer.

The RUN directive specifies the commands to update, install, and configure settings inside the container, including creating a dedicated user and group called www/html .

The WORKDIR instruction specifies the /var/www/html directory as the working directory for the application.

Creating a dedicated user and group called laravel , with restricted permissions mitigates the inherent vulnerability when running Docker containers, which run by default as root.

Setting Mysql

mysql:
image: mysql:8.0.1
restart: unless-stopped
tty: true
container_name: mysql_laravel_enviroment
env_file:
- mysql/.env
ports:
- 3306:3306
networks:
- laravel_enviroment
volumes:
- /opt/mysql_data:/var/lib/mysql

• Defines the Docker image that should be used for this container. In this case, we’re using a MySQL 8.0.1 image from Docker Hub.

• container_name: Sets up the container name for this service: travellist-db.
• restart: Always restart this service, unless it is explicitly stopped.

  • volumes: Creates a volume to share a .sql database dump that will be used to initialize the application database. The MySQL image will automatically import .sql files placed in the /var/lib/mysq directory inside the container.
    • networks: Sets up this service to use a networkname mysql_laravel_enviroment.

Setting Mysql .env

MYSQL_DATABASE=laravel_project
MYSQL_USER=homestead
MYSQL_PASSWORD=secret
MYSQL_ROOT_PASSWORD=secret
  • MYSQL_DATABASE will be the database.
    • MYSQL_USER will be the username you will use for your database. In this case, we will use .
    • MYSQL_PASSWORD will be the secure password you would like to use for this user account.
    • MYSQL_ROOT_PASSWORD will be the mysql root password .

Setting composer

composer:
build:
context: ./dockerfiles
dockerfile: composer.dockerfile
volumes:
- ./src:/var/www/html
depends_on:
- php
networks:
- laravel_enviroment

Setting All composer.dockerfile

FROM composer:latest

RUN addgroup -g 1000 laravel && adduser -G laravel -g laravel -s /bin/sh -D laravel

USER laravel

WORKDIR /var/www/html

ENTRYPOINT [ "composer", "--ignore-platform-reqs" ]



version: "3.9"

networks:
laravel_enviroment:

services:
server:
build:
context: .
dockerfile: dockerfiles/nginx.dockerfile
ports:
- 8080:80
volumes:
- ./src:/var/www/html
- ./nginx/default.conf:/etc/nginx/conf.d/default.conf:ro
depends_on:
- php
- redis
- mysql
- mailhog
container_name: laravel_enviroment_server
networks:
- laravel_enviroment
php:
build:
context: .
dockerfile: dockerfiles/php.dockerfile
volumes:
- ./src:/var/www/html:delegated
container_name: php_laravel_enviroment
networks:
- laravel_enviroment
mysql:
image: mysql:8.0.1
restart: unless-stopped
tty: true
container_name: mysql_laravel_enviroment
env_file:
- mysql/.env
ports:
- 3306:3306
networks:
- laravel_enviroment
volumes:
- /opt/mysql_data:/var/lib/mysql
phpmyadmin:
image: phpmyadmin/phpmyadmin:latest
restart: always
container_name: phpmyadmin_laravel_enviroment
depends_on:
- mysql
ports:
- '8891:80'
environment:
- PMA_HOST=mysql
- PMA_USER=root
- PMA_PASSWORD=secret
networks:
- laravel_enviroment
redis:
image: redis:alpine
container_name: redis_laravel_enviroment
restart: unless-stopped
ports:
- 6379:6379
networks:
- laravel_enviroment
command: redis-server --appendonly yes --replica-read-only no

composer:
build:
context: ./dockerfiles
dockerfile: composer.dockerfile
volumes:
- ./src:/var/www/html
depends_on:
- php
networks:
- laravel_enviroment
artisan:
build:
context: .
dockerfile: dockerfiles/php.dockerfile
volumes:
- ./src:/var/www/html
entrypoint: ["php", "/var/www/html/artisan"]
#depends_on:
#- mysql
networks:
- laravel_enviroment
scheduler:
build:
context: .
dockerfile: dockerfiles/php.dockerfile
container_name: scheduler_laravel_enviroment
volumes:
- ./src:/var/www/html
working_dir: /var/www/html
entrypoint: [ "php", "artisan", "schedule:work" ]
networks:
- laravel_enviroment
mailhog:
image: mailhog/mailhog:latest
container_name: mailhog_laravel_enviroment
ports:
- 1025:1025
- 8025:8025
networks:
- laravel_enviroment

The extructure will be like this

Step 3 — Run those Containers

docker-compose up -d

Step 4— Create Laravel Project and Set Database

docker-compose run --rm composer create-project laravel/laravel .

Access PHP My Admin

Access phpmyadmin and create the Db -laravel_db ( the same name that is on mysql.env — MYSQL_DATABASE=laravel_db )

Set Laravel .env


DB_CONNECTION=mysql
DB_HOST=mysql
DB_PORT=3306
DB_DATABASE=laravel_db
DB_USERNAME=root
DB_PASSWORD=secret

DB_host with must be the same name of the configuration in dockerfile

Clear the config cache

docker-compose run --rm artisan config:cache

Migrate Database

docker-compose run  --rm artisan migrate

Step 5 — Access the Project

Access the url — localhost:8080
The url with the same name of the configuration server in dockerfile -

Conclusion:

Congratulations! You’ve successfully set up a Laravel development environment using Docker and Docker Compose. This approach ensures consistency across different development machines and simplifies the process of managing dependencies. As you continue developing your Laravel application, you can extend and customize this setup to suit your specific project requirements. Happy coding!

Git Hub Code -

Thanks a lot for reading till end. Follow or contact me via:
Github:https://github.com/murilolivorato
LinkedIn: https://www.linkedin.com/in/murilo-livorato-80985a4a/
Youtube : https://www.youtube.com/@murilolivorato1489

Fonte: - https://medium.com/@murilolivorato/setting-up-a-laravel-development-environment-with-docker-and-docker-compose-a-step-by-step-5e37670ae640

2

Share

Donate to Site


About Author

Renato

Developer

Add a Comment
Comments 0 Comments

No comments yet! Be the first to comment

Blog Search


Categories

OUTROS (16) Variados (109) PHP (133) Laravel (173) Black Hat (3) front-end (29) linux (114) postgresql (40) Docker (28) rest (5) soap (1) webservice (6) October (1) CMS (2) node (7) backend (13) ubuntu (56) devops (25) nodejs (5) npm (3) nvm (1) git (9) firefox (1) react (7) reactnative (5) collections (1) javascript (7) reactjs (8) yarn (0) adb (1) Solid (2) blade (3) models (1) controllers (0) log (1) html (2) hardware (3) aws (14) Transcribe (2) transcription (1) google (4) ibm (1) nuance (1) PHP Swoole (5) mysql (31) macox (4) flutter (1) symfony (1) cor (1) colors (2) homeOffice (2) jobs (3) imagick (2) ec2 (1) sw (1) websocket (2) markdown (1) ckeditor (1) tecnologia (14) faceapp (1) eloquent (14) query (4) sql (40) ddd (3) nginx (9) apache (4) certbot (1) lets-encrypt (3) debian (12) liquid (1) magento (2) ruby (1) LETSENCRYPT (1) Fibonacci (1) wine (1) transaction (1) pendrive (1) boot (1) usb (1) prf (1) policia (2) federal (1) lucena (1) mongodb (4) paypal (1) payment (1) zend (1) vim (4) ciencia (6) js (1) nosql (1) java (1) JasperReports (1) phpjasper (1) covid19 (1) saude (1) athena (1) cinnamon (1) phpunit (2) binaural (1) mysqli (3) database (42) windows (6) vala (1) json (2) oracle (1) mariadb (4) dev (12) webdev (24) s3 (4) storage (1) kitematic (1) gnome (2) web (2) intel (3) piada (1) cron (2) dba (18) lumen (1) ffmpeg (2) android (2) aplicativo (1) fedora (2) shell (4) bash (3) script (3) lider (1) htm (1) csv (1) dropbox (1) db (3) combustivel (2) haru (1) presenter (1) gasolina (1) MeioAmbiente (1) Grunt (1) biologia (1) programming (22) performance (3) brain (1) smartphones (1) telefonia (1) privacidade (1) opensource (3) microg (1) iode (1) ssh (3) zsh (2) terminal (3) dracula (1) spaceship (1) mac (2) idiomas (1) laptop (2) developer (37) api (5) data (1) matematica (1) seguranca (2) 100DaysOfCode (9) hotfix (1) documentation (1) laravelphp (10) RabbitMQ (3) Elasticsearch (1) redis (2) Raspberry (4) Padrao de design (4) JQuery (1) angularjs (4) Dicas (44) Kubernetes (3) vscode (3) backup (1) angular (3) servers (2) pipelines (1) AppSec (1) DevSecOps (4) rust (1) RustLang (1) Mozilla (1) algoritimo (1) sqlite (1) Passport (2) jwt (5) security (2) translate (1) kube (2) iot (1) politica (2) bolsonaro (1) flow (1) podcast (1) Brasil (1) containers (3) traefik (1) networking (1) host (1) POO (2) microservices (2) bug (1) cqrs (1) arquitetura (3) Architecture (4) sail (3) militar (1) artigo (1) economia (1) forcas armadas (1) ffaa (1) autenticacao (2) autorizacao (2) authentication (4) authorization (3) NoCookies (1) wsl (4) memcached (1) macos (2) unix (2) kali-linux (1) linux-tools (5) apple (1) noticias (2) composer (1) rancher (1) k8s (1) escopos (1) orm (1) jenkins (4) github (5) gitlab (3) queue (1) Passwordless (1) sonarqube (1) phpswoole (1) laraveloctane (1) Swoole (1) Swoole (1) octane (1) Structurizr (1) Diagramas (1) c4 (1) c4-models (1) compactar (1) compression (1) messaging (1) restfull (1) eventdrive (1) services (1) http (1) Monolith (1) microservice (1) historia (1) educacao (1) cavalotroia (1) OOD (0) odd (1) chatgpt (1) openai (3) vicuna (1) llama (1) gpt (1) transformers (1) pytorch (1) tensorflow (1) akitando (1) ia (1) nvidia (1) agi (1) guard (1) multiple_authen (2) rpi (1) auth (1) auth (1) livros (2) ElonMusk (2) Oh My Zsh (1) Manjaro (1) BigLinux (2) ArchLinux (1) Migration (1) Error (1) Monitor (1) Filament (1) LaravelFilament (1) replication (1) phpfpm (1) cache (1) vpn (1) l2tp (1) zorin-os (1) optimization (1) scheduling (1) monitoring (2) linkedin (1) community (1) inteligencia-artificial (2) wsl2 (1) maps (1) API_KEY_GOOGLE_MAPS (1) repmgr (1) altadisponibilidade (1) banco (1) modelagemdedados (1) inteligenciadedados (4) governancadedados (1) bancodedados (2) Observability (1) picpay (1) ecommerce (1) Curisidades (1) Samurai (1) KubeCon (1) GitOps (1) Axios (1) Fetch (1) Deepin (1) vue (4) nuxt (1) PKCE (1) Oauth2 (2) webhook (1) TypeScript (1) tailwind (1) gource (2)

New Articles



Get Latest Updates by Email