zoukankan      html  css  js  c++  java
  • 关于centos7中使用rpm方式安装mysql5.7版本后无法使用root登录的问题

    最近在centos7中通过rpm方式安装了最新版本的mysql-server 5.7 (mysql57-community-release-el7-7.noarch.rpm) ,发现安装成功后无法使用root登录。百度google一番无果,最后在官方文档中找到了答案。现记录完整安装及问题解决过程,希望能帮助到其他朋友。
     
    OS版本:
    Linux version 3.10.0-327.el7.x86_64 (builder@kbuilder.dev.centos.org) (gcc version 4.8.3 20140911 (Red Hat 4.8.3-9) (GCC) ) #1 SMP Thu Nov 19 22:10:57 UTC 2015
     
    RPM方式安装mysql-server过程如下:
     
         $ su root
         $ sudo rpm -ivh mysql57-community-release-el7-7.noarch.rpm
         $ sudo yum install mysql-server   
     
    ##一路yes之后等待安装成功的提示
     
    到此为止,mysql57已经成功安装。现在使用root尝试登录到mysql,提示错误 ERROR 1045 (28000): Access denied for user 'root'@'localhost'
    发生这个问题的原因估计是rpm方式安装之后mysql使用了默认密码来初始化root用户。
     
    度娘谷歌之后得到的解决方案对5.7.x版本无效。 在官网上寻找到了一些思路 https://dev.mysql.com/doc/refman/5.7/en/server-management-using-systemd.html
    mysql5.7.x版本有一些新的变化,大致是 
    1. mysqld_safe已经被废弃,rpm安装包默认不会安装mysqld_safe
    2. user表中password列已经更改为authentication_string
     
    在经过多次试验之后终于解决了root登录问题。解决步骤如下
     
         $ sudo systemctl stop mysqld.service
         $ sudo systemctl set-environment MYSQLD_OPTS="--user=mysql --skip-grant-tables --skip-networking"
         $ sudo systemctl start mysqld.service    
         $ mysql -u root mysql
     
         mysql > UPDATE mysql.user SET authentication_string=PASSWORD("abcdef")  WHERE user='root' and host='localhost';
         mysql > flush privileges;
         mysql > quit
     
         $ sudo systemctl unset-environment MYSQLD_OPTS
         $ sudo systemctl restart mysqld.service
     
    OK,经过以上几个步骤操作之后,重新使用root登录成功。
  • 相关阅读:
    linux查看日志文件内容命令tail、cat、tac、head、echo
    改变自己的128种方法,教你变得更优秀!
    php 23种设计模式
    Swoole消息推送
    PHP 出现 502 解决方案
    【centos7】添加开机启动服务/脚本
    curl 参数配置详解
    i系列标准-互联网周刊
    MySQL 设计与开发规范2
    Cocos Creator webviw网页置顶增加返回键的方法
  • 原文地址:https://www.cnblogs.com/andrew-xie/p/5245625.html
Copyright © 2011-2022 走看看