mirror of
https://github.com/tteck/Proxmox.git
synced 2025-02-15 06:09:15 +01:00
112 lines
3.4 KiB
Bash
112 lines
3.4 KiB
Bash
#!/usr/bin/env bash
|
|
source <(curl -s https://raw.githubusercontent.com/tteck/Proxmox/main/misc/build.func)
|
|
# Copyright (c) 2021-2024 tteck
|
|
# Author: tteck (tteckster)
|
|
# Co-Author: T.H. (ELKozel)
|
|
# License: MIT
|
|
# https://github.com/tteck/Proxmox/raw/main/LICENSE
|
|
|
|
function header_info {
|
|
clear
|
|
cat <<"EOF"
|
|
________ __ _ __
|
|
/ ____/ /___ ______/ /_(_)____________ ____ ___________/ /_
|
|
/ __/ / / __ `/ ___/ __/ / ___/ ___/ _ \/ __ `/ ___/ ___/ __ \
|
|
/ /___/ / /_/ (__ ) /_/ / /__(__ ) __/ /_/ / / / /__/ / / /
|
|
/_____/_/\__,_/____/\__/_/\___/____/\___/\__,_/_/ \___/_/ /_/
|
|
|
|
EOF
|
|
}
|
|
header_info
|
|
echo -e "Loading..."
|
|
APP="Elasticsearch"
|
|
var_disk="6"
|
|
var_cpu="4"
|
|
var_ram="4096"
|
|
var_os="debian"
|
|
var_version="12"
|
|
variables
|
|
color
|
|
catch_errors
|
|
|
|
function default_settings() {
|
|
CT_TYPE="1"
|
|
PW=""
|
|
CT_ID=$NEXTID
|
|
HN=$NSAPP
|
|
DISK_SIZE="$var_disk"
|
|
CORE_COUNT="$var_cpu"
|
|
RAM_SIZE="$var_ram"
|
|
BRG="vmbr0"
|
|
NET="dhcp"
|
|
GATE=""
|
|
APT_CACHER=""
|
|
APT_CACHER_IP=""
|
|
DISABLEIP6="no"
|
|
MTU=""
|
|
SD=""
|
|
NS=""
|
|
MAC=""
|
|
VLAN=""
|
|
SSH="no"
|
|
VERB="no"
|
|
echo_default
|
|
}
|
|
|
|
function update_script() {
|
|
header_info
|
|
if [[ ! -f /etc/systemd/system/Elasticsearch.service ]]; then msg_error "No ${APP} Installation Found!"; exit; fi
|
|
if (( $(df /boot | awk 'NR==2{gsub("%","",$5); print $5}') > 80 )); then
|
|
read -r -p "Warning: Storage is dangerously low, continue anyway? <y/N> " prompt
|
|
[[ ${prompt,,} =~ ^(y|yes)$ ]] || exit
|
|
fi
|
|
|
|
msg_info "Updating ${APP} LXC"
|
|
apt-get update &>/dev/null
|
|
apt-get -y upgrade &>/dev/null
|
|
msg_ok "Updated ${APP} LXC"
|
|
|
|
exit
|
|
}
|
|
|
|
function ask_extend_mmap() {
|
|
# Check if max_map_count setting is set in sysctl.conf (It is not set by default)
|
|
# so if it is set, we don't want to override what the user has set
|
|
if ! grep -q "vm.max_map_count" /etc/sysctl.conf; then
|
|
echo "Elasticsearch recommends extending the vm.max_map_count on the host"
|
|
read -r -p "Would you like to extend mmap count? <y/N>" prompt
|
|
if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then
|
|
msg_info "Extending max mmap count"
|
|
echo "vm.max_map_count=262144" >>/etc/sysctl.conf
|
|
msg_ok "Extended max mmap count"
|
|
fi
|
|
fi
|
|
}
|
|
|
|
start
|
|
ask_extend_mmap
|
|
build_container
|
|
description
|
|
|
|
msg_info "Configuring User"
|
|
ELASTIC_USER=elastic
|
|
KIBANA_USER=kibana
|
|
ELASTIC_PASSWORD=$(lxc-attach -n "$CTID" -- bash -c "/usr/share/elasticsearch/bin/elasticsearch-reset-password -sbf -u $ELASTIC_USER" || exit)
|
|
KIBANA_TOKEN=$(lxc-attach -n "$CTID" -- bash -c "/usr/share/elasticsearch/bin/elasticsearch-create-enrollment-token -s $KIBANA_USER" || exit)
|
|
ENROLLMENT_TOKEN=$(lxc-attach -n "$CTID" -- bash -c "/usr/share/elasticsearch/bin/elasticsearch-create-enrollment-token -s node" || exit)
|
|
msg_ok "Configured User"
|
|
|
|
msg_info "Checking Health"
|
|
ELASTIC_PORT=9200
|
|
curl -s -XGET --insecure --fail --user $ELASTIC_USER:$ELASTIC_PASSWORD https://${IP}:$ELASTIC_PORT/_cluster/health?pretty >/dev/null
|
|
msg_ok "Cluster is healthy"
|
|
|
|
msg_ok "Completed Successfully!\n"
|
|
echo -e "${APP} is installed, you can check it's health by opening (using the user and password generated for you):
|
|
${BL}https://${IP}:$ELASTIC_PORT/_cluster/health?pretty${CL}
|
|
Elasticsearch credentials are:
|
|
User: ${BL}${ELASTIC_USER}${CL}
|
|
Password: ${BL}${ELASTIC_PASSWORD}${CL}
|
|
Enrollment and Kibana tokens were also generated for you:
|
|
Kibana Token: ${BL}${KIBANA_TOKEN}${CL}
|
|
Enrollment Token: ${BL}${ENROLLMENT_TOKEN}${CL} \n"
|