MySQL Access Denied (CentOS)

He aquí una idea para ti. Aunque no ha sido probado.

La idea es separar los archivos y directorios recién descomprimidos para cada archivo fuente único en su propia carpeta temporal. Esto se repite recursivamente, y cuando la recurrencia regresa desde las profundidades, los archivos y directorios se mueven a su destino adecuado y se elimina el directorio temporal.

function vacatetmp () {
    echo "Vacating TMP folder ${1}...."
    # You need a prefix for the new auxiliary temporary folders.
    prefix=SomeGoodPrefix
    for i in "$1"/*; do
        if [ -f "$i" ]; then
            # From your explanation:
            # "Look up the mime type of "$i" and unzip the files into "$1"."
            # Now, before you mix the new files and dirs with the old ones,
            # unzip them to a special new directory with the prefix and the file name
            # so that they're not mixed with the files and directories already present in "$1".
            mkdir "$1"/"${prefix}""$i" &&
            # How do you pass the target directory to "caseit"?
            # However you do, pass it the temporary folder.
            caseit "$i" "$1"/"${prefix}""$i" &&
            # Now the new unzipped files and folders are in "$1"/"${prefix}""$i", so
            # vacatetmp the auxiliary prefixed directory: 
            vacatetmp "$1"/"${prefix}""$i" &&
            # and after you've finished with vacatetmp-ing that directory,
            # move the contents of it to "$1".           
            mv "$1"/"${prefix}""$i"/* "$1" &&
            # And finally remove the prefixed directory.
            rmdir "$1"/"${prefix}""$1"
            # This file is done. Recursively.
        elif [ -d "$i" ]; then
            vacatetmp "$i"
        fi
    done
}

Avísame si me equivoqué en alguna parte. No ha sido probado, como he advertido antes.

1
06.02.2016, 02:44
2 ответа

Вероятно, там есть установка пароля root, обычно вы должны запустить mysql_secure_installation от имени root, который запросит у вас пароль mysql root и там просто нажмите enter.

В вашем случае похоже, что установлен пароль root, вы можете изменить его, используя

sudo mysqld_safe --user=mysql --pid-file=/var/run/mysql/mysqld.pid --socket=/var/run/mysql/mysql. sock --datadir=/var/lib/mysql --skip-grant-tables

Это позволит вам запустить mysql и вы сможете mysql -u root войти в mysql, после чего нужно будет обновить пароль root.

mysql> use mysql; 
mysql> update user set password=PASSWORD("yournewrootpasshere") where User='root';
mysql> flush privileges;
mysql> quit

--skip-grant-tables опция является ключевой, при использовании которой не будет запрашиваться пароль.

После этого, если вы перезапустите mysql, он нормально запустится, и вы даже сможете запустить mysql_secure_installation снова с новым паролем root, если захотите.

Поскольку это свежая установка, вы также можете удалить пакет mysql и установить его заново. Не забудьте также удалить базу данных.

0
29.04.2021, 00:18

отредактируйте /etc/my.cnf и добавьте:

skip-grant-tables

затем перезапустите службу MySQL и попробуйте войти

mysql

также вы можете проверить [официальное руководство]:

1
29.04.2021, 00:18

Теги

Похожие вопросы