{"id":24919,"date":"2021-11-12T09:59:00","date_gmt":"2021-11-12T09:59:00","guid":{"rendered":"https:\/\/www.devopsschool.com\/blog\/?p=24919"},"modified":"2021-11-20T06:07:43","modified_gmt":"2021-11-20T06:07:43","slug":"supervisor-fatal-backoff-exited-too-quickly-process-log-may-have-details","status":"publish","type":"post","link":"https:\/\/www.devopsschool.com\/blog\/supervisor-fatal-backoff-exited-too-quickly-process-log-may-have-details\/","title":{"rendered":"[SOLVED] Laravel : Supervisor FATAL\/BACKOFF Exited too quickly (process log may have details)"},"content":{"rendered":"\n<h1 class=\"has-text-align-center wp-block-heading\"><span class=\"has-inline-color has-vivid-red-color\">Problem<\/span><\/h1>\n\n\n\n<p>I&#8217;m trying to use Laravel queues with a supervisor but the service is not working properly.<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-1\" data-shcb-language-name=\"PHP\" data-shcb-language-slug=\"php\"><span><code class=\"hljs language-php\">&lt;strong&gt;My config \/etc\/supervisord.d\/laravel-worker.conf is:&lt;\/strong&gt;\n&#91;program:laravel-worker]\nprocess_name=%(program_name)s_%(process_num)<span class=\"hljs-number\">02<\/span>d\ncommand=\/usr\/bin\/php \/<span class=\"hljs-keyword\">var<\/span>\/www\/my-project\/artisan queue:work --sleep=<span class=\"hljs-number\">3<\/span> --tries=<span class=\"hljs-number\">3<\/span>\nautostart=<span class=\"hljs-keyword\">true<\/span>\nautorestart=<span class=\"hljs-keyword\">true<\/span>\nuser=root:root\nnumprocs=<span class=\"hljs-number\">8<\/span>\nredirect_stderr=<span class=\"hljs-keyword\">true<\/span>\nstdout_logfile=\/<span class=\"hljs-keyword\">var<\/span>\/www\/my-project\/worker.log<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-1\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">PHP<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">php<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p><\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-2\" data-shcb-language-name=\"HTML, XML\" data-shcb-language-slug=\"xml\"><span><code class=\"hljs language-xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">strong<\/span>&gt;<\/span>When I try to restart all programs:<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">strong<\/span>&gt;<\/span>\n$ sudo supervisorctl restart all\n$ laravel-worker:laravel-worker_00: ERROR (abnormal termination)\n$ laravel-worker:laravel-worker_01: ERROR (abnormal termination)<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-2\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">HTML, XML<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">xml<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p><\/p>\n\n\n\n<p><strong>When I try to check status:<\/strong><br>$ sudo supervisorctl status<br>$ laravel-worker:laravel-worker_00:    BACKOFF   Exited too quickly (process log may have details)<br>$ laravel-worker:laravel-worker_00:    BACKOFF   Exited too quickly (process log may have details)<\/p>\n\n\n\n<p><\/p>\n\n\n\n<h1 class=\"has-text-align-center wp-block-heading\"><span class=\"has-inline-color has-vivid-red-color\">Solution<\/span><\/h1>\n\n\n\n<p>In my case, the supervisor was exiting very fast because it was finishing before the startsecs and since startsecs wasn&#8217;t defined, it uses the default which is 1.<\/p>\n\n\n\n<p>Setting&nbsp;<code><span class=\"has-inline-color has-vivid-red-color\"><strong>startsecs=0<\/strong><\/span><\/code>&nbsp;fixed my issue.<\/p>\n\n\n\n<p><\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-3\" data-shcb-language-name=\"HTML, XML\" data-shcb-language-slug=\"xml\"><span><code class=\"hljs language-xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">strong<\/span>&gt;<\/span>you need to add startsecs = 0 to your laravel-worker config like so:<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">strong<\/span>&gt;<\/span>\n&#91;program:laravel-worker]     \nprocess_name=%(program_name)s_%(process_num)02d\ncommand=\/usr\/bin\/php \/var\/www\/my-project\/artisan queue:work --sleep=3 --tries=3\n.....\nstartsecs = 0<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-3\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">HTML, XML<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">xml<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p><\/p>\n\n\n\n<p><span class=\"has-inline-color has-vivid-red-color\"><strong><code>startsecs<\/code>&nbsp;<\/strong><\/span>is default to 1s, if the program does not stay up for 1s it will see the startup as a failure. Set it to 0 so the program needn\u2019t stay running for any particular amount of time. You can check this GitHub issue for more info:&nbsp;<a href=\"https:\/\/github.com\/Supervisor\/supervisor\/issues\/212\" target=\"_blank\" rel=\"noopener\">https:\/\/github.com\/Supervisor\/supervisor\/issues\/212<\/a><\/p>\n\n\n\n<p>It would be better if you run the queue worker in daemon mode, use the &#8211;daemon flag:&nbsp;<code>command=\/usr\/bin\/php \/var\/www\/my-project\/artisan queue:work database --daemon --sleep=3 --tries=3<\/code><\/p>\n\n\n\n<p>After you change the config file, you may need to run\u00a0<code><span class=\"has-inline-color has-vivid-red-color\"><strong>supervisorctl reload<\/strong><\/span><\/code>\u00a0to allow the changes to take effect.<\/p>\n\n\n<div class=\"epyt-gallery\" data-currpage=\"1\" id=\"epyt_gallery_44957\"><iframe loading=\"lazy\"  id=\"_ytid_67728\"  width=\"760\" height=\"427\"  data-origwidth=\"760\" data-origheight=\"427\" src=\"https:\/\/www.youtube.com\/embed\/?enablejsapi=1&#038;autoplay=0&#038;cc_load_policy=0&#038;cc_lang_pref=&#038;iv_load_policy=1&#038;loop=0&#038;rel=1&#038;fs=1&#038;playsinline=0&#038;autohide=2&#038;theme=dark&#038;color=red&#038;controls=1&#038;disablekb=0&#038;\" class=\"__youtube_prefs__  no-lazyload\" title=\"YouTube player\"  data-epytgalleryid=\"epyt_gallery_44957\"  allow=\"fullscreen; accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share\" referrerpolicy=\"strict-origin-when-cross-origin\" allowfullscreen data-no-lazy=\"1\" data-skipgform_ajax_framebjll=\"\"><\/iframe><div class=\"epyt-gallery-list\"><div>Sorry, there was a YouTube error.<\/div><\/div><\/div>","protected":false},"excerpt":{"rendered":"<p>Problem I&#8217;m trying to use Laravel queues with a supervisor but the service is not working properly. When I try to check status:$ sudo supervisorctl status$ laravel-worker:laravel-worker_00: BACKOFF Exited too&#8230; <\/p>\n","protected":false},"author":19,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_joinchat":[],"footnotes":""},"categories":[4957,5201],"tags":[7101,7100,7096,7098,7099,7097,7102],"class_list":["post-24919","post","type-post","status-publish","format-standard","hentry","category-linux","category-laravel","tag-fatal-state","tag-process-log-may-have-details","tag-supervisor","tag-supervisor-backoff","tag-supervisor-exited-too-quickly","tag-supervisor-fatal","tag-too-many-start-retries-too-quickly"],"_links":{"self":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts\/24919","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/users\/19"}],"replies":[{"embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/comments?post=24919"}],"version-history":[{"count":11,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts\/24919\/revisions"}],"predecessor-version":[{"id":25897,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts\/24919\/revisions\/25897"}],"wp:attachment":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/media?parent=24919"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/categories?post=24919"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/tags?post=24919"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}