硬干货:下面这些运维工程师Linux指令你都知道吗?(一)

最后更新 :2022.03.05

大家好啊,今天盾叔又来给大家科普内容了!

什么?说我水文章,不可能!看来是得给你们点颜色看看,不然都不知道我有几把刷子~

大家都知道,无论是做运维还是渗透测试,我们用到最多的是什么?是理论知识吗?不,是各类的指令和命令,这些指令和命令会帮助我们更快捷方便的完成工作,解决问题。

今天,给大家带来了网络运维常用的Linux指令大全,快来看看,这些指令有哪些是你不知道的吧。

常用Linux指令大全

1.ls [选项] [目录名 | 列出相关目录下的所有目录和文件

-a 列出包括.a开头的隐藏文件的所有文件

-A 通-a,但不列出"."和".."

-l 列出文件的详细信息

-c 根据ctime排序显示

-t 根据文件修改时间排序

---color[=WHEN] 用色彩辨别文件类型 WHEN 可以是'never'、'always'或'auto'其中之一

白色:表示普通文件

蓝色:表示目录

绿色:表示可执行文件

红色:表示压缩文件

浅蓝色:链接文件

红色闪烁:表示链接的文件有问题

黄色:表示设备文件

灰色:表示其它文件


2.mv [选项] 源文件或目录 目录或多个源文件 | 移动或重命名文件

-b 覆盖前做备份

-f 如存在不询问而强制覆盖

-i 如存在则询问是否覆盖

-u 较新才覆盖

-t 将多个源文件移动到统一目录下,目录参数在前,文件参数在后

eg:

mv a /tmp/ 将文件a移动到 /tmp目录下

mv a b 将a命名为b

mv /home/zenghao test1.txt test2.txt test3.txt


3.cp [选项] 源文件或目录 目录或多个源文件 | 将源文件复制至目标文件,或将多个源文件复制至目标目录。

-r -R 递归复制该目录及其子目录内容

-p 连同档案属性一起复制过去

-f 不询问而强制复制

-s 生成快捷方式

-a 将档案的所有特性都一起复制


4.scp [参数] [原路径] [目标路径] | 在Linux服务器之间复制文件和目录

-v 详细显示输出的具体情况

-r 递归复制整个目录

(1) 复制文件:

命令格式:

scp local_file remote_username@remote_ip:remote_folder

或者

scp local_file remote_username@remote_ip:remote_file

或者

scp local_file remote_ip:remote_folder

或者

scp local_file remote_ip:remote_file

第1,2个指定了用户名,命令执行后需要输入用户密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名

第3,4个没有指定用户名,命令执行后需要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名

(2) 复制目录:

命令格式:

scp -r local_folder remote_username@remote_ip:remote_folder

或者

scp -r local_folder remote_ip:remote_folder

第1个指定了用户名,命令执行后需要输入用户密码;

第2个没有指定用户名,命令执行后需要输入用户名和密码;

eg:

从 本地 复制到 远程

scp /home/daisy/full.tar.gz root@172.19.2.75:/home/root

从 远程 复制到 本地

scp root@/172.19.2.75:/home/root/full.tar.gz /home/daisy/full.tar.gz


5.rm [选项] 文件 | 删除文件

-r 删除文件夹

-f 删除不提示

-i 删除提示

-v 详细显示进行步骤


6.touch [选项] 文件 | 创建空文件或更新文件时间

-a 只修改存取时间

-m 值修改变动时间

-r eg:touch -r a b ,使b的时间和a相同

-t 指定特定的时间 eg:touch -t 201211142234.50 log.log

-t time [[CC]YY]MMDDhhmm[.SS],C:年前两位


7.pwd 查看当前所在路径

8.cd 改变当前目录

- :返回上层目录

.. :返回上层目录

回车 :返回主目录

/ :根目录


9.mkdir [选项] 目录… | 创建新目录

-p 递归创建目录,若父目录不存在则依次创建

-m 自定义创建目录的权限 eg:mkdir -m 777 hehe

-v 显示创建目录的详细信息


10.rmdir 删除空目录

-v 显示执行过程

-p 若自父目录删除后父目录为空则一并删除


11.rm [选项] 文件… | 一个或多个文件或目录

-f 忽略不存在的文件,不给出提示

-i 交互式删除

-r 将列出的目录及其子目录递归删除

-v 列出详细信息


12.echo:显示内容

-n 输出后不换行

-e 遇到转义字符特殊处理

eg:

echo "he\nhe" 显示he\nhe

ehco -e "he\nhe" 显示he(换行了)he




13.cat [选项] [文件]..| 一次显示整个文件或从键盘创建一个文件或将几个文件合并成一个文件

-n 编号文件内容再输出

-E 在结束行提示$


14.tac | 反向显示

15.more | 按页查看文章内容,从前向后读取文件,因此在启动时就加载整个文件

+n 从第n行开始显示

-n 每次查看n行数据

+/String 搜寻String字符串位置,从其前两行开始查看

-c 清屏再显示

-p 换页时清屏


16.less | 可前后移动地逐屏查看文章内容,在查看前不会加载整个文件

-m 显示类似于more命令的百分比

-N 显示行号

/ 字符串:向下搜索“字符串”的功能

? 字符串:向上搜索“字符串”的功能

n 重复前一个搜索(与 / 或 ? 有关)

N 反向重复前一个搜索(与 / 或 ? 有关)

b 向后翻一页

d 向后翻半页


17.nl [选项]… [文件]… | 将输出内容自动加上行号

-b

-b a 不论是否有空行,都列出行号(类似 cat -n)

-b t 空行则不列行号(默认)

-n 有ln rn rz三个参数,分别为再最左方显示,最右方显示不加0,最右方显示加0


18.head [参数]… [文件]… | 显示档案开头,默认开头10行

-v 显示文件名

-c number 显示前number个字符,若number为负数,则显示除最后number个字符的所有内容

-number/n (+)number 显示前number行内容,

-n number 若number为负数,则显示除最后number行数据的所有内容


19.tail [必要参数] [选择参数] [文件] | 显示文件结尾内容

-v 显示详细的处理信息

-q 不显示处理信息

-num/-n (-)num 显示最后num行内容

-n +num 从第num行开始显示后面的数据

-c 显示最后c个字符

-f 循环读取


20.vi 编辑文件

:w filename 将文章以指定的文件名保存起来

:wq 保存并退出

:q! 不保存而强制退出

命令行模式功能键

(1)插入模式

按「i」切换进入插入模式「insert mode」,按"i"进入插入模式后是从光标当前位置开始输入文件;

按「a」进入插入模式后,是从目前光标所在位置的下一个位置开始输入文字;

按「o」进入插入模式后,是插入新的一行,从行首开始输入文字。


(2)从插入模式切换为命令行模式

按「ESC」键。


(3)移动光标

  vi可以直接用键盘上的光标来上下左右移动,但正规的vi是用小写英文字母「h」、「j」、「k」、「l」,分别控制光标左、下、上、右移一格。

  按「ctrl」+「b」:屏幕往"后"移动一页。

  按「ctrl」+「f」:屏幕往"前"移动一页。

  按「ctrl」+「u」:屏幕往"后"移动半页。

  按「ctrl」+「d」:屏幕往"前"移动半页。

  按数字「0」:移到文章的开头。

  按「G」:移动到文章的最后。

  按「$」:移动到光标所在行的"行尾"。

  按「^」:移动到光标所在行的"行首"

  按「w」:光标跳到下个字的开头

  按「e」:光标跳到下个字的字尾

  按「b」:光标回到上个字的开头

  按「#l」:光标移到该行的第#个位置,如:5l,56l。


(4)删除文字

  「x」:每按一次,删除光标所在位置的"后面"一个字符。

  「#x」:例如,「6x」表示删除光标所在位置的"后面"6个字符。

  「X」:大写的X,每按一次,删除光标所在位置的"前面"一个字符。

  「#X」:例如,「20X」表示删除光标所在位置的"前面"20个字符。

  「dd」:删除光标所在行。

  「#dd」:从光标所在行开始删除#行


(5)复制

  「yw」:将光标所在之处到字尾的字符复制到缓冲区中。

  「#yw」:复制#个字到缓冲区

  「yy」:复制光标所在行到缓冲区。

  「#yy」:例如,「6yy」表示拷贝从光标所在的该行"往下数"6行文字。

  「p」:将缓冲区内的字符贴到光标所在位置。注意:所有与"y"有关的复制命令都必须与"p"配合才能完成复制与粘贴功能。


(6)替换

  「r」:替换光标所在处的字符。

  「R」:替换光标所到之处的字符,直到按下「ESC」键为止。


(7)回复上一次操作

  「u」:如果您误执行一个命令,可以马上按下「u」,回到上一个操作。按多次"u"可以执行多次回复。


(8)更改

  「cw」:更改光标所在处的字到字尾处

  「c#w」:例如,「c3w」表示更改3个字


(9)跳至指定的行

  「ctrl」+「g」列出光标所在行的行号。

  「#G」:例如,「15G」,表示移动光标至文章的第15行行首。


21.which 可执行文件名称 | 查看可执行文件的位置,在PATH变量指定的路径中查看系统命令是否存在及其位置

22.whereis [-bmsu] [BMS 目录名 -f ] 文件名| 定位可执行文件、源代码文件、帮助文件在文件系统中的位置

-b 定位可执行文件。

-m 定位帮助文件。

-s 定位源代码文件。

-u 搜索默认路径下除可执行文件、源代码文件、帮助文件以外的其它文件。

-B 指定搜索可执行文件的路径。

-M 指定搜索帮助文件的路径。

-S 指定搜索源代码文件的路径。


23.locate | 通过搜寻数据库快速搜寻档案

-r 使用正规运算式做寻找的条件


24.find find [PATH] [option] [action] | 在文件树种查找文件,并作出相应的处理

选项与参数:

1. 与时间有关的选项:共有 -atime, -ctime 与 -mtime 和-amin,-cmin与-mmin,以 -mtime 说明

-mtime n :n 为数字,意义为在 n 天之前的『一天之内』被更动过内容的档案;

-mtime +n :列出在 n 天之前(不含 n 天本身)被更动过内容的档案档名;

-mtime -n :列出在 n 天之内(含 n 天本身)被更动过内容的档案档名。

-newer file :file 为一个存在的档案,列出比 file 还要新的档案档名


2. 与使用者或组名有关的参数:

-uid n :n 为数字,这个数字是用户的账号 ID,亦即 UID

-gid n :n 为数字,这个数字是组名的 ID,亦即 GID

-user name :name 为使用者账号名称!例如 dmtsai

-group name:name 为组名,例如 users ;

-nouser :寻找档案的拥有者不存在 /etc/passwd 的人!

-nogroup :寻找档案的拥有群组不存在于 /etc/group 的档案!


3. 与档案权限及名称有关的参数:

-name filename:搜寻文件名为 filename 的档案(可使用通配符)

-size [+-]SIZE:搜寻比 SIZE 还要大(+)或小(-)的档案。这个 SIZE 的规格有:

c: 代表 byte

k: 代表 1024bytes。所以,要找比 50KB还要大的档案,就是『 -size +50k 』

-type TYPE :搜寻档案的类型为 TYPE 的,类型主要有:

一般正规档案 (f)

装置档案 (b, c)

目录 (d)

连结档 (l)

socket (s)

FIFO (p)

-perm mode :搜寻档案权限『刚好等于』 mode的档案,这个mode为类似chmod的属性值,举例来说,-rwsr-xr-x 的属性为4755!

-perm -mode :搜寻档案权限『必须要全部囊括 mode 的权限』的档案,举例来说,

我们要搜寻-rwxr--r-- 亦即 0744 的档案,使用-perm -0744,当一个档案的权限为 -rwsr-xr-x ,亦即 4755 时,也会被列出来,因为 -rwsr-xr-x 的属性已经囊括了 -rwxr--r-- 的属性了。

-perm +mode :搜寻档案权限『包含任一 mode 的权限』的档案,举例来

说,我们搜寻-rwxr-xr-x ,亦即 -perm +755 时,但一个文件属性为 -rw-------也会被列出来,因为他有 -rw.... 的属性存在!

4. 额外可进行的动作:

-exec command :command 为其他指令,-exec 后面可再接额外的指令来处理搜寻到的结果。

-print :将结果打印到屏幕上,这个动作是预设动作!

eg:

find / -perm +7000 -exec ls -l {} \; ,额外指令以-exec开头,以\;结尾{}代替前面找到的内容

| xargs

-i 默认的前面输出用{}代替

eg:

find . -name "*.log" | xargs -i mv {} test4


25.grep ‘正则表达式’ 文件名 | 用正则表达式搜索文本,并把匹配的行打印出来

-c 只输出匹配行的计数。

-I 不区分大小写(只适用于单字符)。

-l 只显示文件名

-v 显示不包含匹配文本的所有行。

-n 显示匹配行数据及其行号


26.gzip [-cdtv#] 檔名 | 压缩、解压缩,源文件都不再存在

-d 进行解压缩

-c 将压缩的数据输出到屏幕上

-v :显示原档案/压缩文件案的压缩比等信息

-# :压缩等级,-1最快,但压缩比最差,=9最慢,但压缩比最好


27.gunzip | 解压缩

28.bzip2 | 压缩、解压缩

-d :解压

-z :压缩

-k :保留源文件

-c :将压缩的过程产生的数据输出到屏幕上!

-v :可以显示出原档案/压缩文件案的压缩比等信息;

-# :与 gzip 同样的,都是在计算压缩比的参数, -9 最佳, -1 最快!


29.bzcat 读取数据而无需解压

30.tar [主选项+辅选项] 文件或者目录 | 多个目录或档案打包、压缩成一个大档案

主选项:

-c 建立打包档案,可搭配 -v 来察看过程中被打包的档名(filename)

-t 察看打包档案的内容含有哪些档名,重点在察看『档名』就是了;

-x 解打包或解压缩的功能,可以搭配 -C (大写) 在特定目录解开

辅选项:

-j 透过 bzip2 的支持进行压缩/解压缩:此时档名最好为 *.tar.bz2

-z 透过 gzip 的支持进行压缩/解压缩:此时档名最好为 *.tar.gz

-v 在压缩/解压缩的过程中,将正在处理的文件名显示出来!

-f filename -f 后面要立刻接要被处理的档名!

-C 目录 这个选项用在解压缩,若要在特定目录解压缩,可以使用这个选项。

--exclude FILE:在压缩打包过程中忽略某文件 eg: tar --exclude /home/zenghao -zcvf myfile.tar.gz /home/* /etc

-p 保留备份数据的原本权限与属性,常用于备份(-c)重要的配置文件

-P(大写) 保留绝对路径,亦即允许备份数据中含有根目录存在之意;

eg:

压 缩:tar -jcvf filename.tar.bz2 要被压缩的档案或目录名称

查 询:tar -jtvf filename.tar.bz2

解压缩:tar -jxvf filename.tar.bz2 -C 欲解压缩的目录


31.exit 退出当前shell

32.logout 退出登录shell

33.shutdown -h now

34.users 显示当前登录系统地用户

35.who 登录在本机的用户与来源

-H或--heading  显示各栏位的标题信息列。


36.w 登录在本机的用户及其运行的程序

-s  使用简洁格式列表,不显示用户登入时间,终端机阶段作业和程序所耗费的CPU时间。

-h  不显示各栏位的标题信息列。


37.write 给当前联机的用户发消息

38.wall 给所有登录再本机的用户发消息

39.last 查看用户的登陆日志

40.lastlog 查看每个用户最后的登陆时间

由于盾叔手打的比较累,今天就只分享一部分,剩下的,后面再分享给大家。

当然啦,要是你迫不及待想知道下面的内容了,可以让盾叔帮你联系下隔壁技术员小姐姐,不过能不能弄出货来就看你自己啦。(懂我意思吧)

最后,再跟大家多叨叨两句,不要每次来就是问我,现在网络安全这块前景怎么样啊,能不能赚钱啊?

我都说了不知道多少次了,现在网络安全行业的人才缺口日益增加,国家对于这方面的人才关注度也非常大,所以前景是一定没问题的,要是没赚钱,那么一定有两个原因。

一是自己没有好好学,三天打鱼两天晒网的,第二个原因是你没有选对方法,比如你来这里试试(指下图),有时候,选择真的比努力更重要!!

- END -

看更多