Skip to content

Laravel Docker Template - Laravel v11.x, PHP v8.3.x, MySQL v8.1.x, phpMyAdmin v5.x, Mailpit v1.x

Notifications You must be signed in to change notification settings

xuyixuan67/laravel-docker

 
 

Repository files navigation

Laravel Logo

Laravel Docker Starter Kit

  • Laravel v11.x
  • PHP v8.3.x
  • MySQL v8.1.x (default)
  • MariaDB v10.11.x
  • PostgreSQL v16.x
  • pgAdmin v4.x
  • phpMyAdmin v5.x
  • Mailpit v1.x
  • Node.js v18.x
  • NPM v10.x
  • Yarn v1.x
  • Vite v5.x
  • Rector v1.x
  • Redis v7.2.x

Requirements

How To Deploy

For first time only !

  • git clone https://github.com/refactorian/laravel-docker.git
  • cd laravel-docker
  • docker compose up -d --build
  • docker compose exec phpmyadmin chmod 777 /sessions
  • docker compose exec php bash
  • chown -R www-data:www-data /var/www/storage /var/www/bootstrap/cache
  • chmod -R 775 /var/www/storage /var/www/bootstrap/cache
  • composer setup

From the second time onwards

  • docker compose up -d

Notes

Laravel Versions

Laravel App

Mailpit

phpMyAdmin

  • URL: http://localhost:8080
  • Server: db
  • Username: refactorian
  • Password: refactorian
  • Database: refactorian

Adminer

  • URL: http://localhost:9090
  • Server: db
  • Username: refactorian
  • Password: refactorian
  • Database: refactorian

Basic docker compose commands

  • Build or rebuild services
    • docker compose build
  • Create and start containers
    • docker compose up -d
  • Stop and remove containers, networks
    • docker compose down
  • Stop all services
    • docker compose stop
  • Restart service containers
    • docker compose restart
  • Run a command inside a container
    • docker compose exec [container] [command]

Useful Laravel Commands

  • Display basic information about your application
    • php artisan about
  • Remove the configuration cache file
    • php artisan config:clear
  • Flush the application cache
    • php artisan cache:clear
  • Clear all cached events and listeners
    • php artisan event:clear
  • Delete all of the jobs from the specified queue
    • php artisan queue:clear
  • Remove the route cache file
    • php artisan route:clear
  • Clear all compiled view files
    • php artisan view:clear
  • Remove the compiled class file
    • php artisan clear-compiled
  • Remove the cached bootstrap files
    • php artisan optimize:clear
  • Delete the cached mutex files created by scheduler
    • php artisan schedule:clear-cache
  • Flush expired password reset tokens
    • php artisan auth:clear-resets

Laravel Pint (Code Style Fixer | PHP-CS-Fixer)

  • Format all files
    • vendor/bin/pint
  • Format specific files or directories
    • vendor/bin/pint app/Models
    • vendor/bin/pint app/Models/User.php
  • Format all files with preview
    • vendor/bin/pint -v
  • Format uncommitted changes according to Git
    • vendor/bin/pint --dirty
  • Inspect all files
    • vendor/bin/pint --test

Rector

  • Dry Run
    • vendor/bin/rector process --dry-run
  • Process
    • vendor/bin/rector process

SQL Question 1:

-SELECT bnbs.id AS bnb_id, bnbs.name AS bnb_name, SUM(orders.amount) AS may_amount FROM orders JOIN bnbs ON orders.bnb_id = bnbs.id
WHERE orders.currency = 'TWD' AND orders.created_at BETWEEN '2023-05-01' AND '2023-05-31'GROUP BY bnbs.id, bnbs.name ORDER BY may_amount DESC LIMIT 10;

SQL Question 2:

create index for bnb.id, orders.currency and orders.created and use explain analyze to check if the speed is improved.

If not, try to create a composite index on (bnb.id, orders.currency and orders.created_at) to see if it is improved

About

Laravel Docker Template - Laravel v11.x, PHP v8.3.x, MySQL v8.1.x, phpMyAdmin v5.x, Mailpit v1.x

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • PHP 60.5%
  • Blade 37.2%
  • Dockerfile 1.4%
  • Other 0.9%