forked from jguay/ElasticMisc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmigrateIndicesToTierPreference.sh
executable file
·132 lines (118 loc) · 5.78 KB
/
migrateIndicesToTierPreference.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
#!/bin/bash
#### SETTINGS TO CHANGE ####
elasticsearchBaseURL="https://localhost:9200"
username="elastic"
settingUsedForAllocation="index.routing.allocation.require.data"
#For next 3 settings : To skip ; use empty string : ""
valueUsedForHot="hot"
valueUsedForWarm="warm"
valueUsedForCold=""
#### DO NOT CHANGE BELOW SETTINGS ####
password="" # leave this empty to get prompted to not expose sensitive information
############################
# https://www.elastic.co/guide/en/elasticsearch/reference/7.17/migrate-index-allocation-filters.html#set-tier-preference
# This is an example after moving to data tiers and having many indices using custom node attributes
# The script will find indices in hot/warm/cold to remove the customer node attributes and set tier preference
# requires curl,jq,bash and setting the URL, the setting used for attribute-based allocation filters and value used
############################
function log () {
# parameter 1 is message
# parameter 2 log level - ERROR will cause script to exit
echo "[$(date -u)] $2 - $1"
if [[ "$2" = "ERROR" ]]; then
exit 4
fi
}
function checkCommand () {
if [[ $(command -v "$1" | wc -l) -eq 0 ]]; then
log "command [${1}] not found, please install and ensure it's configured in the PATH" "ERROR"
fi
}
function getIndicesWithSetting () {
# parameter 1 will be the index setting to look for
# parameter 2 will be the index setting value to look for
# function will store result in array variable targetIndices
if [[ ( -z "$1" ) || ( -z "$2") ]]; then
log "Missing mandatory parameter 1[${1}] or 2[${2}] for getIndicesWithSetting call" "ERROR"
fi
listOfIndices=""
#note this is 7.7.0+ syntax here
listOfIndices=($(curl -k -s -u "${username}:${password}" "${elasticsearchBaseURL}/_settings?pretty&human&expand_wildcards=all" | jq --raw-output "to_entries[] | select (.value.settings.${1} == \"${2}\") | select (.value.settings.index.routing.allocation.include._tier_preference == null) | .key"))
#if script is run late and ILM already tried to move old indices; for example require hot with preference data_warm,data_hot with indeex in warm in ILM explain
listOfIndicesWithTierPreference=""
listOfIndicesWithTierPreference=($(curl -k -s -u "${username}:${password}" "${elasticsearchBaseURL}/_settings?pretty&human&expand_wildcards=all" | jq --raw-output "to_entries[] | select (.value.settings.${1} == \"${2}\") | select (.value.settings.index.routing.allocation.include._tier_preference) | .key"))
}
function updateIndicesWithSetting () {
# parameter 1 will be the index setting to set
# parameter 2 will be the index setting value to set - note double-quote are needed to allow for value null
# parameter 3 (optional) will be a second index setting to set
# parameter 4 (optional) will be a second index setting value to set - note double-quote are needed to allow for value null
if [[ -n "$listOfIndices" ]]; then
if [[ ( -n "$1" ) && ( -n "$2" ) ]]; then
jsonPayload="{ \"${1}\" : ${2}"
if [[ ( -n "$3" ) && ( -n "$4" ) ]]; then
jsonPayload="${jsonPayload}, \"${3}\" : ${4}"
fi
jsonPayload="${jsonPayload} }"
else
log "Missing mandatory parameter 1[${1}] or 2[${2}] for updateIndicesWithSetting call" "ERROR"
fi
for index in "${listOfIndices[@]}"
do
log "processing index [${index}] to put settings [${jsonPayload}]"
response_code=$(curl -k -s -H 'Content-Type: application/json' -o /dev/null -w "%{http_code}" -u "${username}:${password}" -XPUT "${elasticsearchBaseURL}/${index}/_settings" -d "${jsonPayload}")
if [[ ! "$response_code" == "200" ]]; then
log "HTTP response [${response_code}] returned" "ERROR"
fi
done
fi
}
function removeFilteringForIndicesAlreadyUsingTierPreference () {
jsonPayload="{\"${1}\":null}"
for index in "${listOfIndicesWithTierPreference[@]}"
do
log "processing index [${index}] to put settings [${jsonPayload}]"
response_code=$(curl -k -s -H 'Content-Type: application/json' -o /dev/null -w "%{http_code}" -u "${username}:${password}" -XPUT "${elasticsearchBaseURL}/${index}/_settings" -d "${jsonPayload}")
if [[ ! "$response_code" == "200" ]]; then
log "HTTP response [${response_code}] returned" "ERROR"
fi
done
}
function checkPrerequisites () {
checkCommand "jq"
checkCommand "curl"
checkCommand "wc"
}
function moveIndicesToTierPreference () {
if [[ -n "$valueUsedForHot" ]]; then
getIndicesWithSetting "$settingUsedForAllocation" "$valueUsedForHot"
updateIndicesWithSetting "$settingUsedForAllocation" "null" "index.routing.allocation.include._tier_preference" "\"data_hot\""
removeFilteringForIndicesAlreadyUsingTierPreference "$settingUsedForAllocation"
fi
if [[ -n "$valueUsedForWarm" ]]; then
getIndicesWithSetting "$settingUsedForAllocation" "$valueUsedForWarm"
updateIndicesWithSetting "$settingUsedForAllocation" "null" "index.routing.allocation.include._tier_preference" "\"data_warm,data_hot\""
removeFilteringForIndicesAlreadyUsingTierPreference "$settingUsedForAllocation"
fi
if [[ -n "$valueUsedForCold" ]]; then
getIndicesWithSetting "$settingUsedForAllocation" "$valueUsedForCold"
updateIndicesWithSetting "$settingUsedForAllocation" "null" "index.routing.allocation.include._tier_preference" "\"data_cold,data_warm,data_hot\""
removeFilteringForIndicesAlreadyUsingTierPreference "$settingUsedForAllocation"
fi
}
function verifyESConnectivity () {
if [[ -z "$password" ]]; then
echo -n "Enter a password for user [${username}]: "
read -s password
fi
response_code=$(curl -k -s -o /dev/null -I -w "%{http_code}" -u "${username}:${password}" "$elasticsearchBaseURL")
if [[ ! "$response_code" == "200" ]]; then
log "Connection to Elasticsearch failed with HTTP response [${response_code}] for user [${username}] and URL [${elasticsearchBaseURL}]" "ERROR"
fi
}
function run () {
checkPrerequisites
verifyESConnectivity
moveIndicesToTierPreference
}
run