1
0
mirror of https://github.com/tommytran732/MariaDB-Root-Password-Reset synced 2024-11-13 22:51:33 -05:00
MariaDB-Root-Password-Reset/mariadb-103.sh

39 lines
1.1 KiB
Bash
Raw Normal View History

#!/bin/sh
# Copyright (C) 2023 Thien Tran
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may not
# use this file except in compliance with the License. You may obtain a copy of
# the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations under
# the License.
set -eu
2024-07-05 11:41:01 -04:00
2019-12-31 08:17:31 -05:00
output(){
printf '\e[1;34m%-6s\e[m\n' "${@}"
2019-12-31 08:17:31 -05:00
}
mariadb_root_reset(){
2020-07-25 20:05:55 -04:00
service mysql stop
2019-12-31 08:17:31 -05:00
mysqld_safe --skip-grant-tables >res 2>&1 &
sleep 5
rootpassword=$(/dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 32 | head -n 1)
2019-12-31 08:17:31 -05:00
Q1="UPDATE user SET plugin='';"
Q2="UPDATE user SET password=PASSWORD('$rootpassword') WHERE user='root';"
Q3="FLUSH PRIVILEGES;"
SQL="${Q1}${Q2}${Q3}"
mysql mysql -e "$SQL"
pkill mysqld
2020-07-25 20:05:55 -04:00
service mysql restart
2019-12-31 08:17:31 -05:00
output "Your MariaDB root password is $rootpassword"
}
mariadb_root_reset