像这样:
chown flavio test.txt
例如,假设有一个为 root
所拥有的文件,作为其他用户,你无法对它进行写入:
你可以使用 chown
将文件所有权转移到你:
一种需求十分常见:改变目录的所有权,同时遍历修改其中包含的文件、子目录以及子目录中的文件的所有权。
你可以使用 -R
参数来完成:
chown -R <所有者> <文件>
文件和目录不仅属于所有者,同时还属于用户组。使用以下命令,你可以在变更所有者的同时,更改其所属用户组:
chown <所有者>:<用户组> <文件>
举例:
chown flavio:users test.txt
你还可以使用 chgrp
命令,只更改文件的所属用户组:
chgrp <用户组> <文件名>
Linux 中的 chmod
命令
在 Linux 或 macOS 操作系统(或是任一 UNIX 系统)中,每个文件都有三种权限:读取、写入和执行。
进入一个文件夹,并运行 ls -al
命令。
你在文件列表每一行见到的,像是 drwxr-xr-x
这样的奇怪字符串,定义了文件或文件夹的权限。
让我们来剖析一下。
第一个字母表示文件的类型:
-
-
表示这是一个常规的文件 -
d
表示这是一个目录 -
l
表示这是一个链接
之后你就有了三组值:
-
第一组代表文件所有者拥有的权限
-
第二组代表文件所关联的用户组成员拥有的权限
-
第三组代表其他人拥有的权限
这些组由三个值组成。rwx
代表特定 角色 拥有读取、写入和执行访问权限。任何被移除的权限会被替换为 -
,因此你可以将不同的值,及其代表的相关权限进行组合:例如 rw-
、r--
、r-x
等等。
你可以使用 chmod
命令来改变一个文件的权限。
chmod
有两种用法。其一是使用符号参数,其二是使用数字参数。首先来试试更为直观的符号参数。
终端输入 chmod
,空格,之后加上一个字母:
-
a
表示 all,即全体 -
u
表示 user,即用户 -
g
表示 group,即用户组 -
o
表示 others,即其他人
然后输入 +
或 -
并加上一个或多个权限符号(r
、w
、x
),来添加或删除任意权限。
键入以上所有命令和参数之后,都要加上文件或文件夹名称。
以下是一些例子:
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
:
0022
是什么意思? 这是一个代表权限的八进制数值。
另一个常见的数值是 0002
.
使用 umask -S
查看更具可读性的注释:
在这里,用户(u
),也就是文件的所有者,拥有对文件的读取、写入和执行的权限。
和所有者位于同一用户组的用户(g
)拥有对文件的读取和执行权限,除此之外的其他用户(o
)也一样。
在数字符号中,我们通常会改变最后3位数字。
以下列表给出了这些数字的含义:
-
0
代表读取、写入与执行 -
1
代表读取与写入 -
2
代表读取与执行 -
3
代表只读 -
4
代表写入与执行 -
5
代表仅写入 -
6
代表仅执行 -
7
代表没有权限
注意,这里的数字含义与前述 chmod
命令中用到的并不同。
可以用数值格式,为权限掩码设置一个新的值:
umask 002
也可以更改特定角色的权限:
umask g+r
Linux 中的 du
命令
du
命令会计算整个目录的大小:
du
这里的 32
是一个单位为字节(Byte)的值。
运行 du *
会单独计算每个文件的大小:
你也可以执行 du -m
或 du -g
,以兆字节(MB)或千兆字节(GB)为单位显示文件大小。
使用 -h
选项,会显示更为可读的,适应大小的数值:
添加 -a
选项同样会输出文件夹中每一个文件的大小:
一个方便的做法是按大小对目录进行排序:
du -h | sort -nr
然后通过管道输出到 head
,从而仅获取前 10 个结果:
Linux 中的 df
命令
df
命令用来获取磁盘的使用情况信息。
它的基础形式会输出当前挂载的磁盘卷信息:
使用 -h
参数 (df -h
)会将值以更为可读的方式显示:
你也可以指定任一文件或目录名,以获取其所在的特定卷的信息:
Linux 中的 basename
命令
假设有一个文件路径,比如 /Users/flavio/test.txt
。
执行
basename /Users/flavio/test.txt
会返回 text.txt
字符串:
如果你在任一指向目录的路径字符串上执行 basename
,你会得到路径的最后一节。在以下例子中,/Users/flavio
是一个目录:
Linux 中的 dirname
命令
假设有一个文件路径,比如 /Users/flavio/test.txt
。
执行
dirname /Users/flavio/test.txt
会返回 /Users/flavio
字符串:
Linux 中的 ps
命令
电脑每时每刻都在运行大量不同的进程。
你可以用 ps
命令检查它们:
这是当前会话中运行的,由用户发起的进程列表。
此处我打开了一些 fish
Shell 实例,大多数是在 VS Code 编辑器内部启动的,还运行了一个 Hugo 实例,用来生成网站的开发预览。
这些只是分配给当前用户的命令。要列出所有进程,我们需要给 ps
传递一些参数。
我最常使用的命令是 ps ax
:
a
参数用来同时列出其他用户的进程。x
显示那些未与终端相连的进程(不是由用户通过终端发起的)。
如你所见,较长的命令被截断了。使用 ps axww
继续在新的行上列出命令,而非截断。
我们需要输入
w
两次来应用这个设置(这不是笔误)。
你可以配合使用 grep
和管道符来搜索特定的进程,比如像这样:
ps axww | grep “Visual Studio Code”
ps
返回的列表达了一些重要信息。
第一个信息是 PID
,也就是进程 ID。当你想在另一个命令中引用这个进程时,比如说要杀死它,这是关键的。
然后是 TT
,它告诉我们进程所使用的终端 ID。
接下来 STAT
告诉我们进程的状态:
I
代表闲置的进程(睡眠时间超过约 20 秒)
R
代表可运行的进程
S
代表睡眠时间少于 20 秒的进程
T
代表已停止的进程
U
代表处于不间断等待中的进程
Z
代表已死亡的进程(zombie,即僵尸进程)
如果出现一个以上的字母,那么第二个字母代表进一步的、可能非常有技术性的信息。
常见的是 +
,它代表相应进程在终端中处于前台。而 s
代表相应进程是一个 会话领头进程(session leader).
TIME
则告诉我们进程已经运行了多长时间。
Linux 中的 top
命令
top
命令用来显示系统中正在运行的进程的动态实时信息。
如果要了解系统发生了什么,这条命令真的很方便。
它的用法很简单。你只需要输入 top
,终端会完全沉浸到新的视图中:
这个进程是持续运行的。要退出,你可以输入字母 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 1
、fg 2
,以此类推。
要获取作业进程号,我们可以使用 jobs
命令。
假设我们运行了 top &
,之后再运行 top -o mem &
,因而我们有两个 top 实例在运行。此时 jobs
命令会这样告诉我们:
现在我们可以利用 fg <作业号>
切回任意一个实例。要再次终止程序,可以按下 cmd-Z
。
运行 jobs -l
也会列出每一个作业的进程 ID。
Linux 中的 bg
命令
当命令执行时,你可以按下 ctrl-Z
暂停它。
按下后,命令会即刻停止,并将你带回到 Shell 终端。
你可以恢复命令在后台的执行,这样既可以使命令保持运行,同时又不会妨碍你在终端中做其他工作。
在这一例子中,有 2 个命令停止了:
运行 bg 1
即可在后台恢复作业 #1 的执行。
我也可以不带任何参数执行 bg
命令,它会默认选取作业列表中的 #1 项。
Linux 中的 fg
命令
当命令在后台运行时,由于此前你已经在命令末尾加上了 &
(例如 top &
,或是使用了 bg
命令将命令放到后台),此时你可以用 fg
命令将其切换回前台。
执行
fg
它将在前台恢复最后被暂停的作业。
你也可以加上作业号,即可指定任一你想在前台恢复的作业,作业号可以使用 jobs
命令获得。
执行 fg 2
将恢复作业 #2:
Linux 中的 type
命令
命令可分为以下四种类型:
-
可执行程序
-
Shell 内置程序
-
Shell 功能
-
命令别名
如果你很想知道或只是很好奇,type
命令可以帮你分清这些。它会告诉你某一命令如何被解析。
输出根据 Shell 的类型而有所不同,这是在 Bash 中的样子:
这是在 Zsh 中的样子:
这是在 Fish 中的样子:
其中一个有趣的现象是:对于别名,它会告诉你某个别名将被解析到何处。例如,在 Bash 和 Zsh 中, ll
显示为一个别名,而在 Fish 中,由于 ll
是默认提供的,所以它会告诉你这是内置的 Shell 功能。
Linux 中的 which
命令
假定你有一个可直接执行的命令,因为它处在 Shell 路径中,但你想知道它的具体位置。
你可以用 which
来做这件事。这个命令会返回指定命令的路径。
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
:
我们将通过 xargs
把 cat todelete.txt
的输出引向 rm
命令。
就像这样:
cat todelete.txt | xargs rm
以下是执行结果,我们列出的文件现在已经被删除:
它的工作方式是:xargs
会运行 rm
2次,为 cat
返回的每一行运行一次。
这是 xargs
最简单的用法。我们还可以使用以下的一些参数。
在我看来,其中最有用的是 -p
(特别是刚开始学习 xargs
时)。使用这个选项将使 xargs
打印出一个确认提示,说明它要采取的行动:
-n
选项令 xargs
每次执行若干个迭代,因此你可以用 -p
单独确认它们。这里我们用 -n1
告诉 xargs
一次执行一个迭代:
另一个广泛应用的参数是 -I
。它可以将输出内容放入占位符,之后你可以用来做各种事。
其中一件事是同时运行多个命令,例如:
command1 | xargs -I % /bin/bash -c ‘command2 %; command3 %’
你可以将上方的
%
符号换成其他任何东西——它只是个变量。
Linux 中的 vim
编辑器命令
vim
是一个非常流行的文件编辑器,特别是在程序员中。 它被积极开发且经常更新,且有巨大的社区力量围绕着。甚至还有一个 Vim 会议!
在现代系统中,vi
只是 vim
的一个别名,意思是“改进的 vi
”(即 “vi
im
proved”)。
你可以在命令行运行 vi
启动它。
调用时指定一个文件名,你就可以编辑对应的文件:
vi test.txt
你需要了解的是,Vim 有两个主要的模式:
-
命令(command) 模式,也称为 普通(normal) 模式
-
插入(insert) 模式
当你启动编辑器时,默认处于命令模式。这时你无法像期望的那样,在基于图形界面的编辑器中输入文本。你需要进入插入模式。
可以按下 i
键进入插入模式。当你这样做之后, 在编辑器下方会出现 -- 插入 --
(或 INSERT)字样:
现在你可以开始输入了,用文件内容来填充终端屏幕:
你可以用方向键在文件中移动光标,或者使用 h
- j
- k
- l
四个键。 h-l
代表左和右,j-k
代表上和下。
当完成编辑时,按下 esc
键即可退出插入模式,回到命令模式。
此时你可以浏览文件,但无法向其添加内容(要注意按下了哪个键,某些键可能是编辑器的命令)。
现在你可能想知道如何保存文件。可以按下 :
(冒号),然后输入 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 会话:
macOS 用户们,现在请停一下。如果你当前在使用 Linux,那就没有什么问题,但 macOS 并未搭载使用 GPLv3 协议的应用程序,且每个内置的 UNIX 命令也没有更新到 GPLv3 版本。
虽然这对于我以上已经列出的命令来说,只是个小问题,但就本例而言,使用 2007 年的 emacs 版本与使用经过十余年改进和变化的版本,体验并不完全相同。
对于时常更新的 Vim 来说,这也不算什么。但想要解决 emacs 的问题,你需要运行 brew install emacs
,之后再运行 emacs
,即可使用 Homebrew 提供的新版本(确保 Homebrew 已安装)。
与 Vim 类似,你也可以调用 emacs <文件名>
来编辑已有的文件:
现在你可以开始编辑。当你完成编辑,先按下 ctrl-x
,然后按下 ctrl-w
。先确认文件夹:
而 Emacs 会告诉你这个文件已存在,并询问是否要覆盖它:
回答 y
,你会得到一条操作成功的确认信息:
要退出 Emacs ,可以按下 ctrl-x
,然后再按 ctrl-c
。
或者先按下 ctrl-x
之后再按 c
(期间按住 ctrl
不放)。
Emacs 还有很多要了解的地方,限于篇幅,我在这篇简短教程中不便展开。我鼓励诸位按下 ctrl-h
r
打开内置参考手册,或按下 ctrl-h
t
打开官方教程以继续学习。
Linux 中的 nano
编辑器命令
nano
是一个对初学者友好的编辑器。
输入 nano <文件名>
即可运行。
你可以直接向文件中输入字符,而不必担心所在的模式。
想退出而不修改,你可以直接按下 ctrl-X
。如果你已经编辑了文件缓冲区,编辑器会弹出确认提示,你可以选择保存或放弃更改。
底部的帮助栏为你显示了一部分用于处理文件的键盘命令:
另一条命令 pico
与它大致相同,不过 nano
其实是 pico
的 GNU 版本,后者在一段历史时期内并未开源。 于是人们克隆出 nano
以满足 GNU 操作系统的许可要求。
Linux 中的 whoami
命令
键入 whoami
即可将当前登录终端会话的用户名打印出来:
注意:这和可以输出更多信息的
who am i
命令并不一样。
Linux 中的 who
命令
who
命令显示当前已登录系统的用户。
除非你在使用多人访问的服务器,否则你可能是唯一的登录用户,并且登录了多次:
为什么说是多次呢?因为每打开一次 Shell,都会被算作一次访问。
你可以在此看到使用的终端名,以及会话的起始时间/日期。
参数 -aH
将使 who
显示更多的信息,包括空载的时间与终端的进程 ID:
特殊的 who am i
命令会列出当前终端会话的详情:
Linux 中的 su
命令
当你用一个用户登录到终端 Shell 时,可能需要切换到另一个用户。
例如,你以 root 身份登录,进行了维护工作,但之后你想切换到别的用户账户。
你可以用 su
命令来完成:
su <用户名>
例如: su flavio
.
如果你以用户身份登录,且不带参数运行 su
命令,它会遵从默认行为——提示你输入 root
用户的密码。
su
会以另一个用户的身份,开启新的 Shell。
当你完成操作,执行 exit
即可关闭新开的 Shell,并回到当前用户的 Shell。
Linux 中的 sudo
命令
sudo
通常用来以 root 身份运行命令。
你必须先启用当前身份才能使用 sudo
,启用之后,你可以直接输入你自己的登录密码( 而非 root 用户的密码)来以 root 身份运行命令。
这种权限是高度可配置的,在多用户的服务器环境中尤其有用。一些用户可以通过 sudo
被授予运行特定命令的权限。
例如,你可以用它编辑任一系统配置文件:
sudo nano /etc/hosts
这在普通模式下是无法实现的,因为你没有相应的权限。
你可以执行 sudo -i
,以 root 身份启动一个 Shell:
还可以使用 sudo
以其他任何用户身份运行命令。 默认情况是 root
, 但加上 -u
参数即可指定使用其他用户:
sudo -u flavio ls /Users/flavio
Linux 中的 passwd
命令
在 Linux 中,用户都有一个指定的密码。你可以使用 passwd
命令修改这个密码。
这里有两种情况。
第一种情况是:你想要修改自己的密码,此时你可以输入:
passwd
交互式提示会先询问你的旧密码,之后要求你输入新密码:
当你处于 root
身份(或是其他具有超级用户权限的用户)时,你可以设置你想要更改密码的用户名:
passwd
此时你无需输入旧密码。
Linux 中的 ping
命令
ping
命令可以在本地网络或互联网上探测一个特定的网络主机。
它的语法是 ping <host>
,其中 <host>
可以是域名或 IP 地址。
以下是探测 google.com
的例子:
这个命令向服务器发送一个请求,服务器则返回其响应信息。
ping
在默认情况下,每秒持续发送请求,只有按下 ctrl-C
时才会停止。你可以用 -c
参数指定想要的尝试次数:ping -c 2 google.com
。
一旦 ping
结束运行,它将输出一些结果:例如数据包丢失的百分比,以及其他关于网络性能的统计数据。
你可以看到,屏幕上输出了主机的 IP 地址,以及得到响应所花的时间。
并不是所有的服务器都可以探测,此时会出现请求超时:
有时这是为了“隐藏”服务器,或是减低服务器负载而故意设置的。为了探测所发送的数据包也可以被防火墙过滤。
ping
使用 ICMP 协议 (全称 Internet Control Message Protocol ,互联网控制报文协议)工作。ICMP 与 TCP 和 UDP 一样,是网络层协议。
探测请求向服务器发送一个含有 ECHO_REQUEST
信息的数据包,服务器则会返回 ECHO_REPLY
信息。此处我将不展开讲述,但这是最基本的概念。
用 Ping 探测,在测试主机是否可以访问时非常有用(此处假设主机支持探测),还可以从主机返回信息的时长,获知它的距离有多远。
通常,服务器在地理上离你越近,它向你返回信息的时间就越短。简单的物理规律则告诉我们:电缆越长,数据延迟越高。
Linux 中的 traceroute
命令
当你想要在互联网上到访某个主机时,数据首先会经过家庭路由器,然后到达你的运营商网络,再穿过上层的网络路由器,以此类推,直到最终连通主机。
你是否曾想过:数据包需要经过哪些步骤才能做到这一点?
traceroute
命令就是为此而生的。
你可以调用
traceroute
它将会(缓慢地)在数据包旅行时收集所有相关信息。
以下的例子中,我将尝试用 traceroute flaviocopes.com
到访我的博客:
通常,我们可以看到主机名、IP 地址以及一些性能指标。但并不是所有经过的路由器都会向我们返回信息,此时,traceroute
会输出 * * *
。
每个路由器都可以看到 3 个样本,这意味着 traceroute 默认尝试了 3 次,让你很好地了解到达主机所需的时间。
这就是对服务器执行 traceroute
比简单地执行 ping
要花更多时间的原因。
你可以用 -q
参数自定义尝试的次数:
traceroute -q 1 flaviocopes.com
Linux 中的 clear
命令
输入 clear
来清除当前终端之前执行的所有命令。
此时屏幕会被清理,你将只看到顶部的提示:
提示:这个命令有个好用的快捷键:
ctrl-L
不过,一旦使用了这个命令,你将不能用鼠标滚轮查看此前输入的命令。
因此你可能更想使用 clear -x
,这个参数可以在清理屏幕的同时,保留之前的终端输入,向上滚动鼠标即可回溯查看。
Linux 中的 history
命令
每次运行命令,都会在历史中保存一条记录。
你可以输入下面的命令来查看所有历史记录:
history
这会显示带有序号的历史记录:
你可以使用 !<命令序号>
重现已经储存在历史记录中的命令。以上的例子中,输入 !121
会重现 ls -al | wc -l
命令。
通常,历史记录会保留最后执行的 500 条命令。
你可以将这个命令与 grep
结合使用,以找到之前运行的命令:
history | grep docker
如果要清除历史记录,运行 history -c
即可。
Linux 中的 export
命令
export
命令用来向子进程输出变量。
这是什么意思呢?
假设你像下面这样定义一个 TEST 变量:
TEST=“test”
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Linux运维工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Linux运维知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加VX:vip1024b (备注Linux运维获取)
为了做好运维面试路上的助攻手,特整理了上百道 【运维技术栈面试题集锦】 ,让你面试不慌心不跳,高薪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行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
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)]