Skip to content

Commit

Permalink
Fix yellow cluster state (#95)
Browse files Browse the repository at this point in the history
* Add template and settings to disable replicas on ISM plugin internal indices

* Fix documentation

Replaces exit 1 statements with return 1

* Fix uncommented comment line
  • Loading branch information
AlexRuiz7 committed Sep 9, 2024
1 parent 50db9af commit 7216ce7
Showing 1 changed file with 78 additions and 10 deletions.
88 changes: 78 additions & 10 deletions distribution/src/bin/indexer-ism-init.sh
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,48 @@ function generate_rollover_template() {
EOF
}

#########################################################################
# Creates an index template to disable replicas on ISM configurastion indices.
# Returns:
# The index template as a JSON string.
#########################################################################
function generate_ism_config_template() {
cat <<-EOF
{
"order": 1,
"index_patterns": [
".opendistro-ism-managed-index-history-*",
".opendistro-ism-config",
".opendistro-job-scheduler-lock"
],
"settings": {
"number_of_replicas": 0
}
}
EOF
}

#########################################################################
# Creates persistent cluster's settings to disable replicas for ISM history.
# Returns:
# The setting as a JSON string.
#########################################################################
function generate_ism_config() {
cat <<-EOF
{
"persistent": {
"plugins": {
"index_state_management": {
"history": {
"number_of_replicas": "0"
}
}
}
}
}
EOF
}

#########################################################################
# Loads the index templates for the rollover policy to the indexer.
#########################################################################
Expand All @@ -89,18 +131,44 @@ function load_templates() {
echo "Will create 'wazuh' index template"
if [ -f $wazuh_template_path ]; then
cat $wazuh_template_path |
if ! curl -s -k ${C_AUTH} \
-X PUT "${INDEXER_URL}/_template/wazuh" \
-o "${LOG_FILE}" --create-dirs \
-H 'Content-Type: application/json' -d @-; then
echo " ERROR: 'wazuh' template creation failed"
return 1
else
echo " SUCC: 'wazuh' template created or updated"
fi
else
echo " ERROR: $wazuh_template_path not found"
fi

# Load template for ISM configuration indices
echo "Will create 'ism_history_indices' index template"
generate_ism_config_template |
if ! curl -s -k ${C_AUTH} \
-X PUT "${INDEXER_URL}/_template/wazuh" \
-X PUT "${INDEXER_URL}/_template/ism_history_indices" \
-o "${LOG_FILE}" --create-dirs \
-H 'Content-Type: application/json' -d @-; then
echo " ERROR: 'wazuh' template creation failed"
exit 1
echo " ERROR: 'ism_history_indices' template creation failed"
return 1
else
echo " SUCC: 'wazuh' template created or updated"
echo " SUCC: 'ism_history_indices' template created or updated"
fi

# Make settings persistent
echo "Will disable replicas for 'plugins.index_state_management.history' indices"
generate_ism_config |
if ! curl -s -k ${C_AUTH} \
-X PUT "${INDEXER_URL}/_cluster/settings" \
-o "${LOG_FILE}" --create-dirs \
-H 'Content-Type: application/json' -d @-; then
echo " ERROR: cluster's settings update failed"
return 1
else
echo " SUCC: cluster's settings saved"
fi
else
echo " ERROR: $wazuh_template_path not found"
fi

echo "Will create index templates to configure the alias"
for alias in "${aliases[@]}"; do
Expand Down Expand Up @@ -201,7 +269,7 @@ function create_write_index() {
-H 'Content-Type: application/json' \
-d "$(generate_write_index_alias "${1}")"; then
echo " ERROR: creating '${1}' write index"
exit 1
return 1
else
echo " SUCC: '${1}' write index created"
fi
Expand Down Expand Up @@ -263,7 +331,7 @@ function show_help() {
echo -e " -v, --verbose"
echo -e " Set verbose mode. Prints more information."
echo -e ""
exit 1
return 1
}

#########################################################################
Expand Down Expand Up @@ -353,7 +421,7 @@ function main() {
echo "SUCC: Indexer ISM initialization finished successfully."
else
echo "ERROR: Indexer ISM initialization failed. Check ${LOG_FILE} for more information."
exit 1
return 1
fi
}

Expand Down

0 comments on commit 7216ce7

Please sign in to comment.