Linux普通用户设置root用户密码——sudo命令报错解决方法

本文介绍了在Linux系统中为普通用户添加sudo权限的步骤,包括使用命令`chmod`修改`/etc/sudoers`文件权限,使用`vi`编辑器添加用户到sudoers文件,以及如何安全地撤销文件写权限。此外,还详细说明了如何通过`passwd`命令更改root用户的密码。遵循这些步骤,用户可以确保系统安全并有效管理权限。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、使用命令sudo passwd root

二、只要输入当前用户密码即可,注意有的用户会报错

 xxx is not in the sudoers file.  This incident will be reported.
You have mail in /var/spool/mail/root

解决方法:

先切换到root用户里面去,添加sudoers文件的写权限,命令是:chmod u+w ../etc/sudoers,然后编辑sudoers文件,命令是:vi ../etc/sudoers,键入i,使其处于编辑阶段,找到root ALL=(ALL) ALL,在他下面添加xxx ALL=(ALL) ALL (这里的xxx是你的用户名),添加后如下图,按esc键后再键入:wq退出并保存即可

撤销sudoers文件写权限,命令:chmod u-w ../etc/sudoers,在终端完整输入的命令,这样普通用户就可以使用sudo命令了。

三、输入新的root用户密码,再确定一下即可

四、root用户密码更改成功!

### 解决 MySQL 修改密码报错 1045 Access Denied 当遇到 `ERROR 1045 (28000): Access denied for user 'root'@'localhost'` 错误时,通常是因为认证失败或者权限配置不正确。以下是几种可能的原因及解决方案: #### 可能原因一:多版本 MySQL 冲突 如果计算机上安装了多个不同版本的 MySQL 实例,则可能导致端口和服务冲突,进而引发访问拒绝错误[^3]。 #### 方案实施: - 检查并停止其他正在运行的 MySQL 版本的服务。 - 使用特定版本的启动工具来管理所需使用的 MySQL 服务实例。 #### 可能原因二:身份验证插件变更 自 MySQL 8.0 开始,默认的身份验证方式变更为 `caching_sha2_password`,这可能会导致某些客户端无法正常登录[^2]。 #### 方案实施: 对于这种情况,可以考虑切换回更兼容的身份验证方法——即 `mysql_native_password` 插件。具体操作如下所示: ```sql ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码'; FLUSH PRIVILEGES; ``` #### 可能原因三:忘记或丢失管理员账户凭证 有时会因为遗忘之前的设置而造成无法成功登陆数据库的情况发生。 #### 方案实施: 可以通过跳过权限表的方式重置 root 用户密码。步骤如下: 1. 关闭当前正在运行中的 mysqld 进程; 2. 启动带有 `--skip-grant-tables` 参数的临时服务器实例; 3. 执行 SQL 更新命令更改 root密码; 4. 正常重启 MySQL 服务加载新的凭据信息。 ```bash # Linux环境下执行以下指令 sudo systemctl stop mariadb.service # 或者mysqld.service取决于系统环境变量定义 sudo mysqld_safe --skip-grant-tables & mysql -u root # 不需要提供任何密码即可进入控制台 USE mysql; UPDATE user SET authentication_string=PASSWORD('新密码') WHERE User='root'; # 对于MySQL 5.7及以上版本应采用 ALTER USER 方法替代此行代码 FLUSH PRIVILEGES; exit # 退出SQL交互界面 sudo systemctl start mariadb.service # 重新开启常规模式下的MariaDB/MySQL守护进程 ``` 以上措施能够有效处理大多数情况下由于密码问题所引起的 `Access denied` 报错现象。值得注意的是,在实际应用过程中应当谨慎对待生产环境中敏感数据的安全防护工作,确保采取适当的方法保护好账号信息安全。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xiaochuhe--kaishui

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值