stackkit / laravel-google-cloud-tasks-queue
Fund package maintenance!
marickvantuil
Installs: 341 090
Dependents: 0
Suggesters: 0
Security: 0
Stars: 69
Watchers: 4
Forks: 37
Open Issues: 5
Requires
- php: ^8.1
- ext-json: *
- google/cloud-tasks: ^1.10
- phpseclib/phpseclib: ^3.0
- thecodingmachine/safe: ^1.0|^2.0
Requires (Dev)
- larastan/larastan: ^2.9
- laravel/legacy-factories: ^1.3
- laravel/pint: ^1.13
- orchestra/testbench: ^8.0
- thecodingmachine/phpstan-safe-rule: ^1.2
- dev-master
- 4.x-dev
- v4.2.3-beta.5
- v4.2.3-beta.4
- v4.2.3-beta.3
- v4.2.3-beta.2
- v4.2.3-beta.1
- v4.2.2
- v4.2.1
- v4.2.0
- v4.1.1
- v4.1.0
- v4.0.0
- v4.0.0-beta.2
- v4.0.0-beta.1
- 3.x-dev
- v3.7.0
- v3.7.0-beta.2
- v3.7.0-beta.1
- v3.6.6
- v3.6.5
- v3.6.4
- v3.6.3
- v3.6.2
- v3.6.1
- v3.6.0
- v3.5.2
- v3.5.1
- v3.5.0
- v3.4.1
- v3.4.1-rc1
- v3.4.0
- v3.3.3
- v3.3.2
- v3.3.1
- v3.3.0
- v3.3.0-beta1
- v3.2.1
- v3.2.0
- v3.1.4
- v3.1.3
- v3.1.2
- v3.1.1
- v3.1.0
- v3.0.0
- v3.0.0-beta3
- v3.0.0-beta2
- v3.0.0-beta1
- 2.x-dev
- v2.3.0
- v2.2.1
- v2.2.0
- v2.2.0-beta1
- v2.1.3
- v2.1.2
- v2.1.1
- v2.1.0
- v2.1.0-beta1
- v2.0.1
- v2.0.0
- 1.x-dev
- v1.0.0
- v1.0.0-alpha1
- dev-bugfix/reset-pcntl-alarm
- dev-feature/custom-cloud-tasks-client-options
This package is auto-updated.
Last update: 2025-01-10 21:00:42 UTC
README
Companion packages: Cloud Scheduler, Cloud Logging
Introduction
This package allows Google Cloud Tasks to be used as the queue driver.
Requirements
This package requires Laravel 10 or 11.
Installation
Require the package using Composer
composer require stackkit/laravel-google-cloud-tasks-queue
Add a new queue connection to config/queue.php
'cloudtasks' => [ 'driver' => 'cloudtasks', 'project' => env('CLOUD_TASKS_PROJECT', ''), 'location' => env('CLOUD_TASKS_LOCATION', ''), 'queue' => env('CLOUD_TASKS_QUEUE', 'default'), // Required when using AppEngine 'app_engine' => env('APP_ENGINE_TASK', false), 'app_engine_service' => env('APP_ENGINE_SERVICE', ''), // Required when not using AppEngine 'handler' => env('CLOUD_TASKS_HANDLER', ''), 'service_account_email' => env('CLOUD_TASKS_SERVICE_EMAIL', ''), 'backoff' => 0, ],
Finally, change the QUEUE_CONNECTION
to the newly defined connection.
QUEUE_CONNECTION=cloudtasks
Now that the package is installed, the final step is to set the correct environment variables.
Please check the table below on what the values mean and what their value should be.
Optionally, you may publish the config file:
php artisan vendor:publish --tag=cloud-tasks
If you are using separate services for dispatching and handling tasks, and your application only dispatches jobs and should not be able to handle jobs, you may disable the task handler from config/cloud-tasks.php
:
'disable_task_handler' => env('CLOUD_TASKS_DISABLE_TASK_HANDLER', false),
How to
Passing headers to a task
You can pass headers to a task by using the setTaskHeadersUsing
method on the CloudTasksQueue
class.
use Stackkit\LaravelGoogleCloudTasksQueue\CloudTasksQueue; CloudTasksQueue::setTaskHeadersUsing(static fn() => [ 'X-My-Header' => 'My-Value', ]);
If necessary, the current payload being dispatched is also available:
use Stackkit\LaravelGoogleCloudTasksQueue\CloudTasksQueue; CloudTasksQueue::setTaskHeadersUsing(static fn(array $payload) => [ 'X-My-Header' => $payload['displayName'], ]);
Configure task handler url
You can set the handler url for a task by using the configureHandlerUrlUsing
method on the CloudTasksQueue
class.
use Stackkit\LaravelGoogleCloudTasksQueue\CloudTasksQueue; CloudTasksQueue::configureHandlerUrlUsing(static fn() => 'https://example.com/my-url');
If necessary, the current job being dispatched is also available:
use Stackkit\LaravelGoogleCloudTasksQueue\CloudTasksQueue; CloudTasksQueue::configureHandlerUrlUsing(static fn(MyJob $job) => 'https://example.com/my-url/' . $job->something());
Configure worker options
You can configure worker options by using the configureWorkerOptionsUsing
method on the CloudTasksQueue
class.
use Stackkit\LaravelGoogleCloudTasksQueue\IncomingTask; CloudTasksQueue::configureWorkerOptionsUsing(function (IncomingTask $task) { $queueTries = [ 'high' => 5, 'low' => 1, ]; return new WorkerOptions(maxTries: $queueTries[$task->queue()] ?? 1); });
Use a custom credentials file
Modify (or add) the client_options
key in the config/cloud-tasks.php
file:
'client_options' => [ 'credentials' => '/path/to/credentials.json', ]
Modify CloudTasksClient options
Modify (or add) the client_options
key in the config/cloud-tasks.php
file:
'client_options' => [ // custom options here ]
How it works and differences
Using Cloud Tasks as a Laravel queue driver is fundamentally different than other Laravel queue drivers, like Redis.
Typically a Laravel queue has a worker that listens to incoming jobs using the queue:work
/ queue:listen
command.
With Cloud Tasks, this is not the case. Instead, Cloud Tasks will schedule the job for you and make an HTTP request to
your application with the job payload. There is no need to run a queue:work/listen
command.
Good to know
Cloud Tasks has it's own retry configuration options: maximum number of attempts, retry duration, min/max backoff and max doublings. All of these options are ignored by this package. Instead, you may configure max attempts, retry duration and backoff strategy right from Laravel.
Authentication
Set the GOOGLE_APPLICATION_CREDENTIALS
environment variable with a path to the credentials file.
More info: https://cloud.google.com/docs/authentication/production
If you're not using your master service account (which has all abilities), you must add the following roles to make it works:
- App Engine Viewer
- Cloud Tasks Enqueuer
- Cloud Tasks Viewer
- Cloud Tasks Task Deleter
- Service Account User
Upgrading
Read UPGRADING.MD on how to update versions.
Troubleshooting
HttpRequest.url must start with 'https://'
This can happen when your application runs behind a reverse proxy. To fix this, add the application domain to Laravel's trusted proxies. You may need to add the wildcard *
as trusted proxy.
Maximum call stack size (zend.max_allowed_stack_size - zend.reserved_stack_size) reached. Infinite recursion?
This currently seems to be a bug with PHP 8.3 and googleapis/gax-php
. See this issue for more information.
A potential workaround is to disable PHP 8.3 call stack limit by setting this value in php.ini
:
zend.max_allowed_stack_size: -1
Contributing
You can use the services defined in docker-compose.yml
to start running the package.
Inside the container, run composer install
.
Set up the environment: cp .env.example .env
Some tests hit the Cloud Tasks API and need a project and key to be able to hit it. See the variables in .env