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 系统,无论是进行日常的文件操作、软件包管理,还是进行系统监控和脚本编程,都能做到游刃有余。同时,在进行涉及系统安全和重要数据的操作时,一定要谨慎小心,避免造成不必要的损失。
超级会员免费看

被折叠的 条评论
为什么被折叠?



