phplaraveldockerkuberneteslaravel-horizon

Laravel Horizon not executing pending jobs - Kubernetes and Docker environment


We have two different pods in Kubernetes for our Laravel app,

The issue is when I check the horizon dashboard, it says 'Active', and I can see the Jobs in the 'Pending Jobs' section, but they never actually execute. They are just sitting there idle.

Now, when I SSH in the pod running apache and manually and run the command 'php artisan horizon' than it actually executes all pending jobs.

I have already ensured the followings:

  1. Both the pods are connected with the same Redis database service
  2. Horizon Prefix is the same for both the pods

Solution

  • After struggling for days, I got the answer to this problem.

    While using Redis as a cache, queue, or broadcast broker in the docker environment, we need to make sure that the following environment variables are defined properly and they must be the same across all the pods.

    Hope this will help others trying to deploy the Laravel apps using Kubernetes and Docker.