我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Linux常用命令总结(建议收藏)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Linux常用命令总结(建议收藏)

在这里插入图片描述


文章目录

一、文件管理

1、cat:查看文件内容

-n:由 1 开始对所有输出的行数编号。

ubuntu@VM-24-12-ubuntu:~/20221212$ cat case.sh #!/bin/bashecho "请输入数字:"read numcase $num in        1)                echo "你选择了1"                ;;        2)                echo "你选择了2"                ;;        3)                echo "你选择了3"                ;;        4)                echo "你选择了4"                ;;        *)                echo "输入错误"                ;;esac

案例1:输出内容+行数

ubuntu@VM-24-12-ubuntu:~/20221212$ cat -n case.sh      1  #!/bin/bash     2  echo "请输入数字:" num     3  read -p -n1 "你输入的num是" num      4  case $num in     5          1)     6                  echo "你选择了1"     7                  ;;     8          2)     9                  echo "你选择了2"    10                  ;;    11          3)    12                  echo "你选择了3"    13                  ;;    14          4)    15                  echo "你选择了4"    16                  ;;    17          *)    18                  echo "输入错误"    19                  ;;    20  esac

2、chmod:是控制用户对文件的权限的命令

每个文件的属性由左边第一部分的 10 个字符来确定(如下图)
在这里插入图片描述

从左至右用 0-9 这些数字来表示。
第 0 位确定文件类型,
第 1-3 位确定属主(该文件的所有者)拥有该文件的权限。
第4-6位确定属组(所有者的同组用户)拥有该文件的权限,
第7-9位确定其他用户拥有该文件的权限。
其中,
第 1、4、7 位表示读权限,如果用 r 字符表示,则有读权限,如果用 - 字符表示,则没有读权限;
第 2、5、8 位表示写权限,如果用 w 字符表示,则有写权限,如果用 - 字符表示没有写权限;
第 3、6、9 位表示可执行权限,如果用 x 字符表示,则有执行权限,如果用 - 字符表示,则没有执行权限。

Linux/Unix 的文件调用权限分为三级 :
文件所有者(Owner)
用户组(Group)
其它用户(Other Users)

Linux文件属性有两种设置方法,一种是数字,一种是符号。
Linux 文件的基本权限就有九个,分别是 owner/group/others(拥有者/组/其他) 三种身份各有自己的 read/write/execute 权限。

r:4
w:2
x:1

每种身份(owner/group/others)各自的三个权限(r/w/x)分数是需要累加的,例如当权限为: -rwxrwx— 分数则是:

owner = rwx = 4+2+1 = 7
group = rwx = 4+2+1 = 7
others= — = 0+0+0 = 0
文件的权限字符为: -rwxrwxrwx , 这九个权限是三个三个一组的!其中,我们可以使用数字来代表各个权限,各权限的分数对照表如下:

案例1::将user文件修改成用户、组、其他用户都可以读写可执行的权限

ubuntu@VM-24-12-ubuntu:~/20221212$ chmod 777 users 

3、diff:用于比较文件的差异

diff以逐行的方式,比较文本文件的异同处。如果指定要比较目录,则 diff 会比较目录中相同文件名的文件,但不会比较其中子目录。

ubuntu@VM-24-12-ubuntu:~/20221212$ diff func1.sh func2.sh 4c4<       echo "输入的第一个数为:"--->       echo "请输入的第一个数为:"6c6<       echo "输入的第二个数为:"--->       echo "请输入的第二个数为:"11a12> 13c14< echo "输入的两个数字之和为:$?"---> echo "两个数字之和为:$?"

4、find:命令用来在指定目录下查找文件。

案例1:查找当前目录下以.sh结束的所有文件

ubuntu@VM-24-12-ubuntu:~/20221212$ find ./ -name '*.sh'./func1.sh./for.sh./test2.sh./break.sh./case.sh./test1.sh./func2.sh./func.sh./while.sh./if.sh

案例2:查找当前目录下以f开头的所有文件

ubuntu@VM-24-12-ubuntu:~/20221212$ find ./ -name 'f*'./func1.sh./for.sh./func2.sh./func.sh

