32、Linux 常见操作与命令解析

Linux 常见操作与命令解析

1. 基础概念与命令

1.1 链接类型

  • 符号链接(Symbolic links) :符号链接通过在符号链接文件中存储被链接文件的名称来工作。Linux 读取这个文件名并透明地替换为被链接的文件。此过程在单个文件系统和跨文件系统中都能正常工作。
  • 硬链接(Hard links) :硬链接通过提供多个指向单个文件的目录条目来工作,但这种创建链接的方法在底层文件系统之间不起作用。

1.2 系统安全与操作

  • 普通用户操作 :Linux 的安全特性可防止普通用户在操作时造成意外损坏。
  • root 用户操作 :当获取 root 权限进行系统维护时,需要格外小心,因为 root 用户可能对系统造成更大的损害。

1.3 文件时间戳与删除

  • touch 命令 :用于更新文件的时间戳,目录也可视为文件进行操作。
  • 文件删除 :使用 rm -R junk rm -r junk rm --recursive junk 可递归删除目录及其内容。

1.4 文本查看工具

工具 功能
less 类似于 more,可逐页显示文本文件,还能向后翻页、搜索内容等
grep 用于在文件中搜索指定字符串
cat 可连接多个文件或显示单个文件内容,但功能不如 more 强大
man 显示 Linux 手册页,默认使用 less 查看

1.5 文档类型

文档类型 特点
man 页 用于快速获取命令、配置文件等信息
HOWTOs 作为软件包或广泛主题的介绍

1.6 命令搜索与使用

  • whatis 命令 :搜索包含 man 页名称部分的数据库,返回包含指定关键字的命令名称。
  • man 搜索顺序 :若要覆盖 man 的搜索顺序,可在 man 和要搜索的命令名、文件名等之间指定所需的手册部分。
  • info 页面 :虽使用超链接连接相关文档,但与网页使用不同的格式和协议,且存储在本地硬盘,无需网络访问。

2. 软件包管理与系统日志

2.1 软件包管理工具

工具 适用系统 功能
apt - get Debian 及其派生系统 网络启用工具,可解决依赖关系并检索所需软件包
yum Red Hat 及其派生系统 类似 apt - get 的软件包管理工具
zypper SUSE 系统 用于软件包管理
rpm RPM 系统 非网络启用的软件包管理程序

2.2 系统启动与进程

  • init 进程 :Linux 通常将 init 作为第一个进程启动。
  • top 命令 :按 CPU 使用情况对进程列表进行排序,列表顶部的项当前消耗最多的 CPU 时间,也可通过多种方式更改排序顺序。

2.3 系统日志

  • 日志文件位置 :Linux 中日志文件的标准存储位置是 /var/log
  • 内核环缓冲区 dmesg 命令显示的内核环缓冲区内容会随计算机运行而变化,启动后和运行数周后的内容可能不同。

2.4 正则表达式与文件操作

  • grep 命令 :用于在文件中查找匹配文本并打印这些行,可接受正则表达式。例如,可使用方括号指定要查找的不同字符。
  • 重定向操作符
    • >> :将标准输出追加到文件。
    • | :管道字符,将一个程序的标准输出连接到另一个程序的标准输入。
    • 2> :重定向标准错误,会覆盖目标文件。
    • &> :重定向标准输出和标准错误,会覆盖目标文件。
    • > :重定向标准输出,会覆盖目标文件。

2.5 归档文件操作

  • tar 命令 :使用 --list (t) 命令读取归档文件并显示其内容, --verbose (v) 选项可创建详细的文件列表, --file (f) 指定文件名。例如, tar --list --verbose --file data79.tar 可查看 data79.tar 归档文件的详细内容。

2.6 文本编辑工具

  • nano 编辑器 :适用于 ASCII 或 Unicode 格式的文本文件,对于 LibreOffice 等使用二进制格式的文档无法正确解析。
  • Vi 编辑器 :在命令模式下, dd 用于删除行,前面加上数字可删除指定数量的行。

2.7 脚本编程基础

  • 脚本执行权限 :脚本通常至少有一个可执行位被设置,但在某些情况下也可在无此特性时运行。
  • 脚本参数传递 $0 变量保存脚本的名称,要访问传递给脚本的第一个参数,需使用 $1 变量。
  • 条件表达式 :用于返回 true 或 false 响应,使脚本能够执行一组指令或另一组指令,或终止或继续循环。

2.8 用户与组管理

2.8.1 用户账户
  • UID 0 :保留给系统管理员账户(root)。
  • 用户账户与系统账户 :系统账户的 UID 值通常在 0 到 499 或 999 之间,用户账户的 UID 值通常从 500 或 1000 开始。
2.8.2 用户信息文件
  • /etc/passwd 文件 :包含用户名、加密密码(或 x 表示使用影子密码)、UID 号、默认 GID 号、用户全名、主目录路径和默认文本模式 shell 路径。
2.8.3 用户操作命令
  • sudo 命令 :用于以 root 身份执行单个命令,例如 sudo command
  • userdel 命令 :用于删除用户账户,使用 -r 选项可同时删除用户的主目录和邮件假脱机文件。
  • groupadd 命令 :用于创建新组。
