虚拟机 | Ubuntu操作系统:su和sudo理解及如何处理忘记root密码

系列文章目录

虚拟机 | Ubuntu 安装流程以及界面太小问题解决
虚拟机 | Ubuntu图形化系统: open-vm-tools安装失败以及实现文件拖放


文章目录


前言

经过之前系列文章的学习,我们学会了Ubuntu操作系统的安装,使用open-vm-tools工具集简化宿主机与虚拟机之间的交互。

现在,我们要开始新的历程!

Linux是一个典型的多用户 操作系统,所以,接下来,让我们来探索一下多用户的功能实现,这能够帮助我们更好的使用Linux操作系统。

从用户的观点来看,操作系统是用户与计算机之间的接口


一、su和sudo是什么?

在Linux操作系统中,su和sudo是两个用于执行管理任务或以其他用户身份运行程序的命令。

它们都与系统的安全模型有关,特别是与用户权限提升相关。

1、su

  • su代表"switch user"或"substitute user"的缩写,其主要功能是允许用户切换到另一个用户账户下执行命令,默认情况下是切换到超级用户(root)。
  • 使用su时,系统会提示输入目标用户的密码,如果正确,则切换成功。
bash 复制代码
# 切换到root用户:
su - 或 su - root

# 切换到其他用户:
su - username

命令图示:



注意:

  • 使用su完全切换到了目标用户的环境下,这意味着所有环境变量都将被替换为目标用户的设置。

忘记root密码的解决方案

  • 一般的linux发行版在安装时,会让我们为 root 用户设置密码,并同时创建一个拥有 sudo 权限的普通用户账户。

情况一:

  • 忘记root密码,但是知道拥有sudo权限账户的密码。(简单仅需要终端操作即可)
bash 复制代码
# 设置root账户密码
sudo passwd root


情况二:

  • 忘记root密码,且不知道拥有sudo权限账户的密码。(GRUB)
无法进入GRUB引导页面

编辑GRUB配置文件:

bash 复制代码
sudo nano /etc/default/grub

修改以下内容(如果有):

bash 复制代码
GRUB_TIMEOUT_STYLE=menu
GRUB_TIMEOUT=10

注释以下内容后,按 ctrl+z 退出编辑:

bash 复制代码
GRUB_HIDDEN_TIMEOUT=0
GRUB_HIDDEN_TIMEOUT_QUIET=true

更新GRUB配置:

bash 复制代码
sudo update-grub

正常操作流程,如下:

1、重启,长按shift键进入Grub引导加载程序

  1. 在Ubuntu选项,按E键对其进行编辑
  • 找到 Linux行,在末尾添加如下内容:
bash 复制代码
rw init=/bin/bash
  1. 配置完成后按Ctrl+X键,可进入命令操作界面
  • 输入如下命令修改密码:
bash 复制代码
passwd

4、重启系统,正常登录。

2、sudo

  • sudo意为"superuser do",它允许授权用户以另一个用户(通常是root用户)的身份执行命令,而不需要知道那个用户的密码。

  • sudo通过配置文件:

    • /etc/sudoers,来指定哪些用户可以运行哪些命令。
    • 可以通过不同的参数进行细粒度控制。
  • 以root身份执行单个命令:sudo command

  • 执行多个命令或长时间的任务,使用以下命令来获得一个root shell:

    • sudo -s
    • sudo -i
    • sudo su + 当前账户密码

推荐使用sudo

  • sudo相对于su的一个关键优势在于
    • 它可以记录下谁执行了哪些命令,这有助于审计和追踪
  • sudo可以自定义配置 为仅允许特定命令以提升权限执行,
    • 减少误操作或恶意行为的风险。

总结

  • 虽然可以sudo su 命令 来获取root权限 ,但是 长期保持 root shell可能会增加误操作的风险。
    • 在完成管理任务之后,最好退出(使用:exit)root shell 返回普通用户权限。
  • 此外,频繁使用root账户也可能暴露系统于不必要的安全风险之下。
    • 因此,仅在必要时使用这些命令,并尽可能利用 sudo 来限制特权提升的范围和时间。

各位再见!这里是 鳄鱼杆 ,钓......鳄鱼的杆儿!

期待下次再会,愿每一次垂钓之旅都能满载而归。

相关推荐
春日见6 分钟前
控制算法:PP(纯跟踪)算法
linux·人工智能·驱动开发·算法·机器学习
老前端的功夫7 分钟前
TypeScript 类型魔术:模板字面量类型的深层解密与工程实践
前端·javascript·ubuntu·架构·typescript·前端框架
HABuo30 分钟前
【Linux进程(四)】进程切换&环境变量深入剖析
linux·运维·服务器·c语言·c++·ubuntu·centos
oMcLin44 分钟前
如何在 Rocky Linux 8.7 上通过 Prometheus 与 Grafana 结合,提升大规模容器环境的监控与性能分析?
linux·grafana·prometheus
橘颂TA1 小时前
【Linux】死锁四条件的底层逻辑:从锁冲突到 STL 组件的线程安全实践(Ⅵ)
linux·运维·服务器·c++·死锁
埃伊蟹黄面1 小时前
ELF深入解剖:从文件头到动态段,图解库的二进制构成
linux·c·
五仁火烧1 小时前
生产环境中配置了接口3000后,不能启动,改成8080后就可以
linux·网络·安全·vue
黄焖鸡能干四碗1 小时前
智能制造工业大数据应用及探索方案(PPT文件)
大数据·运维·人工智能·制造·需求分析
JiMoKuangXiangQu1 小时前
Linux build:头文件安装
linux·headers_install
橙露1 小时前
国产PLC与进口PLC全面对比分析:技术、市场与未来趋势
运维·网络