Up and running with small Docker dev environments.
Full documentation can be found at https://vessel.shippingdocker.com.
Stakkr is just a small set of files that sets up a local Docker-based dev environment per project. There is nothing to install globally, except Docker itself!
This is all there is to using it:
composer require stakkr/docker-symfony
# Run this once to initialize project
# Must run with "bash" until initialized
bash stakkr init
./stakkr start
Head to http://localhost
in your browser and see your Laravel site!
ou can do this with this command:
cp -R vendor/shipping-docker/vessel/docker-files/{vessel,docker-compose.yml,docker} .
and then you'll be able to install and continue as normal.
Stakkr attempts to bind to port 80 and 3306 on your machine, so you can simply go to http://localhost
in your browser.
However, if you run more than one instance of Vessel, you'll get an error when starting it; Each port can only be used once. To get around this, use a different port per project by setting the APP_PORT
and MYSQL_PORT
environment variables in one of two ways:
Within the .env
file:
APP_PORT=8080
MYSQL_PORT=33060
Or when starting Stakkr:
APP_PORT=8080 MYSQL_PORT=33060 ./stakkr start
Then you can view your project at http://localhost:8080
and access your database locally from port 33060
;
Here's a list of built-in helpers you can use. Any command not defined in the vessel
script will default to being passed to the docker-compose
command. If not command is used, it will run docker-compose ps
to list the running containers for this environment.
# Start the environment
./stakkr start
## This is equivalent to
./stakkr up -d
# Stop the environment
./stakkr stop
## This is equivalent to
./stakkr down
# Use composer
./stakkr composer <cmd>
./stakkr comp <cmd> # "comp" is a shortcut to "composer"
# Use artisan
./stakkr bin/console <cmd>
./stakkr console <cmd> # "console" is a shortcut to "bin/console"
# Run phpunit tests
./stakkr test
## Example: You can pass anything you would to phpunit to this as well
./stakkr test --filter=some.phpunit.filter
./stakkr test tests/Unit/SpecificTest.php
# Run npm
./stakkr npm <cmd>
## Example: install deps
./stakkr npm install
# Run yarn
./stakkr yarn <cmd>
## Example: install deps
./stakkr yarn install
# Run gulp
./stakkr gulp <cmd>
As mentioned, anything not recognized as a built-in command will be used as an argument for the docker-compose
command. Here's a few handy tricks:
# Both will list currently running containers and their status
./stakkr
./stakkr ps
# Check log output of a container service
./stakkr logs # all container logs
./stakkr logs app # nginx | php logs
./stakkr logs mysql # mysql logs
./stakkr logs redis # redis logs
## Tail the logs to see output as it's generated
./stakkr logs -f # all logs
./stakkr logs -f app # nginx | php logs
# Start a bash shell inside of a container
# This is just like SSH'ing into a server
# Note that changes to a container made this way will **NOT**
# survive through stopping and starting the vessel environment
# To install software or change server configuration, you'll need to
# edit the Dockerfile and run: ./vessel build
./stakkr exec app bash
The aim of this project is simplicity. It includes:
If you're unfamiliar with Docker, try out this Docker in Development course, which explains important topics in how this is put together.
If you want to see how this workflow was developed, check out Shipping Docker and signup for the free course module which explains building this Docker workflow.
Stakkr requires Docker, and currently only works on Windows, Mac and Linux.
Windows requires running Hyper-V. Using Git Bash (MINGW64) and WSL are supported. Native Windows is still under development.
Mac | Linux | Windows |
---|---|---|
Install Docker on Mac | Install Docker on Debian | Install Docker on Windows |
Install Docker on Ubuntu | ||
Install Docker on CentOS |