After allocating node would have less than the required free disk threshold free preventing allocation – How to solve this Elasticsearch error

Opster Team

Aug-23, Version: 1.5-1.5

Briefly, this error occurs when Elasticsearch tries to allocate shards to a node, but the node doesn’t have enough free disk space. Elasticsearch has a disk watermark threshold to prevent disk space issues. If the free disk space falls below this threshold, Elasticsearch will not allocate new shards to that node. To resolve this issue, you can either increase the disk space on the node, delete unnecessary data to free up space, or adjust the disk watermark thresholds in the Elasticsearch settings. However, be cautious with the last option as it could lead to disk space issues.

This guide will help you check for common problems that cause the log ” After allocating; node [{}] would have less than the required {} free disk threshold ({} free); preventing allocation ” to appear. To understand the issues related to this log, read the explanation below about the following Elasticsearch concepts: allocation, cluster, node, routing and threshold.

Log Context

Log “After allocating; node [{}] would have less than the required {} free disk threshold ({} free); preventing allocation” classname is DiskThresholdDecider.java.
We extracted the following from Elasticsearch source code for those seeking an in-depth context :

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
node.nodeId(); freeBytesThresholdHigh; freeBytesAfterShard);
return allocation.decision(Decision.NO; NAME; "after allocation less than required [%s] free on node; free: [%s]";
freeBytesThresholdLow; new ByteSizeValue(freeBytesAfterShard));
}
if (freeSpaceAfterShard
<p> </p>
<p></p><div class="rmp-widgets-container rmp-wp-plugin rmp-main-container js-rmp-widgets-container js-rmp-widgets-container--1057 " data-post-id="1057"> <div class="rmp-rating-widget js-rmp-rating-widget"> <p class="rmp-heading rmp-heading--title"> How helpful was this guide? </p> <div class="rmp-rating-widget__icons"> <ul class="rmp-rating-widget__icons-list js-rmp-rating-icons-list"> <li class="rmp-rating-widget__icons-list__icon js-rmp-rating-item" data-descriptive-rating="Not at all useful" data-value="1"> <i class="js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star "></i> </li> <li class="rmp-rating-widget__icons-list__icon js-rmp-rating-item" data-descriptive-rating="Somewhat useful" data-value="2"> <i class="js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star "></i> </li> <li class="rmp-rating-widget__icons-list__icon js-rmp-rating-item" data-descriptive-rating="Useful" data-value="3"> <i class="js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star "></i> </li> <li class="rmp-rating-widget__icons-list__icon js-rmp-rating-item" data-descriptive-rating="Fairly useful" data-value="4"> <i class="js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star "></i> </li> <li class="rmp-rating-widget__icons-list__icon js-rmp-rating-item" data-descriptive-rating="Very useful" data-value="5"> <i class="js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star "></i> </li> </ul> </div> <p class="rmp-rating-widget__hover-text js-rmp-hover-text"></p> <button class="rmp-rating-widget__submit-btn rmp-btn js-submit-rating-btn"> Submit Rating </button> <p class="rmp-rating-widget__results js-rmp-results "> </p> <p class="rmp-rating-widget__not-rated js-rmp-not-rated rmp-rating-widget__not-rated--hidden"> </p> <p class="rmp-rating-widget__msg js-rmp-msg"></p> </div> <div class="rmp-feedback-widget js-rmp-feedback-widget"> <p class="rmp-heading rmp-heading--title"> We are sorry that this post was not useful for you! </p> <p class="rmp-heading rmp-heading--subtitle"> Let us improve this post! </p> <div class="rmp-feedback-widget__container"> <p class="rmp-feedback-widget__text"> Tell us how we can improve this post? </p> <textarea class="rmp-feedback-widget__input js-rmp-feedback-input" rows="5" id="feedback-text"></textarea> <button type="button" class="rmp-feedback-widget__btn rmp-btn rmp-btn--large js-rmp-feedback-button"> Submit Feedback </button> <div class="rmp-feedback-widget__loader js-rmp-feedback-loader"> <div></div><div></div><div></div> </div> <p class="rmp-feedback-widget__msg js-rmp-feedback-msg"></p> </div> </div> </div>
node.nodeId(); freeBytesThresholdHigh; freeBytesAfterShard); return allocation.decision(Decision.NO; NAME; "after allocation less than required [%s] free on node; free: [%s]"; freeBytesThresholdLow; new ByteSizeValue(freeBytesAfterShard)); } if (freeSpaceAfterShard <p> </p> <p></p><div class="rmp-widgets-container rmp-wp-plugin rmp-main-container js-rmp-widgets-container js-rmp-widgets-container--1057 " data-post-id="1057"> <div class="rmp-rating-widget js-rmp-rating-widget"> <p class="rmp-heading rmp-heading--title"> How helpful was this guide? </p> <div class="rmp-rating-widget__icons"> <ul class="rmp-rating-widget__icons-list js-rmp-rating-icons-list"> <li class="rmp-rating-widget__icons-list__icon js-rmp-rating-item" data-descriptive-rating="Not at all useful" data-value="1"> <i class="js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star "></i> </li> <li class="rmp-rating-widget__icons-list__icon js-rmp-rating-item" data-descriptive-rating="Somewhat useful" data-value="2"> <i class="js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star "></i> </li> <li class="rmp-rating-widget__icons-list__icon js-rmp-rating-item" data-descriptive-rating="Useful" data-value="3"> <i class="js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star "></i> </li> <li class="rmp-rating-widget__icons-list__icon js-rmp-rating-item" data-descriptive-rating="Fairly useful" data-value="4"> <i class="js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star "></i> </li> <li class="rmp-rating-widget__icons-list__icon js-rmp-rating-item" data-descriptive-rating="Very useful" data-value="5"> <i class="js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star "></i> </li> </ul> </div> <p class="rmp-rating-widget__hover-text js-rmp-hover-text"></p> <button class="rmp-rating-widget__submit-btn rmp-btn js-submit-rating-btn"> Submit Rating </button> <p class="rmp-rating-widget__results js-rmp-results "> </p> <p class="rmp-rating-widget__not-rated js-rmp-not-rated rmp-rating-widget__not-rated--hidden"> </p> <p class="rmp-rating-widget__msg js-rmp-msg"></p> </div> <div class="rmp-feedback-widget js-rmp-feedback-widget"> <p class="rmp-heading rmp-heading--title"> We are sorry that this post was not useful for you! </p> <p class="rmp-heading rmp-heading--subtitle"> Let us improve this post! </p> <div class="rmp-feedback-widget__container"> <p class="rmp-feedback-widget__text"> Tell us how we can improve this post? </p> <textarea class="rmp-feedback-widget__input js-rmp-feedback-input" rows="5" id="feedback-text"></textarea> <button type="button" class="rmp-feedback-widget__btn rmp-btn rmp-btn--large js-rmp-feedback-button"> Submit Feedback </button> <div class="rmp-feedback-widget__loader js-rmp-feedback-loader"> <div></div><div></div><div></div> </div> <p class="rmp-feedback-widget__msg js-rmp-feedback-msg"></p> </div> </div> </div>
node.nodeId(); freeBytesThresholdHigh; freeBytesAfterShard);
            return allocation.decision(Decision.NO; NAME; "after allocation less than required [%s] free on node; free: [%s]";
                    freeBytesThresholdLow; new ByteSizeValue(freeBytesAfterShard));
        }
        if (freeSpaceAfterShard 

 

How helpful was this guide?

We are sorry that this post was not useful for you!

Let us improve this post!

Tell us how we can improve this post?