Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/0xibra/docker-jobs-bundle
Symfony bundle that offers a batch processing system with Docker containers.
https://github.com/0xibra/docker-jobs-bundle
batch-processing docker php-jobs symfony symfony-bundle
Last synced: 3 months ago
JSON representation
Symfony bundle that offers a batch processing system with Docker containers.
- Host: GitHub
- URL: https://github.com/0xibra/docker-jobs-bundle
- Owner: 0xIbra
- License: mit
- Created: 2021-03-11T21:17:59.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2022-08-21T10:21:09.000Z (over 2 years ago)
- Last Synced: 2024-04-15T18:42:17.245Z (9 months ago)
- Topics: batch-processing, docker, php-jobs, symfony, symfony-bundle
- Language: PHP
- Homepage:
- Size: 3.83 MB
- Stars: 21
- Watchers: 3
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Docker Jobs Bundle
===================
> Symfony bundle that offers a **batch processing system** with **Docker**.Uses Docker containers to run and handle your jobs.
* [Need to know](#need-to-know)
* [Docker Configuration](#docker-configuration)
* [Installation](#installation)
* [Configuration](#configuration)
* [Job Entity](#job-entity)
* [Bundle Configuration](#bundle-configuration)
* [Next steps](#next-steps)
* [Console commands](docs/console.md)
* [Job orchestration command](docs/console.md#job-orchestration-command)
* [Job submission command](docs/console.md#job-submission-command)
* [Stop job command](docs/console.md#stop-job-command)
* [Orphan job cleaning command](docs/console.md#clean-orphan-jobs-command)
* [Job Monitoring Dashboard](docs/dashboard.md)Need to know
-------------------
All containers started by this bundle, are by default on the host's network.
So, if you need to connect to a local database, you can with the usual `localhost|127.0.0.1`.Docker configuration
--------------------
Docker Engine API must be exposed on a local port in order to be able to connect.##### 1. Edit the `docker.service` which by default on debian is located at `/lib/systemd/system/docker.service`
From this:
```shell
# /lib/systemd/system/docker.service
...
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock
...
```To this:
```shell
# /lib/systemd/system/docker.service
...
ExecStart=/usr/bin/dockerd
...
```##### 2. Edit `/etc/docker/daemon.json` to expose docker api at `127.0.0.1:2375`
Add `hosts` to the json file as next:
```json
{
...
"hosts": ["fd://", "tcp://127.0.0.1:2375"]
...
}
```##### 3. Restart Docker completely
```shell
systemctl daemon-reload
systemctl restart docker
service docker restart
```#### Docker Image
If not already done, you must create a Docker image which will be used to execute your jobs.
This bundle allows use of different images for each job but requires a default image to fallback on when no docker image is specified at launch.
Installation
------------
When installing, you must specify the correct version of the bundle which coressponds to the Symfony version of your project.
```shell
# Symfony 6
composer require ibra-akv/docker-jobs-bundle:~6.0# Symfony 5
composer require ibra-akv/docker-jobs-bundle:~5.0# Symfony 4
composer require ibra-akv/docker-jobs-bundle:~4.0# Symfony 3
composer require ibra-akv/docker-jobs-bundle:~3.0
```Configuration
-------------
The configuration process is a bit lengthy, follow all the steps shown below.* [Job Entity](#job-entity)
* [Bundle Configuration](#bundle-configuration)--------------------------------------------------------------------------------
### Job Entity
You must create your Job entity and extend of BaseJob class.
```php
['all' => true],
...
IterativeCode\DockerJobsBundle\DockerJobsBundle::class => ['all' => true],
];# Symfony 3
# ./project_dir/app/AppKernel.php$bundles = array(
new Symfony\Bundle\FrameworkBundle\FrameworkBundle(),
new Symfony\Bundle\SecurityBundle\SecurityBundle(),
...
new IterativeCode\DockerJobsBundle\DockerJobsBundle(),
)```
**Yaml configuration**
```yaml
# Symfony 4
# ./project_dir/config/packages/docker_jobs.yaml# Symfony 2 - 3
# ./project_dir/app/config/config.ymldocker_jobs:
class:
job: App\Entity\Job # Requireddocker:
# The URI where Docker Engine API is exposed
# The bundle will use this endpoint to communicate with Docker
docker_api_endpoint: 'http://127.0.0.1:2375' # optional (default: http://localhost:2375)# Default docker image ID for job execution
# You can specify docker image when creating a job, this image will be used if no image is specified at creation.
default_image_id: '6c39ebee77c9' # Required# This parameter is required to avoid eventual errors
# When starting a container for your job, the user will cd into this directory.
container_working_dir: '/opt/symfony-project' # Required# This parameter is used to convert docker container dates to my timezone.
# Docker by default uses UTC+00:00 time, me who's residing in France, i need to add 1 hour to it for it to be correct (UTC+01:00).
# You can use this parameter to add or remove hours to adapt it to your timezone.
time_difference: '+1 hour' # Optional (default: +1 hour)
# time_difference: '+3 hours'
# time_difference: '-2 hours'runtime: # Optional
# This is a default concurrency limit value
# This value can be overridden in the job orchestrating command.
concurrency_limit: 4 # Optional (default: 4)```
At this point, you should have the bundle imported and working.
Next you need to configure the **job orchestrating command** to run non-stop.
Check out the steps below.--------------------------------------------------------------------------------
Next steps
----------
- Check out the [Console commands](docs/console.md) to get the system up and running.
This step is vital to get the orchestration of job containers up and running.- Check out the [Monitoring dashboard](docs/dashboard.md) that you can activate if you wish.
--------------------------------------------------------------------------------
License
-------- [Review](LICENSE)