Created
August 16, 2017 16:26
-
-
Save rbrisita/0b360d35c88ebd85c10e17fcd947c849 to your computer and use it in GitHub Desktop.
A non-interactive replacement for mysql_secure_installation.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#! /bin/sh | |
# | |
# Author: Bert Van Vreckem <[email protected]> | |
# | |
# A non-interactive replacement for mysql_secure_installation | |
# | |
# Tested on CentOS 6, CentOS 7, Ubuntu 12.04 LTS (Precise Pangolin), Ubuntu | |
# 14.04 LTS (Trusty Tahr). | |
# | |
# Slighlty modified for MySQL 5.7 - Robert Brisita <[first-initial][last name] at gmail dot com> | |
set -o errexit # abort on nonzero exitstatus | |
set -o nounset # abort on unbound variable | |
#{{{ Functions | |
usage() { | |
cat << _EOF_ | |
Usage: ${0} "ROOT PASSWORD" | |
with "ROOT PASSWORD" the desired password for the database root user. | |
Use quotes if your password contains spaces or other special characters. | |
_EOF_ | |
} | |
# Predicate that returns exit status 0 if the database root password | |
# is set, a nonzero exit status otherwise. | |
is_mysql_root_password_set() { | |
! mysqladmin --user=root status > /dev/null 2>&1 | |
} | |
# Predicate that returns exit status 0 if the mysql(1) command is available, | |
# nonzero exit status otherwise. | |
is_mysql_command_available() { | |
which mysql > /dev/null 2>&1 | |
} | |
#}}} | |
#{{{ Command line parsing | |
if [ "$#" -ne "1" ]; then | |
echo "Expected 1 argument, got $#" >&2 | |
usage | |
exit 2 | |
fi | |
#}}} | |
#{{{ Variables | |
db_root_password="${1}" | |
#}}} | |
# Script proper | |
if ! is_mysql_command_available; then | |
echo "The MySQL/MariaDB client mysql(1) is not installed." | |
exit 1 | |
fi | |
if is_mysql_root_password_set; then | |
echo "Database root password already set" | |
exit 0 | |
fi | |
mysql --user=root <<_EOF_ | |
UPDATE mysql.user SET authentication_string=PASSWORD('${db_root_password}') WHERE User='root'; | |
DELETE FROM mysql.user WHERE User=''; | |
DELETE FROM mysql.user WHERE User='root' AND Host NOT IN ('localhost', '127.0.0.1', '::1'); | |
DROP DATABASE IF EXISTS test; | |
DELETE FROM mysql.db WHERE Db='test' OR Db='test\\_%'; | |
FLUSH PRIVILEGES; | |
_EOF_ |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment