Compare commits

...

2 Commits
main ... main

Author SHA1 Message Date
hmtsai
d59f25f9c0 添加进程的相关内容
Some checks failed
Build and Publish / Run (push) Failing after 6s
2025-01-15 00:20:22 +00:00
hmtsai
d03f30352e 修改部分文章的用词
Some checks failed
Build and Publish / Run (push) Failing after 35s
2025-01-14 22:42:27 +00:00
6 changed files with 46 additions and 10 deletions

View File

@ -4,6 +4,8 @@
备份是计算机使用中非常重要的操作。原则上来说,进行任何重大修改(比如更新系统、更新生产环境中的软件。)之前都需要备份。
这个章节主要是让你对备份这个概念有所了解,等到讲解服务器配置及使用的时候我们再仔细学习。
按照备份的范围来分,常用的备份方式有以下几种:
- 全量备份:指把硬盘等存储介质中的所有文件**一次性完整复制**到其他介质上。

View File

@ -2,7 +2,7 @@
## Linux 的文件结构
按照前文,我们所说的 C 盘就是 `/` 了。那么,我们的 D 盘和 E 盘等等呢?它们则被系统放到了别的地方,你甚至可以自定义这些地方(其实 Windows 也可以,不过放得很深),不过一般被放在了 `/mnt``/run/mount` 或者 `/media/你的用户名` 下。(根据发行版和桌面环境的不同有所区别。如果你是安装上文安装的,那么应该在 `/media/你的用户名` 里面)
按照前文,我们所说的 C 盘就是 `/` 了。那么,我们的 D 盘和 E 盘等等呢?它们则被系统放到了别的地方,你甚至可以自定义这些地方,不过一般被放在了 `/mnt``/run/mount` 或者 `/media/你的用户名` 下。(根据发行版和桌面环境的不同有所区别。如果你是安装上文安装的,那么应该在 `/media/你的用户名` 里面)
我们可以使用自带的文件管理器管理文件,就像 Windows 一样。
@ -36,11 +36,9 @@
- `/var/mail` (本地邮件信箱)
- `/var/spool/news` (新闻组)
- `/var/run` (程序相关文件)
- `/var/lock` (程序锁相)
- `/var/lock` (程序锁相)
- `/sys` 也是一个重要的设备目录
- `/home` 用户目录,相当于 `C:\Users`MacOS`/Users`
到这里,相信你已经掌握了 Linux 文件系统的简单结构。
- `/home` 用户目录,相当于 `C:\Users`
---

View File

