Linux 命令完全手册,被逼无奈开始狂啃底层技术

像这样:

chown flavio test.txt

例如,假设有一个为 root 所拥有的文件,作为其他用户,你无法对它进行写入:

Screen-Shot-2020-09-03-at-18.40.49

你可以使用 chown 将文件所有权转移到你:

Screen-Shot-2020-09-03-at-18.40.58

一种需求十分常见:改变目录的所有权,同时遍历修改其中包含的文件、子目录以及子目录中的文件的所有权。

你可以使用 -R 参数来完成:

chown -R <所有者> <文件>

文件和目录不仅属于所有者,同时还属于用户组。使用以下命令,你可以在变更所有者的同时,更改其所属用户组:

chown <所有者>:<用户组> <文件>

举例:

chown flavio:users test.txt

你还可以使用 chgrp 命令,只更改文件的所属用户组:

chgrp <用户组> <文件名>

Linux 中的 chmod 命令


在 Linux 或 macOS 操作系统(或是任一 UNIX 系统)中,每个文件都有三种权限:读取、写入和执行。

进入一个文件夹,并运行 ls -al 命令。

Screen-Shot-2020-09-03-at-18.49.22

你在文件列表每一行见到的,像是 drwxr-xr-x 这样的奇怪字符串,定义了文件或文件夹的权限。

让我们来剖析一下。

第一个字母表示文件的类型:

  • - 表示这是一个常规的文件

  • d 表示这是一个目录

  • l 表示这是一个链接

之后你就有了三组值:

  • 第一组代表文件所有者拥有的权限

  • 第二组代表文件所关联的用户组成员拥有的权限

  • 第三组代表其他人拥有的权限

这些组由三个值组成。rwx 代表特定 角色 拥有读取、写入和执行访问权限。任何被移除的权限会被替换为 - ,因此你可以将不同的值,及其代表的相关权限进行组合:例如 rw-r--r-x 等等。

你可以使用 chmod 命令来改变一个文件的权限。

chmod 有两种用法。其一是使用符号参数,其二是使用数字参数。首先来试试更为直观的符号参数。

终端输入 chmod ,空格,之后加上一个字母:

  • a 表示 all,即全体

  • u 表示 user,即用户

  • g 表示 group,即用户组

  • o 表示 others,即其他人

然后输入 + 或 - 并加上一个或多个权限符号(rwx),来添加或删除任意权限。

键入以上所有命令和参数之后,都要加上文件或文件夹名称。

以下是一些例子:

chmod a+r filename #每个人都可以读取

chmod a+rw filename #每个人都可以读取和写入

chmod o-rwx filename #其他人(非文件所有者,也不在文件所属用户组中的用户)无法读取、写入或执行文件

只需要在 +/- 前添加多个字母,即可将相同的权限批量应用到不同的身份:

chmod og-r filename #其他人,和用户组无法读取文件。

如果你正在编辑一个文件夹,你可以使用 -r(递归)参数将权限应用到该文件夹中的每个文件。

使用数字参数速度更快,但我认为当你不是每天都使用的话,是很难记住它们的。数字在此代表任一角色的权限。这个数字值最大可以是7,它是这样计算的:

  • 拥有执行权限,记为 1

  • 拥有写入权限,记为 2

  • 拥有读取权限,记为 4

这又给我们带来四种组合:

  • 0 代表无权限

  • 1 代表可以执行

  • 2 代表可以写入

  • 3 代表可以写入和执行

  • 4 代表可以读取

  • 5 代表可以读取和执行

  • 6 代表可以读取和写入

  • 7 代表可以读取、执行和写入

我们使用三组数字,来同时设置所有 3 个用户身份的全部权限:

chmod 777 filename

chmod 755 filename

chmod 644 filename

Linux 中的 umask 命令


创建一个文件时,不需要事先决定权限。权限有默认值。

这些默认值可以使用 umask 命令来控制和修改。

不带参数输入 umask ,它会显示当前的 umask 值,本例中为 0022

Screen-Shot-2020-09-04-at-09.04.19

0022 是什么意思? 这是一个代表权限的八进制数值。

另一个常见的数值是 0002.

使用 umask -S 查看更具可读性的注释:

Screen-Shot-2020-09-04-at-09.08.18

在这里,用户(u),也就是文件的所有者,拥有对文件的读取、写入和执行的权限。

和所有者位于同一用户组的用户(g)拥有对文件的读取和执行权限,除此之外的其他用户(o)也一样。

在数字符号中,我们通常会改变最后3位数字。

以下列表给出了这些数字的含义:

  • 0 代表读取、写入与执行

  • 1 代表读取与写入

  • 2 代表读取与执行

  • 3 代表只读

  • 4 代表写入与执行

  • 5 代表仅写入

  • 6 代表仅执行

  • 7 代表没有权限

注意,这里的数字含义与前述 chmod 命令中用到的并不同。

可以用数值格式,为权限掩码设置一个新的值:

umask 002

也可以更改特定角色的权限:

umask g+r

Linux 中的 du 命令


du 命令会计算整个目录的大小:

du

Screen-Shot-2020-09-04-at-08.11.30

这里的 32 是一个单位为字节(Byte)的值。

运行 du * 会单独计算每个文件的大小:

Screen-Shot-2020-09-04-at-08.12.35

你也可以执行 du -m 或 du -g,以兆字节(MB)或千兆字节(GB)为单位显示文件大小。

使用 -h 选项,会显示更为可读的,适应大小的数值:

Screen-Shot-2020-09-04-at-08.14.40

添加 -a 选项同样会输出文件夹中每一个文件的大小:

Screen-Shot-2020-09-04-at-08.20.12

一个方便的做法是按大小对目录进行排序:

du -h | sort -nr

然后通过管道输出到 head ,从而仅获取前 10 个结果:

Screen-Shot-2020-09-04-at-08.22.25

Linux 中的 df 命令


df 命令用来获取磁盘的使用情况信息。

它的基础形式会输出当前挂载的磁盘卷信息:

Screen-Shot-2020-09-08-at-08.40.39

使用 -h 参数 (df -h)会将值以更为可读的方式显示:

Screen-Shot-2020-09-08-at-08.40.50

你也可以指定任一文件或目录名,以获取其所在的特定卷的信息:

Screen-Shot-2020-09-08-at-08.41.27

Linux 中的 basename 命令


假设有一个文件路径,比如 /Users/flavio/test.txt

执行

basename /Users/flavio/test.txt

会返回 text.txt 字符串:

Screen-Shot-2020-09-10-at-08.27.52

如果你在任一指向目录的路径字符串上执行 basename ,你会得到路径的最后一节。在以下例子中,/Users/flavio 是一个目录:

Screen-Shot-2020-09-10-at-08.28.11

Linux 中的 dirname 命令


假设有一个文件路径,比如 /Users/flavio/test.txt

执行

dirname /Users/flavio/test.txt

会返回 /Users/flavio 字符串:

Screen-Shot-2020-09-10-at-08.31.08-1

Linux 中的 ps 命令


电脑每时每刻都在运行大量不同的进程。

你可以用 ps 命令检查它们:

Screen-Shot-2020-09-02-at-12.25.08

这是当前会话中运行的,由用户发起的进程列表。

此处我打开了一些 fish Shell 实例,大多数是在 VS Code 编辑器内部启动的,还运行了一个 Hugo 实例,用来生成网站的开发预览。

这些只是分配给当前用户的命令。要列出所有进程,我们需要给 ps 传递一些参数。

我最常使用的命令是 ps ax

Screen-Shot-2020-09-02-at-12.26.00

a 参数用来同时列出其他用户的进程。x 显示那些未与终端相连的进程(不是由用户通过终端发起的)。

如你所见,较长的命令被截断了。使用 ps axww 继续在新的行上列出命令,而非截断。

Screen-Shot-2020-09-02-at-12.30.22

我们需要输入 w 两次来应用这个设置(这不是笔误)。

你可以配合使用 grep 和管道符来搜索特定的进程,比如像这样:

ps axww | grep “Visual Studio Code”

Screen-Shot-2020-09-02-at-12.33.45

ps 返回的列表达了一些重要信息。

第一个信息是 PID,也就是进程 ID。当你想在另一个命令中引用这个进程时,比如说要杀死它,这是关键的。

然后是 TT,它告诉我们进程所使用的终端 ID。

接下来 STAT 告诉我们进程的状态:

I 代表闲置的进程(睡眠时间超过约 20 秒)

R 代表可运行的进程

S 代表睡眠时间少于 20 秒的进程

T 代表已停止的进程

U 代表处于不间断等待中的进程

Z 代表已死亡的进程(zombie,即僵尸进程)

如果出现一个以上的字母,那么第二个字母代表进一步的、可能非常有技术性的信息。

常见的是 + ,它代表相应进程在终端中处于前台。而 s 代表相应进程是一个 会话领头进程(session leader).

TIME 则告诉我们进程已经运行了多长时间。

Linux 中的 top 命令


top 命令用来显示系统中正在运行的进程的动态实时信息。

如果要了解系统发生了什么,这条命令真的很方便。

它的用法很简单。你只需要输入 top ,终端会完全沉浸到新的视图中:

Screen-Shot-2020-09-03-at-11.39.53

这个进程是持续运行的。要退出,你可以输入字母 q 或按下 ctrl-C

它给出了很多信息:进程数量、有多少进程在运行或休眠、系统负载、CPU 使用率,还有更多信息。

在下方,占用 CPU 和内存资源最多的进程列表不断刷新。

默认情况下,进程按 CPU 使用率排列,正如你在高亮标记的 %CPU 列中看到的那样。

