anteris-dev / skaffold-laravel
Skaffolds a Laravel project ready to run in a Docker container.
Installs: 39
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 1
Open Issues: 4
Language:Dockerfile
Type:project
This package is auto-updated.
Last update: 2021-04-29 01:14:09 UTC
README
This package makes it easy to get up and running with a Docker environment containing Laravel. It gives you the tools you need to begin developing and then build this into a Docker image for production.
- Note: While you have complete freedom to modify the Nginx configuration files, we assume that this application will be behind a proxy that handles SSL settings as opposed to that being something that directly effects this app. For this reason, SSL settings are not included by default.
Requirements
Getting Started
To being working with this project the following steps must be taken.
- Run
composer create-project anteris-dev/skaffold-laravel
in your project directory. This will download the project files. - (Optional) If you have an existing Laravel project, create a directory labeled
src
and copy your project files into it. On startup, the container will install your composer and npm dependencies, but you will need to run any migrations or builds manually through theworkspace
container. - Run
docker-compose up -d
in your skaffold directory. If no Laravel files are found in thesrc
directory, a new Laravel project will be created. This may take a few moments. - Go to
http://localhost
to view your Laravel website!
Development Tips
- Use the
workspace
container to run any artisan, composer, or npm commands.- You can access this container by running
docker-compose exec -it workspace sh
in your project directory. - Use
docker/docker-entrypoint-workspace.sh
to write any development setup commands (e.g. database migrations / seeding). By default this container installs composer and npm requirements.
- You can access this container by running
- You can build a production container using the command
docker build .
in your project directory. Be sure to modify the configuration files if necessary! - You can set environment variables via the
docker/env-example
file. We recommend you keep this file limited to containingAPP_NAME
andAPP_KEY
. Drive the rest through environment variables passed directly to the Docker container.
Directory Structure
Despite our best efforts, the directory structure in this project is slightly complex. We believe this is a worthwhile trade-off, as it keeps things nicely tucked into their own sections. Each service has been given their own "domain" under the docker
directory.
- .data - This folder will be created automatically to persist your database.
- /docker
- /nginx - Contains Nginx specific configuration files.
- /global - Nginx configuration for all environments.
- /php-fpm - Contains PHP-FPM specific configuration files.
- /development - PHP-FPM configuration for development.
- /production - PHP-FPM configuration for production.
- /supervisord - Contains Supervisord configuration files.
- /global - Supervisord configuration for all environments.
- docker-entrypoint.sh - Entrypoint for the production container.
- docker-entrypoint-workbench.sh - Entrypoint for the workbench container. This would be a good place to write any setup commands for your dev environment (e.g. database migrations / seeding).
- env-example - An env file that will be copied into the container on startup.
- /nginx - Contains Nginx specific configuration files.
- /src - This directory gets created automatically and is yours directory to play with. Laravel gets installed here.
- docker-compose.yaml - This file allows you to quickly spin up a development environment on your machine.
- Dockerfile - The production image for this application.
- Dockerfile.dev - A development image that runs PHP and Nginx.
- Dockerfile.workspace - A development image that contains PHP CLI and NPM so you may run your console commands.