• linux中重置服务器的mysql用户密码


    最近使用阿里云服务器,由于安装lnmp安装包时疏忽,安装完后忘记了mysql的root用户密码。本来想重装服务器系统,但由于之前换系统和安装环境花费了不少时间,也觉得没必要出现什么问题都去重装系统。由于服务器安装的是Linux系统,于是只有用shell命令去修改了。

    在进行重置mysql用户密码时首先确认服务器出于安全的状态,也就是没有人能够任意地连接MySQL数据库。因为在重新设置MySQL的root密码的期间,MySQL数据库完全出于没有密码保护的状态下,其他的用户也可以任意地登录和修改MySQL的信息。可以采用将MySQL对外的端口封闭,并且停止Apache以及所有的用户进程的方法实现服务器的准安全状态。

    1>停止mysql.

     代码如下 复制代码

    # /etc/init.d/mysqld stop

    2>修改MySQL的登录设置

     代码如下 复制代码
    # vi /etc/my.cnf

    在[mysqld]的段中加上一句:skip-grant-tables

    例如:

     代码如下 复制代码

    [mysqld] 

    port = 3306 

    socket = /tmp/mysql.sock 

    skip-external-locking 

    skip-grant-tables

    保存并且退出vi。

    3>重新启动mysql

     代码如下 复制代码

    # /etc/init.d/mysqld restart

    4>登录并修改mysql的root密码

     代码如下 复制代码

    # /usr/bin/mysql 

    mysql> USE mysql ; 

    mysql> UPDATE user SET Password = password('newpassword') WHERE User = 'root' ; 

    mysql> flush privileges ; 

    mysql> quit ;//www.111cn.net

    5>将mysql的登录设置修改回来

     代码如下 复制代码

    # vi /etc/my.cnf

    将刚才在[mysqld]的段中加上的skip-grant-tables删除
    保存并且退出vi。

    6>重新启动mysql

     代码如下 复制代码

    # /etc/init.d/mysqld restart

    例子,一个万能的方法

    作为可选方式,在任何平台上,可使用mysql客户端设置新密码(但该方法不够安全):

    停止mysqld,并用“–skip-grant-tables –user=root”选项重启它(Windows用户可省略–user=root部分)。

    使用下述命令连接到mysqld服务器:www.111Cn.net

     代码如下 复制代码
    shell> mysql -u root

    在mysql客户端发出下述语句:

     代码如下 复制代码
    mysql> UPDATE mysql.user SET Password=PASSWORD(‘newpwd’)
        ->                   WHERE User=’root’;
    mysql> FLUSH PRIVILEGES;

    用打算使用的实际根用户密码替换“newpwd”。

    应能使用新密码进行连接。

     
  • 相关阅读:
    C语言拯救计划Day4-2之输出数组元素
    C语言拯救计划Day4-1之查找整数
    团队作业4——项目冲刺之日志集合贴
    团队作业6:复审与事后分析
    Alpha阶段项目复审
    事后诸葛亮分析
    团队作业5——测试与发布(Alpha版本)
    第7篇 Scrum 冲刺博客
    第6篇 Scrum 冲刺博客
    第5篇 Scrum 冲刺博客
  • 原文地址:https://www.cnblogs.com/alibai/p/3553648.html
Copyright © 2020-2023  润新知