你可以添加一个参数,要求进程列表按内存利用率排列:

top -o mem

Linux 中的 kill 命令


Linux 进程可以接收信号并做出反应。

这是我们与运行中进程打交道的一种方式。

kill 程序可以向任一程序发送多种信号。

虽然这个命令的名字暗示了它的主要功能,但它不只是用来终止程序的。

它的用法是:

kill

默认情况下,它会向指定的进程 ID 发送 TERM 信号。

我们可以使用参数来发送其它信号,包括以下这些:

kill -HUP

kill -INT

kill -KILL

kill -TERM

kill -CONT

kill -STOP

HUP 代表 hang up(挂起)。 如果在终止进程之前,先关闭了启动它的终端窗口,这一信号将被自动发送。

INT 代表 interrupt(干扰),这个信号和在终端中按下 ctrl-C 组合键的作用一样,常常用来终结进程。

KILL 信号并不直接发送给进程,而是发送到操作系统内核,内核会让指定进程立刻停止并终结。

TERM 代表 terminate(终结)。这是本命令的默认信号,进程收到它会自主终结。

CONT 代表 continue(继续)。它可以用来恢复一个被停止的进程。

STOP 信号并不直接发送给进程,而是发送到操作系统内核,内核会让指定进程立刻停止(但不终结)。

有时你也会见到用数字表示状态的情况,例如 kill -1 <PID>。在这种情况下,

1 对应 HUP

2 对应 INT

9 对应 KILL

15 对应 TERM

18 对应 CONT

15 对应 STOP

Linux 中的 killall 命令


与 kill 命令类似, killall 也向进程发送状态信号,但区别是后者可以同时向多个进程发送信号,而非前者只能向单个进程 ID 发送信号。

这是它的命令语法:

killall

name 也就是进程的名字。例如,假设有多个 top 程序的实例在运行, killall top 命令将完全终结它们。

你可以指定某一个信号,就像使用 kill 命令那样(请向上翻阅 kill 命令的指南以了解更多具体可以发送的信号),例如:

killall -HUP top

Linux 中的 jobs 命令


当我们在 Linux / macOS 中运行命令时,我们可以在末尾加入 & 符号,使其在后台运行。

例如,让 top 命令在后台运行:

top &

这对于需要长时间运行的程序来说很方便。

要返回切入后台的程序,可以使用 fg 命令。如果后台只有一个作业进程,那么直接使用就好;否则要在后面加上作业进程的号码,如: fg 1fg 2 ,以此类推。

要获取作业进程号,我们可以使用 jobs 命令。

假设我们运行了 top &,之后再运行 top -o mem & ,因而我们有两个 top 实例在运行。此时 jobs 命令会这样告诉我们:

Screen-Shot-2020-09-03-at-11.49.42

现在我们可以利用 fg <作业号> 切回任意一个实例。要再次终止程序,可以按下 cmd-Z 。

运行 jobs -l 也会列出每一个作业的进程 ID。

Linux 中的 bg 命令


当命令执行时,你可以按下 ctrl-Z 暂停它。

按下后,命令会即刻停止,并将你带回到 Shell 终端。

你可以恢复命令在后台的执行,这样既可以使命令保持运行,同时又不会妨碍你在终端中做其他工作。

在这一例子中,有 2 个命令停止了:

Screen-Shot-2020-09-03-at-16.06.18

运行 bg 1 即可在后台恢复作业 #1 的执行。

我也可以不带任何参数执行 bg 命令,它会默认选取作业列表中的 #1 项。

Linux 中的 fg 命令


当命令在后台运行时,由于此前你已经在命令末尾加上了 & (例如 top & ,或是使用了 bg 命令将命令放到后台),此时你可以用 fg 命令将其切换回前台。

执行

fg

它将在前台恢复最后被暂停的作业。

你也可以加上作业号,即可指定任一你想在前台恢复的作业,作业号可以使用 jobs 命令获得。

Screen-Shot-2020-09-03-at-16.12.46

执行 fg 2 将恢复作业 #2:

Screen-Shot-2020-09-03-at-16.12.54

Linux 中的 type 命令


命令可分为以下四种类型:

  • 可执行程序

  • Shell 内置程序

  • Shell 功能

  • 命令别名

如果你很想知道或只是很好奇,type 命令可以帮你分清这些。它会告诉你某一命令如何被解析。

输出根据 Shell 的类型而有所不同,这是在 Bash 中的样子:

Screen-Shot-2020-09-03-at-16.32.50

这是在 Zsh 中的样子:

Screen-Shot-2020-09-03-at-16.32.57

这是在 Fish 中的样子:

Screen-Shot-2020-09-03-at-16.33.06

其中一个有趣的现象是:对于别名,它会告诉你某个别名将被解析到何处。例如,在 Bash 和 Zsh 中, ll 显示为一个别名,而在 Fish 中,由于 ll 是默认提供的,所以它会告诉你这是内置的 Shell 功能。

Linux 中的 which 命令


假定你有一个可直接执行的命令,因为它处在 Shell 路径中,但你想知道它的具体位置。

你可以用 which 来做这件事。这个命令会返回指定命令的路径。

Screen-Shot-2020-09-03-at-17.22.47

which 只对存储在磁盘上的可执行文件起作用,对别名或内置 Shell 功能无效。

Linux 中的 nohup 命令


有时你必须在远程机器上运行一个长时间活跃的进程,但之后你需要断开连接。

或者,你只是想防止当本地和服务器之间有任何网络问题时,命令被停止执行。

要让任一命令在登出或关闭服务器会话后继续运行,可以使用 nohup 命令。

执行 nohup <命令> 可以让某个进程在你登出后继续工作。

Linux 中的 xargs 命令


在 UNIX Shell 中,xargs 命令用来将标准输入的数据转换成命令的参数。

换句话说,使用 xargs ,可以将一条命令的输出,用作另一条命令的输入。

下面是你将会用到的语法:

command1 | xargs command2

我们使用管道符(|)将输出传递给 xargs。它将负责运行 command2 命令,使用 command1 的输出作为参数。

我们来做个简单的例子。假设你要删除某个目录下的一些特定文件。这些文件列在一个文本文件中。

我们有三个文件: file1、 file2、 file3

在 todelete.txt 中,我们有一份想要删除的文件列表,在这一例子中是 file1 和 file3

Screen-Shot-2020-09-08-at-07.45.28

我们将通过 xargs 把 cat todelete.txt 的输出引向 rm 命令。

就像这样:

cat todelete.txt | xargs rm

以下是执行结果,我们列出的文件现在已经被删除:

Screen-Shot-2020-09-08-at-07.46.39

它的工作方式是:xargs 会运行 rm 2次,为 cat 返回的每一行运行一次。

这是 xargs 最简单的用法。我们还可以使用以下的一些参数。

在我看来,其中最有用的是 -p(特别是刚开始学习 xargs 时)。使用这个选项将使 xargs 打印出一个确认提示,说明它要采取的行动:

Screen-Shot-2020-09-08-at-08.19.09

-n 选项令 xargs 每次执行若干个迭代,因此你可以用 -p 单独确认它们。这里我们用 -n1 告诉 xargs 一次执行一个迭代:

Screen-Shot-2020-09-08-at-08.32.58

另一个广泛应用的参数是 -I。它可以将输出内容放入占位符,之后你可以用来做各种事。

其中一件事是同时运行多个命令,例如:

command1 | xargs -I % /bin/bash -c ‘command2 %; command3 %’

Screen-Shot-2020-09-08-at-08.35.37

你可以将上方的 % 符号换成其他任何东西——它只是个变量。

Linux 中的 vim 编辑器命令


vim 是一个非常流行的文件编辑器,特别是在程序员中。 它被积极开发且经常更新,且有巨大的社区力量围绕着。甚至还有一个 Vim 会议!

在现代系统中,vi 只是 vim 的一个别名,意思是“改进的 vi”(即 “vi improved”)。

你可以在命令行运行 vi 启动它。

Screenshot-2019-02-10-at-11.44.36

调用时指定一个文件名,你就可以编辑对应的文件:

vi test.txt

Screenshot-2019-02-10-at-11.36.21

你需要了解的是,Vim 有两个主要的模式:

  • 命令(command) 模式,也称为 普通(normal) 模式

  • 插入(insert) 模式

当你启动编辑器时,默认处于命令模式。这时你无法像期望的那样,在基于图形界面的编辑器中输入文本。你需要进入插入模式

可以按下 i 键进入插入模式。当你这样做之后, 在编辑器下方会出现 -- 插入 -- (或 INSERT)字样:

Screenshot-2019-02-10-at-11.47.39

现在你可以开始输入了,用文件内容来填充终端屏幕:

Screenshot-2019-02-10-at-11.48.39

你可以用方向键在文件中移动光标,或者使用 h - j - k - l 四个键。 h-l 代表左和右,j-k 代表上和下。

当完成编辑时,按下 esc 键即可退出插入模式,回到命令模式

Screenshot-2019-02-10-at-11.48.44

此时你可以浏览文件,但无法向其添加内容(要注意按下了哪个键,某些键可能是编辑器的命令)。

现在你可能想知道如何保存文件。可以按下 : (冒号),然后输入 w,即 :w

保存并退出,可以按下 : 然后输入 w 和 q,即 :wq

退出但不保存文件,可以按下 : 然后输入 q 和 !,即 :q!

撤销某一个更改并再次编辑,可以在命令模式中按下 u。 如果要重做 (取消上次的撤销操作),可以按下 ctrl-r