案例3:最近60分钟内修改过的文件

ubuntu@VM-24-12-ubuntu:~/20221212$ find -cmin -60../test3.sh

案例4:查找当前目录下以sh结尾的文件,并且把这些文件复制到20221214目录下

ubuntu@VM-24-12-ubuntu:~/20221212$ find ./ -name "*.sh" -exec cp {} ./20221214/ \;

5、cut:截切、取出文本中指定的列、默认以空格或者tab键进行分割(不支持不规则的空格) 选项。

参数:

-c :以字符为单位进行分割。
-d :自定义分隔符,默认为制表符。
-f :与-d一起使用,指定显示哪个区域。

test1.txt文件

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ cat test1.txt name    area            agekobe    beijing         18jm      shanghai        19james   changsha        20

案例1:查看第一列的内容(默认以制表符)

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ cut -f1 test1.txt namekobe jmjames

案例2:以冒号为准,查看第一列的内容(默认以制表符)

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ cut -d":" -f1 passwd rootdaemonbinsyssyncgamesman

案例3:以冒号为准,查看第一列到第3列的内容

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ cut -d: -f1-3 passwd root:x:0daemon:x:1bin:x:2sys:x:3sync:x:4games:x:5man:x:6

6、less:可以随意浏览文件,支持翻页和搜索,支持向上翻页和向下翻页。

ps查看进程信息并通过less分页显示

ubuntu@VM-24-12-ubuntu:~/20221212$ ps -ef | less

7、more:类似 cat ,不过会以一页一页的形式显示,更方便使用者逐页阅读

8、mv:用来为文件或目录改名、或将文件或目录移入其它位置

命令格式运行结果

mv source_file(文件) dest_file(文件)
将源文件名 source_file 改为目标文件名 dest_file

mv source_file(文件) dest_directory(目录)
将文件 source_file 移动到目标目录 dest_directory 中

mv source_directory(目录) dest_directory(目录)
目录名 dest_directory 已存在,将 source_directory 移动到目录名 dest_directory 中;目录名 dest_directory 不存在则 source_directory 改名为目录名 dest_directory

mv source_directory(目录) dest_file(文件) 出错

9、rm:删除文件或者目录

-i 删除前逐一询问确认。
-f 即使原档案属性设为唯读,亦直接删除,无需逐一确认。
-r 将目录及以下之档案亦逐一删除。

删除文件可以直接使用rm命令,若删除目录则必须配合选项"-r",例如:

rm  test.txt rm:是否删除 一般文件 "test.txt"? y  rm  homework  rm: 无法删除目录"homework": 是一个目录  rm  -r  homework  rm:是否删除 目录 "homework"? y 

10、touch:用于修改文件或者目录的时间属性,包括存取时间和更改时间。若文件不存在,系统会建立一个新的文件

使用指令"touch"修改文件"test1.sh "的时间属性为当前系统时间,输入如下命令:

首先,使用ls命令查看"test1.sh "文件的属性,如下所示:

ubuntu@VM-24-12-ubuntu:~/20221212$ ls -al test1.sh -rw-rw-r-- 1 ubuntu ubuntu 242 Dec 12 23:11 test1.sh

执行指令"touch"修改文件属性以后,并再次查看该文件的时间属性,如下所示:

ubuntu@VM-24-12-ubuntu:~/20221212$ touch test1.sh ubuntu@VM-24-12-ubuntu:~/20221212$ ls -al test1.sh -rw-rw-r-- 1 ubuntu ubuntu 242 Dec 14 23:07 test1.sh

11、cp:复制文件或者目录

-r:若给出的源文件是一个目录文件,此时将复制该目录下所有的子目录和文件。

使用指令 cp 将当前目录 test/ 下的所有文件复制到新目录 newtest 下,输入如下命令:

$ cp –r test/ newtest          

12、scp: scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。

1、从本地将文件传输到服务器

scp【本地文件的路径】【服务器用户名】@【服务器地址】:【服务器上存放文件的路径】

scp /root/test ubuntu@82.156.178.247:/home/ubuntu/20221212/

2、从本地将文件夹传输到服务器

scp -r【本地文件的路径】【服务器用户名】@【服务器地址】:【服务器上存放文件的路径】

scp /root/my.txt ubuntu@82.156.178.247:/home/ubuntu/20221212/

3、将服务器上的文件传输到本地

scp 【服务器用户名】@【服务器地址】:【服务器上存放文件的路径】【本地文件的路径】

scp root@82.156.178.247:/data/wwwroot/default/111.png /Users/Desktop

4、将服务器上的文件夹传输到本地

scp -r 【服务器用户名】@【服务器地址】:【服务器上存放文件的路径】【本地文件的路径】

scp -r root@82.156.178.247:/data/wwwroot/default/test /Users/Desktop

13、awk:一种处理文本文件的语言,是一个强大的文本分析工具

BEGIN{}:处理数据之前执行,只执行一次
pattern:匹配模式
{commands}:处理的命令
END{}:处理数据之后执行,只执行一次

内置变量

$0:整行内容
$1-$n:当前行的第1-n个字段
NF:当前行的字段数
NR:当前行行号
FS:输入字段分隔符,默认为空格或者tab键
RS:输入行分隔符,默认为回车符

案例1:、打印文本中所有行的内容(空格)

ubuntu@VM-24-12-ubuntu:~/20221212$ awk '{print $0}' test1.sh #!/bin/bashecho "shell脚本中传递参数:"echo "脚本名称:$0"echo "传递的第一个参数:$1"echo "传递的第二个参数:$2"echo "传递的参数个数:$#"echo "传递的参数有:$@"echo "传递的参数有:$*"

案例2:、打印文本中第一列的内容(空格)

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ awk '{print $1}' test1.txt namekobejmjameszilvjm

案例3:、打印出文本中最后一列的内容(空格)

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ awk '{print $NF}' test1.txt age1819201621

案例4:、打印出文本中倒数第二列的内容(空格)

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ awk '{print $(NF-1)}' test1.txt areabeijingshanghaichangshaawk: cmd. line:1: (FILENAME=test1.txt FNR=5) fatal: attempt to access field -1

案例5:、将包含www关键字的所在行的第3列取出

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ awk '/jm/ {print $2}' test1.txt shanghaiwuhan

案例6:、将以gdm开头到mysql开头之间所有行的最后一列取出(按照冒号分割)

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ awk -F: '/^gdm/,/^mysql/ {print $NF}' passwd /bin/false/usr/sbin/nologin/bin/bash/usr/sbin/nologin/bin/false

案例7:、打印第一行中的第一列

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ awk -F: 'NR==10 {print $1}' passwd lp

案例8:、打印第1到第5行中的第一列

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ awk -F: 'NR==1,NR==5 {print $1}' passwd tdaemonbinsys

案例9:、将文件从10到18行,并且第一列和最后一列打印出来

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ awk -F: 'NR==10,NR==18 {print $1,$NF}' passwd lp /usr/sbin/nologinmail /usr/sbin/nologinnews /usr/sbin/nologinuucp /usr/sbin/nologinproxy /usr/sbin/nologinwww-data /usr/sbin/nologinbackup /usr/sbin/nologinlist /usr/sbin/nologinirc /usr/sbin/nologin

案例10:、将文件从10到18行,并且第一列和最后一列打印出来(左对齐)

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ awk -F: 'NR==10,NR==18 {printf "%-15s%-20s\n",$1,$NF}' passwd lp             /usr/sbin/nologin   mail           /usr/sbin/nologin   news           /usr/sbin/nologin   uucp           /usr/sbin/nologin   proxy          /usr/sbin/nologin   www-data       /usr/sbin/nologin   backup         /usr/sbin/nologin   list           /usr/sbin/nologin   irc            /usr/sbin/nologin   

14、read:用于从标准输入读取数值

-p 后面跟提示信息,即在输入前打印提示信息
-n 后跟一个数字,定义输入文本的长度,很实用。

案例1:简单读取

echo "请输入数字:"read numcase $num in        1)                echo "你选择了1"                ;;        2)                echo "你选择了2"                ;;        3)                echo "你选择了3"                ;;        4)                echo "你选择了4"                ;;        *)                echo "输入错误"                ;;esac
ubuntu@VM-24-12-ubuntu:~/20221212$ bash case.sh 请输入数字:2你选择了2

案例2:-p 参数,允许在 read 命令行中直接指定一个提示。

#!/bin/bashecho "请输入数字:" numread -p "你输入的num是" numcase $num in        1)                echo "你选择了1"                ;;        2)                echo "你选择了2"                ;;        3)                echo "你选择了3"                ;;        4)                echo "你选择了4"                ;;        *)                echo "输入错误"                ;;esac
ubuntu@VM-24-12-ubuntu:~/20221212$ bash case.sh 请输入数字: num你输入的num是2你选择了2

案例3:-n 参数设置 read 命令计数输入的字符。当输入的字符数目达到预定数目时,自动退出,并将输入的数据赋值给变量。

#!/bin/bashread -n1 -p "请你输入[Y/N]" answercase $answer in        Y | y)                echo "继续"                ;;        N | n)                echo "bye"                ;;        *)                echo "error choice"                ;;esac
ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ bash read.sh 请你输入[Y/N]Y继续ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ bash read.sh 请你输入[Y/N]Merror choiceubuntu@VM-24-12-ubuntu:~/20221212/20221215$ bash read.sh 请你输入[Y/N]error choice

15、head:用于查看文件的开头部分的内容,

有一个常用的参数 -n 用于显示行数,默认为 10,即显示 10 行的内容。

案例:显示前3行内容

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ head -n3 read.sh #!/bin/bashread -n1 -p "请你输入[Y/N]" answercase $answer in

16、tail:用于查看文件的内容,

有一个常用的参数 -f 常用于查阅正在改变的日志文件

tail -f filename 会把 filename 文件里的最尾部的内容显示在屏幕上,并且不断刷新,只要 filename 更新就可以看到最新的文件内容。

命令格式:

tail [参数] [文件]

tail notes.log # 默认显示最后 10 行

要跟踪名为 notes.log 的文件的增长情况,请输入以下命令:

tail -f notes.log

二、文档编辑

1、grep:用于查找文件里符合条件的字符串

-i:忽略大小写
-c:只输出匹配行的数量
-n:显示行号
-r:递归搜索
-l:只列出匹配的文件名

案例1、查找文件下包含mysql关键字的所在行

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ grep -i -n 'mysql' passwd 48:mysql:x:127:134:MySQL Server,,,:/nonexistent:/bin/false

案例2、查找某个目录下包含mysql关键字的内容

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ grep -i -n -r 'mysql' ././passwd:48:mysql:x:127:134:MySQL Server,,,:/nonexistent:/bin/false

案例3、查找某个目录下包含mysql关键字的路径

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ grep -i -l -r 'mysql' ../../20221215/passwd

案例4、查找以redis开头的所有行

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ grep -i -n '^redis' passwd 49:redis:x:128:135::/var/lib/redis:/usr/sbin/nologin

案例5、查找以false结尾的所有行

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ grep -i -n 'false$' passwd 27:tss:x:106:111:TPM software stack,,,:/var/lib/tpm:/bin/false35:speech-dispatcher:x:114:29:Speech Dispatcher,,,:/run/speech-dispatcher:/bin/false38:hplip:x:119:7:HPLIP system user,,,:/run/hplip:/bin/false39:whoopsie:x:120:125::/nonexistent:/bin/false43:gnome-initial-setup:x:124:65534::/run/gnome-initial-setup/:/bin/false44:gdm:x:125:130:Gnome Display Manager:/var/lib/gdm3:/bin/false48:mysql:x:127:134:MySQL Server,,,:/nonexistent:/bin/false

案例6、查找包含“oo”的内容

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ grep -i -n 'oo' passwd 2:t:x:0:0:root:/root:/bin/bash10:lp:x:7:7:lp:/var/spool/lpd:/usr/sbin/nologin12:news:x:9:9:news:/var/spool/news:/usr/sbin/nologin13:uucp:x:10:10:uucp:/var/spool/uucp:/usr/sbin/nologin37:kernoops:x:116:65534:Kernel Oops Tracking Daemon,,,:/:/usr/sbin/nologin39:whoopsie:x:120:125::/nonexistent:/bin/false

案例7、统计包含“oo”关键字的行数

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ grep -i -c 'oo' passwd 6

2、sed:文本的增删改查

-n:只打印模式匹配的行
-f:加载存放动作的文件
-r:支持拓展正则
-i:直接修改文件

案例1、将第4行打印出来

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed -n '4 p' passwd bin:x:2:2:bin:/bin:/usr/sbin/nologin

案例2、将第5行到第8行打印出来

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed -n '5,8 p' passwd sys:x:3:3:sys:/dev:/usr/sbin/nologinsync:x:4:65534:sync:/bin:/bin/syncgames:x:5:60:games:/usr/games:/usr/sbin/nologinman:x:6:12:man:/var/cache/man:/usr/sbin/nologin

案例3、将包含root的内容打印出来

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed -n '/root/ p' passwd t:x:0:0:root:/root:/bin/bash

案例4、将以m开头的内容打印出来

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed -n '/^m/ p' passwd man:x:6:12:man:/var/cache/man:/usr/sbin/nologinmail:x:8:8:mail:/var/mail:/usr/sbin/nologinmessagebus:x:103:106::/nonexistent:/usr/sbin/nologinmysql:x:127:134:MySQL Server,,,:/nonexistent:/bin/false

案例5、将以man开头到list开头中间的内容打印出来

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed -n  '/^man/,/^list/ p' passwd man:x:6:12:man:/var/cache/man:/usr/sbin/nologin666666666这三新增的内容lp:x:7:7:lp:/var/spool/lpd:/usr/sbin/nologinmail:x:8:8:mail:/var/mail:/usr/sbin/nologinnews:x:9:9:news:/var/spool/news:/usr/sbin/nologinuucp:x:10:10:uucp:/var/spool/uucp:/usr/sbin/nologinproxy:x:13:13:proxy:/bin:/usr/sbin/nologinwww-data:x:33:33:www-data:/var/www:/usr/sbin/nologinbackup:x:34:34:backup:/var/backups:/usr/sbin/nologinlist:x:38:38:Mailing List Manager:/var/list:/usr/sbin/nologin

案例6、在man开头的下面新增内容

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed '/^man/ a 20221215新增的内容' passwd t:x:0:0:root:/root:/bin/bashdaemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologinbin:x:2:2:bin:/bin:/usr/sbin/nologinsys:x:3:3:sys:/dev:/usr/sbin/nologinsync:x:4:65534:sync:/bin:/bin/syncgames:x:5:60:games:/usr/games:/usr/sbin/nologinman:x:6:12:man:/var/cache/man:/usr/sbin/nologin20221215新增的内容lp:x:7:7:lp:/var/spool/lpd:/usr/sbin/nologinmail:x:8:8:mail:/var/mail:/usr/sbin/nologin

案例7、将文本中包含“四”关键字的行删除

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed '/jm/ d' test1.txt name    area            agekobe    beijing         18james   changsha        20

案例8、将文本中包含五的行和空行删除

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed -r '/^jm|^$/ d' test1.txt name    area            agekobe    beijing         18james   changsha        20zilv    beijing         16

案例9、将第2和3行删除

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed '2,3 d' test1.txt name    area            agejames   changsha        20zilv    beijing         16

案例10、删除第2到最后一行

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed '2,$ d' test1.txt name    area            age

案例11、将jm改成zhil(如果一行有多个,默认修改的是第一个)

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed 's/jm/zhil/g' test1.txt name    area            agekobe    beijing         18zhil    shanghai        19james   changsha        20zilv    beijing         16

案例12、将jm改成zhil,全局修改

g:全局修改
i:忽略大小写

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed 's/jm/zhil/gi' test1.txt name    area            agekobe    beijing         18zhil    shanghai        19james   changsha        20zilv    beijing         16zhil    wuhan           21

案例13、将第2~4行的jm改成zhil,全局修改

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sed '2,4 s/jm/zhil/g' test1.txt name    area            agekobe    beijing         18zhil    shanghai        19james   changsha        20zilv    beijing         16jm      wuhan           21

3、sort:对文本的内容进行排序

默认以字符的ASCII数码值从小到大排序

-n:以数值大小进行排序
-r:倒序
-t:指定分隔符,默认为空格
-k num:指定某个字段进行排序

案例1:以数值大小(从大到小)进行排序

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sort -n sort.txt 1 2345788899 

案例2:sort -n file | uniq:去重(前提进行排序)

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sort -n sort.txt | uniq1 2345789

4、expr:手工命令行计数器,用于在UNIX/LINUX下求表达式变量的值,一般用于整数值,也可用于字符串

用空格隔开每个项;
用反斜杠 \ 放在 shell 特定的字符前面;
对包含空格和其他特殊字符的字符串要用引号括起来

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ expr 2 + 35ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ expr 2 - 3 -1ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ expr 2 \* 3 6ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ expr 8 / 2 4

5、uniq:用于检查及删除文本文件中重复出现的行列,一般与 sort 命令结合使用。

6、wc:计算文本数量

wc -l 打印行数
wc -w 打印单词数

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ wc -l test1.txt 4 test1.txtubuntu@VM-24-12-ubuntu:~/20221212/20221215$ wc -w test1.txt 12 test1.txt

三、磁盘管理

1、cd:用于切换当前工作目录

2、df:用于显示目前在 Linux 系统上的文件系统磁盘使用情况统计

ubuntu@VM-24-12-ubuntu:~/20221212$ dfFilesystem     1K-blocks    Used Available Use% Mounted onudev              966068       0    966068   0% /devtmpfs             203016     740    202276   1% /run/dev/vda2       41174636 5004576  34397372  13% /tmpfs            1015060      24   1015036   1% /dev/shmtmpfs               5120       0      5120   0% /run/locktmpfs            1015060       0   1015060   0% /sys/fs/cgrouptmpfs             203012       0    203012   0% /run/user/1000

-h选项,通过它可以产生可读的格式df命令的输出

ubuntu@VM-24-12-ubuntu:~/20221212$ df -hFilesystem      Size  Used Avail Use% Mounted onudev            944M     0  944M   0% /devtmpfs           199M  740K  198M   1% /run/dev/vda2        40G  4.8G   33G  13% /tmpfs           992M   24K  992M   1% /dev/shmtmpfs           5.0M     0  5.0M   0% /run/locktmpfs           992M     0  992M   0% /sys/fs/cgrouptmpfs           199M     0  199M   0% /run/user/1000

3、du:用于显示目录或文件的大小。

4、mkdir:用于创建目录。

-p 确保目录名称存在,不存在的就建一个

案例1:在工作目录下的 runoob2 目录中,建立一个名为 test 的子目录。
若 runoob2 目录原本不存在,则建立一个。

mkdir -p runoob2/test

5、pwd:用于显示工作目录。

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ pwd/home/ubuntu/20221212/20221215

6、rmdir:删除空的目录

-p 是当子目录被删除后使它也成为空目录的话,则顺便一并删除。

在工作目录下的 BBB 目录中,删除名为 Test 的子目录。若 Test 删除后,BBB 目录成为空目录,则 BBB 亦予删除。

rmdir -p BBB/Test

7、tree:用于以树状图列出目录的内容

ubuntu@VM-24-12-ubuntu:~/20221212$ tree.├── 20221214│   └── data.txt├── a.txt├── break.sh├── case.sh├── for.sh├── func1.sh├── func2.sh├── func.sh├── if.sh├── myfile├── test1.sh├── test2.sh├── time.txt├── users└── while.sh1 directory, 15 files

8、ls:用于显示指定工作目录下之内容(列出目前工作目录所含之文件及子目录)

-a 显示所有文件及目录 (. 开头的隐藏文件也会列出)
-l 除文件名称外,亦将文件型态、权限、拥有者、文件大小等资讯详细列出

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ ls -a.  ..  passwd  read.sh  sort.txt  test1.txtubuntu@VM-24-12-ubuntu:~/20221212/20221215$ ls -altotal 24drwxrwxr-x 2 ubuntu ubuntu 4096 Dec 15 09:43 .drwxrwxr-x 4 ubuntu ubuntu 4096 Dec 15 09:29 ..-rw-rw-r-- 1 ubuntu ubuntu 2807 Dec 15 08:59 passwd-rw-rw-r-- 1 ubuntu ubuntu  167 Dec 15 09:35 read.sh-rw-rw-r-- 1 ubuntu ubuntu   24 Dec 15 09:43 sort.txt-rw-rw-r-- 1 ubuntu ubuntu   66 Dec 15 09:07 test1.txt

四、网络通信

1、ifconfig:用于显示或设置网络设备

2、netstat:用于显示网络状态

3、ping:用于检测主机

执行 ping 指令会使用 ICMP 传输协议,发出要求回应的信息,若远端主机的网络功能没有问题,就会回应该信息,因而得知该主机运作正常。

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ ping www.baidu.comPING www.a.shifen.com (110.242.68.3) 56(84) bytes of data.64 bytes from 110.242.68.3 (110.242.68.3): icmp_seq=1 ttl=251 time=10.3 ms64 bytes from 110.242.68.3 (110.242.68.3): icmp_seq=2 ttl=251 time=10.3 ms64 bytes from 110.242.68.3 (110.242.68.3): icmp_seq=3 ttl=251 time=10.3 ms

五、系统管理

1、useradd、passwd、userdel:用于建立用户帐号,设置密码、用于删除用户帐号

useradd 可用来建立用户帐号。帐号建好之后,
再用 passwd 设定帐号的密码。
而可用 userdel 删除帐号。
使用 useradd 指令所建立的帐号,实际上是保存在 /etc/passwd 文本文件中

案例1:添加user1用户

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sudo useradd user1

案例2:查看所添加用户

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ cat /etc/passwd | grep user1user1:x:1002:1002::/home/user1:/bin/sh

案例3:修改用户密码

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sudo passwd user1New password: Retype new password: passwd: password updated successfully

案例4:删除用户

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ sudo userdel user1

2、date:可以用来显示或设定系统的日期与时间

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ dateThu 15 Dec 2022 09:55:12 AM CST

3、kill:用于删除执行中的程序或工作

彻底杀死进程

kill -9 123456

4、ps:用于显示当前进程的状态,类似于 windows 的任务管理器。

ps -ef | grep 进程关键字

5、top:用于实时显示 process 的动态

6、sudo:以系统管理者的身份执行指令,也就是说,经由 sudo 所执行的指令就好像是 root 亲自执行。

7、su:用于变更为其他使用者的身份,除 root 外,需要键入该使用者的密码。

8、id:用于显示用户的ID,以及所属群组的ID

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ id rootuid=0(root) gid=0(root) groups=0(root)

9、free:用于显示内存状态

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ free              total        used        free      shared  buff/cache   availableMem:        2030124      277180       96608        2332     1656336     1557592Swap:             0           0           0

六、系统设置

1、clear:用于清除屏幕

2、unset:用于删除变量或函数

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ a=24ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ echo $a24ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ unset aubuntu@VM-24-12-ubuntu:~/20221212/20221215$ echo $a

3、export:用于设置或显示环境变量

export -p 列出当前的环境变量值
export MYENV=7 定义环境变量并赋值

七、备份压缩

1、tar:用来建立,还原备份文件的工具程序,它可以加入,解开备份文件内的文件。

