A pretty configurable, production-ready and multi-stage Dockerfile for Laravel Octane powered web services and microservices.
The Docker configuration provides the following setup:
- PHP 8.0 and 8.1 official DebianBuster-based images
- Preconfigured JIT compiler and OPcache
Mode | CONTAINER_MODE ARG |
Supervisor config file | HTTP server | Exposed port |
---|---|---|---|---|
Octane (default) | app |
supervisord.app.conf | Swoole | 9000 |
Horizen | horizon |
supervisord.horizon.conf | - | - |
Scheduler | scheduler |
- | - | - |
If you want to run Horizon in the Octane container, then you should set
APP_WITH_HORIZON
build argumenttrue
.
If you want to run Scheduler in the Octane container, then you should set
APP_WITH_SCHEDULER
build argumenttrue
.
And the following PHP extensions are included:
- OpenSwoole/Swoole with support of OpenSSL, HTTP/2, Native cURL hook for coroutines,
mysqlnd
and asynchronous DNS. - OPcache
- Redis
- PCNTL
- BCMath
- RDKAFKA
- INTL
- pdo_mysql
- pdo_pgsql (disabled by default)
- pgsql (disabled by default)
- Memcached (disabled by default)
- zip
- cURL
- GD
- mbstring
- Clone this repository:
git clone --depth 1 [email protected]:exaco/laravel-octane-dockerfile.git
- Copy cloned directory content including
deployment
directory,Dockerfile
and.dockerignore
into your Octane powered Laravel project - Change directory to your Laravel project
- Build your image:
- Container
app
mode:
docker build -t <image-name>:<tag> .
- Container
horizon
mode:
docker build -t <image-name>:<tag> --build-arg CONTAINER_MODE=horizon .
- Container
scheduler
mode:
docker build -t <image-name>:<tag> --build-arg CONTAINER_MODE=scheduler .
- Up the container:
docker run -p <port>:9000 --rm <image-name>:<tag>
There are something that you maybe want to configure:
- Swoole HTTP server config in
supervisord.app.conf
- OPcache and JIT configurations in
opcache.ini
- PHP configurations in
php.ini
ENTRYPOINT
Bash script inentrypoint.sh
- Set
PHP_VERSION
using the--build-arg
option along with the build command - Set
TZ
(OS timezone) using the--build-arg
option along with the build command
// config/octane.php
return [
'swoole' => [
'options' => [
'http_compression' => true,
'http_compression_level' => 6, // 1 - 9
'compression_min_length' => 20,
'open_http2_protocol' => true
]
]
];
Also, some useful Bash functions and aliases are added in utilities.sh
that maybe help.
- Laravel Octane logs requests information only in the
local
environment. - Please be aware about
.dockerignore
content
- Add support for Horizon
- Add support for RoadRunner
- Add support for the full stack apps (Front-end assets)
- Add support
testing
environment and CI - Add support for Laravel scheduler
- Add support for Laravel Dusk
- Support more PHP extensions
- Add tests
- Add Alpine-based images
Thank you for considering contributing! If you find an issue, or have a better way to do something, feel free to open an issue, or a PR.
This repository is open-sourced software licensed under the MIT license.