以上是使用 Vim 工作的基本操作。接下来是一个无底洞,这篇简短的介绍是无法讲完的。

下面我只会提到那些能让你入门 Vim 编辑的命令:

  • 按下 x 键,删除当前光标高亮的字符

  • 按下 A 跳转到当前选择行的末尾

  • 按下 0 跳转到行的开头

  • 定位到任一单词的首字母,按下 d ,然后按 w 即可删除相应单词。如果输入 e 而非 w,后一个单词前的空白处将被保留

  • 在 d 和 w 之间加入一个数字,即可删除多个单词,例如使用 d3w 来向前删除 3 个单词

  • 按下 d 然后再按一次 d ,即可删除整行。按下 d 然后再按 $ ,即可删除以光标为开头,直至当前行末尾的整行内容。

如需了解更多 Vim 的内容,我推荐参阅 Vim 常见问题。你还可以运行 vimtutor 命令,它应该已经安装到系统中,可以对你开始探索 vim 有很大帮助。

Linux 中的 emacs 编辑器命令


emacs 是一个很棒的编辑器,它在历史上被认作是专为 UNIX 系统而生的。更著名的是:围绕 vi 与 emacs 之间的火热纷争与激烈论战曾给全世界的开发者带来许多无益的时光。

emacs 非常强大。一些人将其当作一种操作系统,全天候都在使用它 (https://news.ycombinator.com/item?id=19127258)。我们在此处只谈及一些基础的用法。

你可以调用 emacs 来开启新的 emacs 会话:

Screenshot-2019-02-10-at-12.14.18

macOS 用户们,现在请停一下。如果你当前在使用 Linux,那就没有什么问题,但 macOS 并未搭载使用 GPLv3 协议的应用程序,且每个内置的 UNIX 命令也没有更新到 GPLv3 版本。

虽然这对于我以上已经列出的命令来说,只是个小问题,但就本例而言,使用 2007 年的 emacs 版本与使用经过十余年改进和变化的版本,体验并不完全相同。

对于时常更新的 Vim 来说,这也不算什么。但想要解决 emacs 的问题,你需要运行 brew install emacs ,之后再运行 emacs,即可使用 Homebrew 提供的新版本(确保 Homebrew 已安装)。

与 Vim 类似,你也可以调用 emacs <文件名> 来编辑已有的文件:

Screenshot-2019-02-10-at-13.12.49

现在你可以开始编辑。当你完成编辑,先按下 ctrl-x,然后按下 ctrl-w。先确认文件夹:

Screenshot-2019-02-10-at-13.14.29

而 Emacs 会告诉你这个文件已存在,并询问是否要覆盖它:

Screenshot-2019-02-10-at-13.14.32

回答 y,你会得到一条操作成功的确认信息:

Screenshot-2019-02-10-at-13.14.35

要退出 Emacs ,可以按下 ctrl-x ,然后再按 ctrl-c

或者先按下 ctrl-x 之后再按 c (期间按住 ctrl 不放)。

Emacs 还有很多要了解的地方,限于篇幅,我在这篇简短教程中不便展开。我鼓励诸位按下 ctrl-h r 打开内置参考手册,或按下 ctrl-h t 打开官方教程以继续学习。

Linux 中的 nano 编辑器命令


nano 是一个对初学者友好的编辑器。

输入 nano <文件名> 即可运行。

你可以直接向文件中输入字符,而不必担心所在的模式。

想退出而不修改,你可以直接按下 ctrl-X。如果你已经编辑了文件缓冲区,编辑器会弹出确认提示,你可以选择保存或放弃更改。

底部的帮助栏为你显示了一部分用于处理文件的键盘命令:

Screenshot-2019-02-10-at-11.03.51

另一条命令 pico 与它大致相同,不过 nano 其实是 pico 的 GNU 版本,后者在一段历史时期内并未开源。 于是人们克隆出 nano 以满足 GNU 操作系统的许可要求。

Linux 中的 whoami 命令


键入 whoami 即可将当前登录终端会话的用户名打印出来:

Screen-Shot-2020-09-03-at-18.08.05

注意:这和可以输出更多信息的 who am i 命令并不一样。

Linux 中的 who 命令


who 命令显示当前已登录系统的用户。

除非你在使用多人访问的服务器,否则你可能是唯一的登录用户,并且登录了多次:

Screen-Shot-2020-09-03-at-18.03.05

为什么说是多次呢?因为每打开一次 Shell,都会被算作一次访问。

你可以在此看到使用的终端名,以及会话的起始时间/日期。

参数 -aH 将使 who 显示更多的信息,包括空载的时间与终端的进程 ID:

Screen-Shot-2020-09-03-at-18.05.29

特殊的 who am i 命令会列出当前终端会话的详情:

Screen-Shot-2020-09-03-at-18.06.35

Screen-Shot-2020-09-03-at-18.07.30

Linux 中的 su 命令


当你用一个用户登录到终端 Shell 时,可能需要切换到另一个用户。

例如,你以 root 身份登录,进行了维护工作,但之后你想切换到别的用户账户。

你可以用 su 命令来完成:

su <用户名>

例如: su flavio.

如果你以用户身份登录,且不带参数运行 su 命令,它会遵从默认行为——提示你输入 root 用户的密码。

Screen-Shot-2020-09-03-at-18.18.09

su 会以另一个用户的身份,开启新的 Shell。

当你完成操作,执行 exit即可关闭新开的 Shell,并回到当前用户的 Shell。

Linux 中的 sudo 命令


sudo 通常用来以 root 身份运行命令。

你必须先启用当前身份才能使用 sudo,启用之后,你可以直接输入你自己的登录密码( 而非 root 用户的密码)来以 root 身份运行命令。

这种权限是高度可配置的,在多用户的服务器环境中尤其有用。一些用户可以通过 sudo 被授予运行特定命令的权限。

例如,你可以用它编辑任一系统配置文件:

sudo nano /etc/hosts

这在普通模式下是无法实现的,因为你没有相应的权限。

你可以执行 sudo -i ,以 root 身份启动一个 Shell:

Screen-Shot-2020-09-03-at-18.25.50

还可以使用 sudo 以其他任何用户身份运行命令。 默认情况是 root , 但加上 -u 参数即可指定使用其他用户:

sudo -u flavio ls /Users/flavio

Linux 中的 passwd 命令


在 Linux 中,用户都有一个指定的密码。你可以使用 passwd 命令修改这个密码。

这里有两种情况。

第一种情况是:你想要修改自己的密码,此时你可以输入:

passwd

交互式提示会先询问你的旧密码,之后要求你输入新密码:

Screen-Shot-2020-09-04-at-07.32.05

当你处于 root 身份(或是其他具有超级用户权限的用户)时,你可以设置你想要更改密码的用户名:

passwd

此时你无需输入旧密码。

Linux 中的 ping 命令


ping 命令可以在本地网络或互联网上探测一个特定的网络主机。

它的语法是 ping <host>,其中 <host> 可以是域名或 IP 地址。

以下是探测 google.com 的例子:

Screen-Shot-2020-09-09-at-15.21.46

这个命令向服务器发送一个请求,服务器则返回其响应信息。

ping 在默认情况下,每秒持续发送请求,只有按下 ctrl-C 时才会停止。你可以用 -c 参数指定想要的尝试次数:ping -c 2 google.com

一旦 ping 结束运行,它将输出一些结果:例如数据包丢失的百分比,以及其他关于网络性能的统计数据。

你可以看到,屏幕上输出了主机的 IP 地址,以及得到响应所花的时间。

并不是所有的服务器都可以探测,此时会出现请求超时:

Screen-Shot-2020-09-09-at-15.21.27

有时这是为了“隐藏”服务器,或是减低服务器负载而故意设置的。为了探测所发送的数据包也可以被防火墙过滤。

ping 使用 ICMP 协议 (全称 Internet Control Message Protocol ,互联网控制报文协议)工作。ICMP 与 TCP 和 UDP 一样,是网络层协议。

探测请求向服务器发送一个含有 ECHO_REQUEST 信息的数据包,服务器则会返回 ECHO_REPLY 信息。此处我将不展开讲述,但这是最基本的概念。

用 Ping 探测,在测试主机是否可以访问时非常有用(此处假设主机支持探测),还可以从主机返回信息的时长,获知它的距离有多远。

通常,服务器在地理上离你越近,它向你返回信息的时间就越短。简单的物理规律则告诉我们:电缆越长,数据延迟越高。

Linux 中的 traceroute 命令


当你想要在互联网上到访某个主机时,数据首先会经过家庭路由器,然后到达你的运营商网络,再穿过上层的网络路由器,以此类推,直到最终连通主机。

你是否曾想过:数据包需要经过哪些步骤才能做到这一点?

traceroute 命令就是为此而生的。

你可以调用

traceroute

它将会(缓慢地)在数据包旅行时收集所有相关信息。

以下的例子中,我将尝试用 traceroute flaviocopes.com 到访我的博客:

Screen-Shot-2020-09-09-at-16.32.01

通常,我们可以看到主机名、IP 地址以及一些性能指标。但并不是所有经过的路由器都会向我们返回信息,此时,traceroute 会输出 * * *

每个路由器都可以看到 3 个样本,这意味着 traceroute 默认尝试了 3 次,让你很好地了解到达主机所需的时间。

这就是对服务器执行 traceroute 比简单地执行 ping 要花更多时间的原因。

你可以用 -q 参数自定义尝试的次数:

traceroute -q 1 flaviocopes.com

Screen-Shot-2020-09-09-at-16.36.07

Linux 中的 clear 命令


输入 clear 来清除当前终端之前执行的所有命令。

此时屏幕会被清理,你将只看到顶部的提示:

Screen-Shot-2020-09-03-at-18.10.32

提示:这个命令有个好用的快捷键: ctrl-L

不过,一旦使用了这个命令,你将不能用鼠标滚轮查看此前输入的命令。

因此你可能更想使用 clear -x,这个参数可以在清理屏幕的同时,保留之前的终端输入,向上滚动鼠标即可回溯查看。

Linux 中的 history 命令


每次运行命令,都会在历史中保存一条记录。

你可以输入下面的命令来查看所有历史记录:

history

这会显示带有序号的历史记录:

Screen-Shot-2020-09-04-at-08.03.10

你可以使用 !<命令序号> 重现已经储存在历史记录中的命令。以上的例子中,输入 !121 会重现 ls -al | wc -l 命令。

通常,历史记录会保留最后执行的 500 条命令。

你可以将这个命令与 grep 结合使用,以找到之前运行的命令:

history | grep docker

Screen-Shot-2020-09-04-at-08.04.50

如果要清除历史记录,运行 history -c 即可。

Linux 中的 export 命令


export 命令用来向子进程输出变量。

这是什么意思呢?

假设你像下面这样定义一个 TEST 变量:

TEST=“test”

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Linux运维工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Linux运维知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加VX:vip1024b (备注Linux运维获取)
img

为了做好运维面试路上的助攻手,特整理了上百道 【运维技术栈面试题集锦】 ,让你面试不慌心不跳,高薪offer怀里抱!

这次整理的面试题,小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。

本份面试集锦涵盖了

  • 174 道运维工程师面试题
  • 128道k8s面试题
  • 108道shell脚本面试题
  • 200道Linux面试题
  • 51道docker面试题
  • 35道Jenkis面试题
  • 78道MongoDB面试题
  • 17道ansible面试题
  • 60道dubbo面试题
  • 53道kafka面试
  • 18道mysql面试题
  • 40道nginx面试题
  • 77道redis面试题
  • 28道zookeeper

总计 1000+ 道面试题, 内容 又全含金量又高

  • 174道运维工程师面试题

1、什么是运维?

2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?

3、现在给你三百台服务器,你怎么对他们进行管理?

4、简述raid0 raid1raid5二种工作模式的工作原理及特点

5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?

6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?

7、Tomcat和Resin有什么区别,工作中你怎么选择?

8、什么是中间件?什么是jdk?

9、讲述一下Tomcat8005、8009、8080三个端口的含义?

10、什么叫CDN?

11、什么叫网站灰度发布?

12、简述DNS进行域名解析的过程?

13、RabbitMQ是什么东西?

14、讲一下Keepalived的工作原理?

15、讲述一下LVS三种模式的工作过程?

16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?

17、如何重置mysql root密码?

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img


export 命令用来向子进程输出变量。

这是什么意思呢?

假设你像下面这样定义一个 TEST 变量:

TEST=“test”

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Linux运维工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-yTPgkq63-1712508115261)]
[外链图片转存中…(img-iJeHXwPy-1712508115262)]
[外链图片转存中…(img-CdsAP7ED-1712508115262)]
[外链图片转存中…(img-p7b7m0NT-1712508115262)]
[外链图片转存中…(img-4H3LZ5QU-1712508115263)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Linux运维知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加VX:vip1024b (备注Linux运维获取)
[外链图片转存中…(img-uA3sKy2o-1712508115263)]

为了做好运维面试路上的助攻手,特整理了上百道 【运维技术栈面试题集锦】 ,让你面试不慌心不跳,高薪offer怀里抱!

这次整理的面试题,小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。

[外链图片转存中…(img-dnd66QUu-1712508115263)]

本份面试集锦涵盖了

  • 174 道运维工程师面试题
  • 128道k8s面试题
  • 108道shell脚本面试题
  • 200道Linux面试题
  • 51道docker面试题
  • 35道Jenkis面试题
  • 78道MongoDB面试题
  • 17道ansible面试题
  • 60道dubbo面试题
  • 53道kafka面试
  • 18道mysql面试题
  • 40道nginx面试题
  • 77道redis面试题
  • 28道zookeeper

总计 1000+ 道面试题, 内容 又全含金量又高

  • 174道运维工程师面试题

1、什么是运维?

2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?

3、现在给你三百台服务器,你怎么对他们进行管理?

4、简述raid0 raid1raid5二种工作模式的工作原理及特点

5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?

6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?

7、Tomcat和Resin有什么区别,工作中你怎么选择?

8、什么是中间件?什么是jdk?

9、讲述一下Tomcat8005、8009、8080三个端口的含义?

10、什么叫CDN?

11、什么叫网站灰度发布?

12、简述DNS进行域名解析的过程?

13、RabbitMQ是什么东西?

14、讲一下Keepalived的工作原理?

15、讲述一下LVS三种模式的工作过程?

16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?

17、如何重置mysql root密码?

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-NeRfzPuw-1712508115264)]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/599241.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最优算法100例之31-正则表达式匹配