案例1:将当前目录下所有的文件和目录进行压缩

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ tar -cvf log.tar ./*./1/./1/log.tar./passwd./read.sh./sort.txt./test1.txt

案例2:解包

ubuntu@VM-24-12-ubuntu:~/20221212/20221215/1$ tar -xvf log.tar ./sort.txt./test1.txt

案例3:将当前目录下以txt结尾的文件,进行压缩成tar.gz类型的文件

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ tar -czvf log.tar.gz ./*.txt./sort.txt./test1.txt

案例4:解压

ubuntu@VM-24-12-ubuntu:~/20221212/20221215$ tar -xzvf log.tar.gz ./sort.txt./test1.txt

在这里插入图片描述

来源地址:https://blog.csdn.net/YZL40514131/article/details/128321806

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Linux常用命令总结(建议收藏)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Linux常用命令总结(建议收藏)

文章目录 一、文件管理1、cat:查看文件内容案例1:输出内容+行数 2、chmod:是控制用户对文件的权限的命令案例1::将user文件修改成用户、组、其他用户都可以读写可执行的权限 3、diff:用于比较文件的差
2023-08-25

建议收藏:好用的 Unix/Linux 命令技巧

1、删除一个大文件 我在生产服务器上有一个很大的200GB的日志文件需要删除。我的rm和ls命令已经崩溃,我担心这是由于巨大的磁盘IO造成的,要删除这个大文件,输入:> /path/to/file.log # 或使用如下格式 :
2022-06-04

linux patch 命令小结(收藏)

说到patch命令,就不得不提到diff命令,也就是制作patch的必要工具。diff命令,在制作patch文件的时候,基本上只需要使用到diff -Nau 这个参数,如果比较的是文件夹,还要加上-r参数,所以一般直接使用Naur参数。 实
2022-06-04

Linux的常用命令总结

这篇文章主要讲解了“Linux的常用命令总结”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux的常用命令总结”吧!1.ls [选项] [目录名 | 列出相关目录下的所有目录和文件-a
2023-06-05

linux日常命令总结

这篇文章主要介绍“linux日常命令总结”,在日常操作中,相信很多人在linux日常命令总结问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”linux日常命令总结”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
2023-06-05

总结Linux 常用命令手册

非常实用的 Linux 命令手册,查看超级方便NO分类PS1命令名用法及参数功能注解1 文件管理# lsls -a列出当前目录下的所有文件,包括以.头的隐含文件文件管理# lsls -l或ll列出当前目录下文件的详细信息文件管理# pwdp
2022-06-03

linux中的常用命令总结

本篇内容主要讲解“linux中的常用命令总结”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“linux中的常用命令总结”吧!man 察看命令详解,只要觉得哪个命令不清楚,man它就可以了. m
2023-06-13

猿创征文|mysql中show的常用命令-Navicat篇【建议收藏】

文章目录 一.mysql show 命令1.查看表信息2.查看表信息3.显示表中列名称4.显示create database 语句是否能够创建指定的数据库5.显示create table 语句是否能够创建指定的表6.显示当前使用或
2023-08-19

Vue3中的pinia使用方法总结(建议收藏版)

Pinia是Vue的存储库,它允许您跨组件/页面共享状态,Pinia的成功可以归功于他管理存储数据的独特功,下面这篇文章主要给大家介绍了关于Vue3中pinia使用方法的相关资料,需要的朋友可以参考下
2023-05-17

Linux下常用的shell命令总结

这篇文章主要介绍“Linux下常用的shell命令总结”,在日常操作中,相信很多人在Linux下常用的shell命令总结问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Linux下常用的shell命令总结”的疑
2023-06-16

Linux下常用cvs命令整总结

这篇文章主要介绍“Linux下常用cvs命令整总结”,在日常操作中,相信很多人在Linux下常用cvs命令整总结问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Linux下常用cvs命令整总结”的疑惑有所帮助!
2023-06-13

Linux 常用命令操作大全(推荐收藏)

1.系统信息命令arch显示机器的处理器架构(1)uname -m显示机器的处理器架构(2)uname -r显示正在使用的内核版本dmidecode -q显示硬件系统部件 - (SMBIOS / DMI)hdparm -i /dev/hda
2022-06-03

docker常用命令总结

本篇内容主要讲解“docker常用命令总结”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“docker常用命令总结”吧!个人简单总结:参数用途语法示例search在docker hub中搜索镜像d
2023-06-03

Git常用命令总结

这篇文章主要讲解了“Git常用命令总结”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Git常用命令总结”吧!前言  这里就不介绍 git 了,表一看到命令行就怕怕,常用的命令也就这些,基本满
2023-06-09

编程热搜

目录