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.1 and 8.2 official DebianBuster-based images
- Preconfigured JIT compiler and OPcache
You can build the Docker image in different modes:
Mode | CONTAINER_MODE ARG |
HTTP server | Exposed port |
---|---|---|---|
Octane (default) | app |
Swoole / RoadRunner | 9000 |
Horizen | horizon |
- | - |
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
- bz2
- Clone this repository:
git clone --depth 1 git@github.com:exaco/laravel-octane-dockerfile.git
- Copy cloned directory content including
deployment
directory,Dockerfile
, and.dockerignore
into your Octane powered Laravel project - Change the 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 is 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
- Ensure you have roadrunner as a dependency in your
composer.json
- Set
OCTANE_SERVER=roadrunner
using the--build-arg
option along with the build command
You can configure RoadRunner through
deployment/octane/.rr.prod.yaml
.
// config/octane.php
return [
'swoole' => [
'options' => [
'http_compression' => true,
'http_compression_level' => 6, // 1 - 9
'compression_min_length' => 20,
'package_max_length' => 20 * 1024 * 1024, // 20MB
'open_http2_protocol' => true,
'document_root' => public_path(),
'enable_static_handler' => true,
]
]
];
Also, some useful Bash functions and aliases are added in utilities.sh
that maybe help.
- Laravel Octane logs request information only in the
local
environment. - Please be aware of
.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 the 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.