专栏主页&#xff1a;计算机专业基础知识总结&#xff08;适用于期末复习考研刷题求职面试&#xff09;系列文章https://blog.csdn.net/seeker1994/category_12585732.html 题目描述 请实现一个函数用来匹配包括.和*的正则表达式。模式中的字符.表示任意一个字符&#xff0c;而…

线程安全性问题的原因

1.抢占式执行随机调度 这里的意思就是&#xff0c;当两个线程同时启动的时候&#xff0c;两个线程会同时进行&#xff0c;并且是抢占式执行的。 而且是随机调度资源的。 如代码&#xff1a; public class Deome4 {public static void main(String[] args) {Thread t1 new …

三防平板定制服务:亿道信息与个性化生产的紧密结合

在当今数字化时代&#xff0c;个性化定制已经成为了市场的一大趋势&#xff0c;而三防平板定制服务作为其中的一部分&#xff0c;展现了数字化技术与个性化需求之间的紧密结合。这种服务是通过亿道信息所提供的技术支持&#xff0c;为用户提供了满足特定需求的定制化三防平板&a…

云原生安全当前的挑战与解决办法

云原生安全作为一种新兴的安全理念&#xff0c;不仅解决云计算普及带来的安全问题&#xff0c;更强调以原生的思维构建云上安全建设、部署与应用&#xff0c;推动安全与云计算深度融合。所以现在云原生安全在云安全领域越来受到重视&#xff0c;云安全厂商在这块的投入也是越来…