@ -4,7 +4,7 @@
### 多用户操作系统的概念
不同于Windows这种基本上是单用户的操作系统Linux这种Unix-like系统因为是集成了Unix概念的原因,所以是实打实的多用户多任务分时操作系统。
不同于Windows这种基本上是单用户的操作系统 Linux 这种 Unix-like 操作系统系统由于直接或间接继承了Unix的原因,所以是实打实的多用户多任务分时操作系统。
Unix刚发明的时候电脑十分笨重且昂贵一台电脑不可能让一个用户独占必须同时分给多个用户使用。即便是最基本的电脑也能分出32个终端同时使用。这时候完善的用户与权限的管理就是十分必要的了。
@ -26,7 +26,12 @@ All Users
Unix-like使用UID而不是用户名区分用户如果你试着把两个账户的UID互相调换你会神奇的发现这两个用户的权限和所拥有的文件也被互换了。
UID的各个号段都已经被预先分配好了分配如下- 0 root权限最高的用户 - 1-999 系统服务保留UID下分两种 - 1-200 发行版自带软件所需帐号的UID - 201-999 用户自行创建的或用户所安装软件创建的账户的UID - 1000-60000 普通账户
UID的各个号段都已经被预先分配好了分配如下
- 0 root权限最高的用户
- 1-999 系统服务保留UID下分两种
- 1-200 发行版自带软件所需帐号的UID
- 201-999 用户自行创建的或用户所安装软件创建的账户的UID
- 1000-60000 普通账户
除了root意外其他账户的权限基本没有区别。
@ -54,7 +59,10 @@ vboxadd:x:979:1::/var/run/vboxadd:/bin/false
用户名:密码:UID:GID:其他信息:家目录位置:登录Shell
```
密码字段现在有三种可能性:- `x`表示密码在`/etc/shadow`中 - 留空表示密码为空,无需密码即可登录 - `!`表示该账户已经被禁用,无法登录
密码字段有三种可能性:
- `x`表示密码在`/etc/shadow`中
- 留空表示密码为空,无需密码即可登录
- `!`表示该账户已经被禁用,无法登录
其他信息默认存储用户名,这个也可以存储其他信息,但是现在很少用到。

View File

@ -4,7 +4,7 @@
> 在linux上也有些常见的图形化压缩包管理器比如 `Ark`,但是它们远不及命令行工具的快速和稳定性。
tar压缩包都有一个显著的特征文件名中都带有一个 `.tar`tgz 等部分格式除外),但是后面的 `.gz` 等等又是什么呢其实tar 本身并不是一个压缩格式,它只是简单的把所有文件和文件夹打包到一起,而后面的 `.gz`、`.bz2`、`.xz` 等等才是压缩的格式。
tar压缩包都有一个显著的特征大多数该类型文件的文件名中都带有一个 `.tar`,但是后面的 `.gz` 等等又是什么呢其实tar 本身并不是一个压缩格式,它只是简单的把所有文件和文件夹打包到一起,而后面的 `.gz`、`.bz2`、`.xz` 等等才是压缩的格式。
> 关于其它格式的压缩包,比如`zip`、`rar`等,可以使用其它命令,比如`unzip`、`unrar`等。

View File

@ -156,6 +156,33 @@ Shell 中有一些系统变量,它们在 Shell 启动时自动设置,例如
- `$0`:启动当前终端程序或者 ShellScript 的命令,如 `/bin/bash`
- `$#`:启动当前终端程序或者 ShellScript 的参数个数。
## 进程
在学习上一章节的时候,你是否会疑惑:为什么执行一个新的 Shell 就可以在一个不影响原本 Shell 的环境中工作呢?
实际上我们在执行一个命令的时候Shell 会为这个程序开启一个新进程。那什么叫做进程呢?你可以把它理解为你给计算机派发的一个任务。你只需要派发任务就好了,而计算机要考虑的事情就多了。(划掉)计算机负责执行这个进程,操作系统给它分配系统资源。
我们每个人都有自己的父母,进程也是一样。例如,进程 A 启动了进程 B那么进程 A 就是进程 B 的父进程(也可以称之为母进程)。
一般情况下,进程的环境变量只能向下传递。也就是当父进程启动了一个子进程的时候,子进程会继承父进程的环境变量。但是这时集成的只是父进程在创建子进程时环境变量的一个快照,以后父进程中环境变量更新的时候不会影响子进程。
我们可以通过实例来了解一下这个问题。
```sh
$ export TEST=114514
$ echo $TEST
114514
$ bash # 启动一个新的 Shell 进程
$ echo $TEST
114514 # 从父进程那里继承了环境变量
$ export TEST=1919810 # 尝试修改变量
$ echo $TEST
1919810
$ exit # 回到父进程
$ echo $TEST
114514 # 父进程的环境变量没有被改变
```
## 管道
Shell 中的管道是链接两个命令的方式,管道遵守下面的格式。

View File

@ -10,7 +10,8 @@
>
> Shell 也指代一种命令语言,由这种语言编写的脚本称为 Shell Script。
上面的内容有些难懂,你不妨可以理解为 Shell 就是用户的命令与 Kernel 之间的“桥梁”。
如果你听不太懂的话,你可以简单的把 Shell 理解为内核的秘书。秘书主要干什么?就是帮助老板安排会议、与他人沟通的嘛。
## Shell 有哪些