2.8.4 密码管理
  • 好的密码特征 :应包含大小写字母、数字和符号的组合,长度较长且不包含明显的单词。
  • 密码更改命令 :通常使用 passwd 命令在命令行更改密码。
graph LR
    A[开始] --> B{选择操作}
    B -->|查看文件| C(使用 less 或 cat 命令)
    B -->|搜索文件| D(使用 grep 或 find 命令)
    B -->|软件包管理| E(使用 apt - get 或 yum 等工具)
    B -->|用户管理| F(使用 userdel 或 groupadd 等命令)
    C --> G[结束]
    D --> G
    E --> G
    F --> G

3. 深入脚本编程与用户管理细节

3.1 脚本编程进阶

3.1.1 循环结构
  • for 循环 :可用于执行固定次数的循环。例如,以下脚本可循环打印 1 到 5 的数字:
#!/bin/bash
for i in {1..5}
do
    echo $i
done
  • while 和 until 循环 while 循环会一直执行,直到测试条件不再满足; until 循环则相反,会一直执行,直到测试条件满足。以下是一个 while 循环的示例,用于计算 1 到 5 的和:
#!/bin/bash
sum=0
i=1
while [ $i -le 5 ]
do
    sum=$((sum + i))
    i=$((i + 1))
done
echo $sum
3.1.2 条件判断与分支
  • case 语句 :用于根据不同的条件执行不同的代码块。例如,根据用户输入的数字输出对应的星期几:
#!/bin/bash
read -p "请输入 1 到 7 的数字: " num
case $num in
    1)
        echo "星期一"
        ;;
    2)
        echo "星期二"
        ;;
    3)
        echo "星期三"
        ;;
    4)
        echo "星期四"
        ;;
    5)
        echo "星期五"
        ;;
    6)
        echo "星期六"
        ;;
    7)
        echo "星期日"
        ;;
    *)
        echo "输入无效"
        ;;
esac

3.2 用户与组管理深入

3.2.1 用户账户删除细节

当使用 userdel -r 命令删除用户账户时,虽然会删除用户的主目录和邮件假脱机文件,但对于用户存储在其他非标准位置的文件,需要使用 find 命令进行定位。例如,要查找用户 nemo 在整个系统中所有的文件,可以使用以下命令:

find / -user nemo

若要删除这些文件,可以将查找结果通过管道传递给 rm 命令,但要格外小心,避免误删重要文件:

find / -user nemo -print0 | xargs -0 rm -rf
3.2.2 组管理操作
  • 添加用户到组 :使用 usermod 命令可将用户添加到指定组。例如,将用户 john 添加到 developers 组:
usermod -aG developers john

其中, -a 选项表示追加, -G 选项指定要添加的组。
- 更改用户默认组 :同样使用 usermod 命令,例如将用户 john 的默认组更改为 designers

usermod -g designers john

3.3 系统监控与日志分析

3.3.1 进程监控
  • top 命令高级用法 :除了按 CPU 使用情况排序外,还可以按内存使用情况排序。在 top 命令运行时,按下 M 键即可按内存使用情况对进程列表进行排序。
  • 查看当前登录用户 :使用 w 命令可以查看当前登录的用户信息,包括用户名、登录时间、使用的终端、空闲时间等。
3.3.2 日志分析
  • syslog 服务 syslog 是 Linux 中用于系统日志记录的服务,许多系统和应用程序的日志都会通过 syslog 进行记录。可以通过编辑 /etc/syslog.conf /etc/rsyslog.conf 文件来配置日志的存储位置和记录规则。
  • 日志文件查看与分析 :使用 grep 等命令可以从日志文件中筛选出有用的信息。例如,要查看 /var/log/messages 文件中包含 error 关键字的行,可以使用以下命令:
grep "error" /var/log/messages

4. 总结与操作流程梳理

4.1 常见操作总结

操作类型 相关命令
文件操作 touch rm grep cat less
软件包管理 apt - get yum zypper rpm
用户与组管理 userdel groupadd usermod passwd
脚本编程 for while until case if - then - else
系统监控与日志分析 top w dmesg grep

4.2 操作流程示例

4.2.1 安装软件包流程
graph LR
    A[开始] --> B{选择系统类型}
    B -->|Debian 及其派生系统| C(使用 apt - get 安装)
    B -->|Red Hat 及其派生系统| D(使用 yum 安装)
    B -->|SUSE 系统| E(使用 zypper 安装)
    C --> F[结束]
    D --> F
    E --> F
4.2.2 删除用户账户流程
graph LR
    A[开始] --> B(使用 userdel -r 命令删除账户和主目录)
    B --> C(使用 find 命令查找其他位置的用户文件)
    C --> D{是否删除其他文件}
    D -->|是| E(使用 xargs 和 rm 命令删除文件)
    D -->|否| F[结束]
    E --> F

通过对这些 Linux 操作和命令的深入了解,我们可以更加高效地管理和使用 Linux 系统,无论是进行日常的文件操作、软件包管理,还是进行系统监控和脚本编程,都能做到游刃有余。同时,在进行涉及系统安全和重要数据的操作时,一定要谨慎小心,避免造成不必要的损失。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值