算法设计与分析(实验6)---最短增益路径法求解最大流问题

一&#xff0e;实验目的 掌握最大流算法思想。学会用最大流算法求解应用问题。 二&#xff0e;实验步骤与结果 1.上述问题可按最大流问题求解&#xff1a; 假设有医生n个&#xff0c;现要安排元旦&#xff08;共D’天&#xff09;和五一&#xff08;共D’’天&#xff09;的…

ChatGPT基础(一) GPT的前世今生

文章目录 GPT模型简史GPT系列模型ChatGPT的应用 最近ChatGPT3.5可以免注册使用了&#xff0c;出来刨一波坟 说一说ChatGPT的来源和应用。 GPT模型简史 Generative pre-trained transformers(GPT)生成式预训练转换模型是大语言模型的一种(Large Language Model–>LLM)。它是…

如何在 Windows 上安装 Jupyter Notebook?

Jupyter Notebook 是一个开源 Web 应用程序&#xff0c;可用于创建和共享包含实时代码、公式、可视化效果和叙述文本的文档。用途包括数据清理和转换、数值模拟、统计建模、数据可视化、机器学习等 在本文中&#xff0c;我们将看到使用 pip 安装在Windows上安装 Jupyter Noteb…

Java8关于Function接口

Java学习-Function接口 1 函数式接口简介和学习地址2 两种常见的函数式接口2.1 Runnable&#xff1a;执行接口&#xff0c;不接收参数&#xff0c;也无返回结果。2.2 Consumer&#xff1a;作为消费接口&#xff0c;接收一个参数&#xff0c;无返回结果。 3 初识3.1 定义Functio…

