You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
87 lines
2.2 KiB
87 lines
2.2 KiB
#!/bin/bash
|
|
# info: list mysql config parameters
|
|
# options: [FORMAT]
|
|
#
|
|
# example: v-list-sys-mysql-config
|
|
#
|
|
# This function for obtaining the list of mysql config parameters.
|
|
|
|
#----------------------------------------------------------#
|
|
# Variables & Functions #
|
|
#----------------------------------------------------------#
|
|
|
|
# Argument definition
|
|
format=${1-shell}
|
|
|
|
# Includes
|
|
# shellcheck source=/etc/hestiacp/hestia.conf
|
|
source /etc/hestiacp/hestia.conf
|
|
# shellcheck source=/usr/local/hestia/func/main.sh
|
|
source $HESTIA/func/main.sh
|
|
# load config file
|
|
source_conf "$HESTIA/conf/hestia.conf"
|
|
|
|
# JSON list function
|
|
json_list() {
|
|
str=$(echo "$config" | egrep "$keys" \
|
|
| sed -e "s/[ ]*=/=/" -e "s/=[ ]*/=\'/" -e "s/$/'/")
|
|
parse_object_kv_list "$str"
|
|
echo '{
|
|
"CONFIG": {
|
|
"max_user_connections": "'$max_user_connections'",
|
|
"max_connections": "'$max_connections'",
|
|
"wait_timeout": "'$wait_timeout'",
|
|
"interactive_timeout": "'$interactive_timeout'",
|
|
"max_allowed_packet": "'$max_allowed_packet'",
|
|
"config_path": "'$config_path'"
|
|
}
|
|
}'
|
|
}
|
|
|
|
# SHELL list function
|
|
shell_list() {
|
|
echo "$config" | egrep "$keys" | tr '=' ' '
|
|
echo "config_path $config_path"
|
|
}
|
|
|
|
# PLAIN list function
|
|
plain_list() {
|
|
echo "$config" | egrep "$keys" | tr '=' ' '
|
|
echo "config_path $config_path"
|
|
}
|
|
|
|
# CSV list function
|
|
csv_list() {
|
|
echo "$keys" | sed "s/|/,/g"
|
|
echo "$config" | egrep "$keys" | tr '=' ' ' | awk '{print $2}' | tr '\n' ','
|
|
echo
|
|
}
|
|
|
|
#----------------------------------------------------------#
|
|
# Action #
|
|
#----------------------------------------------------------#
|
|
|
|
# Defining config path
|
|
config_path=$(find /etc/my* -name my.cnf)
|
|
|
|
# Defining keys
|
|
keys="max_user_connections|max_connections|wait_timeout|interactive_timeout"
|
|
keys="${keys}|max_allowed_packet"
|
|
|
|
# Reading config
|
|
config=$(cat $config_path | grep -v "^;")
|
|
|
|
# Listing data
|
|
case $format in
|
|
json) json_list ;;
|
|
plain) plain_list ;;
|
|
csv) csv_list ;;
|
|
shell) shell_list | column -t ;;
|
|
esac
|
|
|
|
#----------------------------------------------------------#
|
|
# Hestia #
|
|
#----------------------------------------------------------#
|
|
|
|
exit
|