https://dev.to/bernardwiesner https://laravel.com/docs/9.x/queues is great and easy to use, however one big disadvantage is it's not microservice friendly. You would need to write your job inside the same repo as your web app, and when you deploy to production, you would need to deploy both your web app and your batch server that is running the queue worker with the same repo code.
The subscriptions will get processed on a separate repo, we can call it a PubSub API repo.
Configure your subscription as push and enter your PubSub API endpoint (your laravel dedicated repo to process subscriptions): https://res.cloudinary.com/practicaldev/image/fetch/s--Q957GsmB--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/od6b12ke9jbpza302xu4.png
By using GCP PubSub and a dedicated laravel API for processing jobs you can scale your jobs and benefit from a microservice architecture.