系统架构评估_2.SAAM方法

SAAM&#xff08;Scenarios-based Architecture Analysis Method&#xff09;是卡耐基梅隆大学软件工程研究所&#xff08;SEI at CMU&#xff09;的Kazman等人于1983年提出的一种非功能质量属性的架构分析方法&#xff0c;是最早形成文档并得到广泛使用的软件架构分析方法。最…

MySQL基础练习题:创建数据库

这部分主要是为了帮助大家回忆回忆MySQL的基本语法&#xff0c;数据库来自于MySQL的官方简化版&#xff0c;题目也是网上非常流行的35题。这些基础习题基本可以涵盖面试中需要现场写SQL的问题。 创建数据库 在开始练习之前&#xff0c;我默认你的电脑上是没有本系列练习题需要…

物联网可视化平台

随着数字化转型的深入&#xff0c;物联网技术正在成为企业实现智能化、高效化运营的重要工具。物联网可视化平台&#xff0c;作为连接物理世界与数字世界的桥梁&#xff0c;为企业提供了直观、实时的数据展示和监控能力&#xff0c;从而在数字化转型中扮演着关键角色。 一、物…

内外网数据交换发展进程:安全与便捷并行

随着信息化的不断推进&#xff0c;医院、党政以及企业的内外网数据交换正成为日益关注的焦点。在保障数据安全的前提下&#xff0c;需要寻求一种既安全可靠又操作便捷的数据传输方式。本文将探讨内外网数据交换发展进程&#xff0c;分析各种传输方式的优缺点&#xff0c;以及它…