跳到内容

工作中总结的30个常用Linux指令,实在记不住就别硬记了,看这篇就够了

更新时间
快连VPN:速度和安全性最佳的VPN服务
快连VPN:速度和安全性最佳的VPN服务

写在开头

最近发现自己记忆力严重下滑,很多sql命令,linux命令都记不住,特别是linux命令,很多命令参数很多,一段时间不用,再去使用就需要从网上重查了,很烦人,为此花了一些时间把之前笔记中的Linux命令给整理了一下,汇总出30个常用的分享出来,下次再想不起来直接看这篇文章就行了。

1、Linux指令-ls

ls 是 list 命令的缩写,它在 Linux 系统中起着关键作用。通过 ls 命令,用户可以查看文件夹中的文件列表,并且可以获取关于文件权限、目录信息等详细信息。 ls 命令的强大之处在于它不仅提供了文件名的清单,还可以显示文件的权限、所有者、大小等重要属性。因此,ls 命令是 Linux 用户在浏览文件系统时的重要工具之一。通过简单的 ls 命令,用户可以快速了解文件系统

ls -a 列出目录下所有文件,包含以.开始的隐藏文件ls -A 列出除.及..的其他文件ls -r 文件以反序排列ls -t 文件以修改时间排序ls -S 文件以大小排序ls -h 以易读大小显示ls -l 除了文件名外,还将文件的权限、所有者、文件大小等详细信息显示出来ls -lhrt 按照易读方式按时间反序排序,并显示文件详细信息ls -lrS 按大小反序显示文件详细信息ls -l t* 列出当前目录中所有以“t”开头的目录的详细内容
登录后复制

2、Linux指令-cd

切换目录,是changedirectory的缩写

cd / 进入指定的目录cd ~ 进入home目录cd - 进入上一次工作路径cd .. 切换到上一级目录
登录后复制

3、Linux指令-pwd

该命令用于查看当前工作目录的路径, print work directory的缩写

pwd 查看当前目录路径pwd -P 查看软连接的实际路径
登录后复制

4、Linux指令-mkdir

该指令用于创建目录,是make directory的缩写

mkdir t 当前工作目录下创建名为t的文件夹mkdir -m 对新建的目录设置权限,当然也可以用chmod命令赋权mkdir -p 若路径中的某些目录尚不存在,系统会自动创建mkdir -p /tmp/test/t 在tmp目录下创建路径为test的目录,在test目录下创建t目录
登录后复制

5、Linux指令-rm

rm是remove的缩写,指删除一个目录中的一个或多个文件或目录。如果没有使用 -r 选项,则 rm 不会删除目录。如果使用 rm 来删除文件,通常仍可以将该文件恢复原状。

命令语法:rm [选项] 文件..rm -f 强制删除,忽略不存在的文件,不给出提示rm -i 交互式删除,删除前给提示rm -r 递归删除目录下文件,以及子目录下的文件rm -i *.log 删除任何.log文件,删除前逐一询问确认rm -rf test 强制删除test目录或文件,无需确认
登录后复制

6、Linux指令-rmdir

rmdir是remove directory的缩写,指删除空目录

rmdir -v 删除时有提示rmdir -p 如果一个目录和子目录皆为空,则在删除子目录时,父目录一并删除rmdir -p a/b/c 等同于rmdir a/b/c a/b a
登录后复制

7、Linux指令-mv

mv是move的缩写,指移动文件、目录,移动时可修改文件或目录名

命令语法:mv [选项] 源文件或目录 目标文件或目录mv test.txt test2.txt 将文件test.txt重命名为test2.txtmv log.txt log2.txt /log 将log.txt、log2.txt文件移动到/log目录中mv -i log.txt log2.txt 将文件log.txt更名为log2.txt,如果log2.txt已经存在,则询问是否覆盖。mv -f log.txt log2.txt 将文件log.txt更名为log2.txt,如果log2.txt已经存在,直接覆盖。mv * ../ 移动当前文件夹下的所有文件到上一级目录
登录后复制

8、Linux指令-cp

复制,将多文件或目录复制至目标目录(shell 脚本中不加 -i 参数会直接覆盖不会提示)

常用指令:-i 提示-r 复制目录以及目录内所有的文件-a 复制的文件与原文件时间一样cp -ai a.txt test 复制a.txt文件到test目录下,保持原文件时间,如果test目录中已经存在a.txt文件,提示是否覆盖。cp -s a.txt a_link.txt 为a.txt文件创建一个链接
登录后复制

9、Linux指令-cat

文本输出命令

cat filename 一次显示整个文件cat > filename 从键盘创建一个文件cat file1 file2 > file 将几个文件合并为一个文件-b 对非空输出行号-n 输出所有行号cat -n log1.log log2.log 把log1.log的文件内容加上行号后输入到log2.log文件里cat -b log1.log log2.log log.log 把log1.log和log2.log的文件内容加上行号(空白行不加)附加到log.log里。
登录后复制

10、Linux指令-more

阅读命令,与 cat 类似, more 会以一页一页的显示方便逐页阅读,按空格键(space)就往下一页显示,按 b 键就会往回(back)一页显示。

命令参数:+n 从第n行开始显示-n 定义屏幕大小为n行+/pattern 在每个档案显示前搜寻该(pattern)字符串,然后从该字串前两行之后开始显示-c 从顶部清屏,然后显示-s 把连续的多个空行显示为一行-u 把文件中的下划线去掉常用的操作命令:Enter 向下n行,需要定义。默认为1行Ctrl+F 向下滚动一屏空格键 向下滚动一屏Ctrl+B 返回上一屏= 输出当前行的行号:f 输出文件名和当前行的行号!命令 调用shell,并执行命令q 退出moremore +3 text.txt 显示文件中从第三行起的内容ls -l | more -5 以每次显示5行数据的量,列出当前目录下的所有文件详细信息
登录后复制

11、Linux指令-less

浏览文件命令,less 可以随意浏览文件,less 在查看之前不会加载整个文件

常用参数:-i 忽略搜索时的大小写-N 显示每行行号-o将less输出的内容在指定的文件中保存起来-s 显示连续空行为一行/字符串 向下搜索“字符串”的功能?字符串 向上搜索“字符串”的功能-x将tab键显示为规定的数字空格空格键 滚动一行回车键 滚动一页[pagedown] 向下发动一页[pageup] 向上翻动一页ps -aux | less -Nps查看进程信息并通过less分页显示,显示行号less a.log b.log 查看多个文件,可以使用n查看下一个,使用怕p查看前一个
登录后复制

12、Linux指令-tail

用于显示指定文件末尾内容,不指定文件时,作为输入信息进行处理,常用来查看日志文件

常用参数:-f 循环读取(常用于查看程序执行后递增的日志文件)-n 显示行数(从后向前)tail -n 100 显示后100行日志文件tail -f log.log 循环读取日志文件逐渐增加的内容tail -200f log.log 循环读取日志文件后200行的内容
登录后复制

13、Linux指令-head

显示开头或结尾命令 head 用来显示档案的开头至标准输出中,默认 head 命令打印文件的开头 10 行

常用参数:-n显示的行数(行数为复数表示从后向前数)head a.log -n 20 显示a.log文件中前20行数据head -c 20 a.log 显示a.log文件前20字节head -n -10 a.log 显示a.log最后10行数据
登录后复制

14、Linux指令-which

这个指令平时用的比较少,主要功能是PATH 中搜索某个系统命令的位置,并返回第一个搜索结果 which 命令,可以看到某个系统命令是否存在,执行命令的位置。

which ls查看 ls 命令的执行文件位置
登录后复制

15、Linux指令-locate

搜索文档数据库命令 locate 通过搜寻系统内建文档数据库达到快速找到档案,数据库由 updatedb 程序来更新,updatedb 由 cron daemon 周期性调用 locate 命令在搜寻较快,但最近才建立或刚更名的,可能会找不到 locate 与 find 命令相似,可以使用正则匹配查找

常用参数:-l num 要显示的行数-f 将特定的档案系统排除在外-r 使用正则运算符作为寻找条件locate pwd 查找文件名中包换pwd的所有文件locate /etc/sh 搜索etc目录下的所有以sh开头的文件locate -r '^/var.*txt$' 查找/var目录下,以txt结尾的文件
登录后复制

16、Linux指令-find

查找文件树命令,用于在文件树中查找文件,并作出相应的处理。

命令格式:find pathname -options [-print -exex -ok ...]命令参数:pathname:查找的目录路径 ~表示home目录 .表示当前目录 /表示根目录-print:匹配的文件输出到标准输出-exec:对匹配的文件执行该参数所给出的shell命令-ok:和-exec作用相同,不过是以一种更安全的模式来执行该参数所给出的shell命令,在执行每一个命令前,都会给出提示,让用户来确定是都执行。-options:表示查找方式,如下是其具体选项-name 按照文件名查找文件-perm 按照文件权限查找文件-user 按照文件属主查找文件-group 按照文件所属的组来查找文件-type 查找某一类型的文件b 块设备文件d 目录c 字符设备文件l 符号链接文件p 管道文件f 普通文件-size n :[c] 查找文件长度为n块文件,带有c时表示文件字节大小-amin n 查找系统中最后n分钟访问的文件-atime n 查找系统中最后n*24小时访问的文件-cmin n 查找系统中最后n分钟被改变文件状态的文件-ctime n 查找系统中最后n*24小时被改变文件状态的文件-mmin n 查找系统中最后n分钟被改变文件数据的文件-mtime n 查找系统中最后n*24小时被改变文件数据的文件-maxdepth n 最大查找目录深度-prune 选项来指出需要忽略的目录-newer 查找更改时间比某个文件新,但比另外一个文件旧的所有文件find . -name '[A-Z]*.txt' -print 在当前目录及子目录中,查找大写字母开头的txt文件 find . -mtime -2 -type f -print查找两天内被更该过的文件find . -name 'del.txt' -ok rm {} ; 查找名为del.txt的文件并删除,删除前提示确认find logs -type f -mtime +5 -exec -ok rm {} ;在 /logs目录中查找更改时间在5日以前的文件并删除它们
登录后复制

17、Linux指令-chmod

用于改变 linux 系统文件或目录的访问权限 该命令有两种用法:一种是包含字母和操作符表达式的文字设定法;另一种是包含数字的数字设定法 每一文件或目录的访问权限都有三组,每组用三位代号表示:

文件属主的读、写和执行权限与属主同组的用户的读、写和执行权限系统中其他用户的读、写和执行权限
登录后复制
常用参数:-c 当发生改变时,报告处理信息-R 处理指定目录以及其子目录下的所有文件权限范围:u:目录或者文件的当前的用户g:目录或者文件的当前的群组o:除了目录或者文件的当前用户或者群组之外的用户a:所有的用户及群组权限代号:r :读权限,用数字4表示w :写权限,用数字2表示x :执行权限,用数字1表示- :删除权限,用数字0表示s :特殊权限chmod -R 755 目录名称
登录后复制

18、Linux指令-tar

压缩和解压文件 tar 本身不具有压缩功能,只具有打包功能,有关压缩及解压是调用其它的功能来完成

命令参数:-c 建立新的压缩文件-f 指定压缩文件-r 添加文件到已经压缩文件包中-u 添加改了和现有的文件到压缩包中-x 从压缩包中抽取文件-t 显示压缩文件中的内容-z 支持gzip压缩-j 支持bzip2压缩-Z 支持compress解压文件-v 显示操作过程示列:tar -cvf log.tar 1.log,2.log 将1.log和2.log文件全部打成tar包tar -zcvf /temp/log.tar.gz /log 将/log下所有文件及目录打包到指定的目录,并使用gz压缩tar -ztvf /temp/log.tar.gz 查看刚打包的文件内容tar -zxvf log.tar.gz 解压这个log.tar.gz文件tar --exclude /log/mylog/ -zcvf /tmp/loglog.tar.gz /log 压缩打包/log,排除/log/mylog
登录后复制

19、Linux指令-chown

将指定文件的拥有者改为指定的用户或组,操作权限为root用户

用户可以是用户名或者用户 ID组可以是组名或者组 ID文件是以空格分开的要改变权限的文件列表,支持通配符
登录后复制
常用参数:-c 显示更改部分的信息-R 处理指定的目录及子目录chown -c log:log a.txt 改变文件a.txt的拥有者和群组都为log,并显示改变信息chown -c :log a.txt 改变文件a.txt的群组为log,并显示改变信息chown -c log a.txt改变文件a.txt的拥有者为log,并显示改变信息chown -cR log: log/ 改变文件夹log及子文件、目录属主为log
登录后复制

20、Linux指令-df

显示磁盘空间使用情况

获取硬盘被占用空间,剩余空间等信息。默认所有当前被挂载的文件系统的可用空间都会显示默认情况下,磁盘空间以 1KB 为单位进行显示
登录后复制
常用参数:-a 全部文件系统列表-h 以方便阅读的方式显示信息-i 显示inode信息-k 区块为1024字节-l 只显示本地磁盘-T 列出文件系统类型
登录后复制

21、Linux指令-du

是查看目录使用空间情况,与 df 命令不同的是 du 命令是对文件和目录磁盘使用的空间的查看

命令格式:du [选项] [文件]常用参数:-a 显示目录中所有文件大小-k 以kb为单位显示文件大小-m 以MB为单位显示文件大小-g 以GB为单位显示文件大小-h 以易读方式显示文件大小-s 仅显示总计-c 或 --total 除了显示个别目录或文件大小,同时也显示所有的目录或文件的大小总和du -ah --max-depth=1显示各个文件夹大小
登录后复制

22、Linux指令-ln

为文件在另外一个位置建立一个同步的链接

链接分为:

1、软链接

软链接,以路径的形式存在。类似于 Windows 操作系统中的快捷方式软链接可以跨文件系统 ,硬链接不可以软链接可以对一个不存在的文件名进行链接软链接可以对目录进行链接
登录后复制

2、硬链接

硬链接,以文件副本的形式存在。但不占用实际空间。不允许给目录创建硬链接硬链接只有在同一个文件系统中才能创建
登录后复制

需要注意:

ln 命令会保持每一处链接文件的同步性,也就是说,不论你改动了哪一处,其它的文件都会发生相同的变化ln 的链接又分软链接和硬链接两种,软链接就是ln –s 源文件 目标文件,它只会在你选定的位置上生成一个文件的镜像,不会占用磁盘空间;硬链接 ln 源文件 目标文件,没有参数 -s, 在指定的位置上生成一个和源文件大小相同的文件,无论是软链接还是硬链接,文件都保持同步变化ln 指令用在链接文件或目录,如同时指定两个以上的文件或目录,且目标目录已经,则会把前面指定的所有文件或目录复制到该目录中。若同时指定多个文件或目录,且目标目录不存在,则会出现错误信息
登录后复制
常用参数:-b 删除,覆盖之前建立的链接-s 软连接-v 显示详细处理过程ln -s /usr/local/mysql/bin/mysql /usr/bin 建立一个软链接
登录后复制

23、Linux指令-date

显示或设定系统的日期与时间

命令参数:-d显示字符串所指的日期与时间,字符串前后必须加上双引号-s根据字符串来设置日期与时间,字符串前后必须加上双引号-u显示GMT%H 小时(00-23)%I 小时(00-12)%M 分钟(以00-59来表示)%s 总秒数起算时间为1970-01-01 00:00:00 UTC%S 秒(以本地的惯用法来表示)%a 星期的缩写%A 星期的完整名称%d 日期(以01-31来表示)%D 日期(含年月日)%m 月份(以01-12来表示)%y 年份(以00-99来表示)%Y 年份(以四位数来表示)实例:date +回车 查看系统当前时间date -s "2018-05-24 16:36:00" 修改当天系统时间为所设置时间date +%Y%m%d --date="+1 day"//显示下一天的日期date -d "nov 22" 显示今年的 11 月 22 日date -d "2 weeks"显示2周后的日期date -d "next monday"显示下周一的日期date -d next-day +%Y%m%d 或 date -d tomorrow +%Y%m%d显示明天的日期date -d last-day +%Y%m%d 或 date -d yesterday +%Y%m%d显示昨天的日期date -d last-month +%Y%m显示上个月的月份date -d next-month +%Y%m显示下个月的月份
登录后复制

24、Linux指令-cal

显示公历日历 指令后只有一个参数,表示年份,1-9999 指令后有两个参数,表示月份和年份

常用参数:-3 显示前一个月,当前月,后一个月三个月的日历-m 显示星期一为第一列-j 显示当前年第几天-y [year]显示[year]年份的日历cal 11 2021 显示2021年11月的日历
登录后复制

25、Linux指令-grep

文本搜索命令,grep 是 Global Regular Expression Print 的缩写,全局正则表达式搜索 grep 在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须使用引号,模板后的所有字符串被看作文件名,搜索的结果被送到标准输出,不影响原文件内容。

命令格式:grep [option] pattern file|dir常用参数:-A n --after-context显示匹配字符后n行-B n --before-context显示匹配字符前n行-C n --context 显示匹配字符前后n行-c --count 计算符合样式的列数-i 忽略大小写-l 只列出文件内容符合指定的样式的文件名称-f 从文件中读取关键词-n 显示匹配内容的所在文件中行数-R 递归查找文件夹grep 的规则表达式:^锚定行的开始 如:'^log'匹配所有以 log 开头的行。 $锚定行的结束 如:'log$'匹配所有以 log 结尾的行。 .匹配一个非换行符的字符,'l.g' 匹配 l+非换行字符+g,如:log*匹配零个或多个先前字符 如:'*log' 匹配所有一个或多个空格后紧跟 log 的行.* 一起用代表任意字符[] 匹配一个指定范围内的字符,如:'[Ll]og' 匹配 Log 和 log [^]匹配一个不在指定范围内的字符,如:'[^A-FH-Z]og' 匹配不包含 A-F 和 H-Z 的一个字母开头,紧跟 log 的行(..) 标记匹配字符,如:'(log)',log 被标记为 1<h2><span class="ez-toc-section" id="2625E325802581Linux25E6258C258725E425BB25A4-wc"></span>26、Linux指令-wc<span class="ez-toc-section-end"></span></h2><p>wc(word count),统计指定的文件中字节数、字数、行数,并将统计结果输出</p><pre class="brush:php;toolbar:false;">命令参数:-c 统计字节数-l 统计行数-m 统计字符数-w 统计词数,一个字被定义为由空白、跳格或换行字符分隔的字符串
登录后复制

27、Linux指令-ps

ps(process status),用来查看当前运行的进程状态,一次性查看,如果需要动态连续结果使用 top 指令

linux 系统中进程有5种状态:

运行(正在运行或在运行队列中等待)中断(休眠中, 受阻, 在等待某个条件的形成或接受到信号)不可中断(收到信号不唤醒和不可运行, 进程必须等待直到有中断发生)僵死(进程已终止, 但进程描述符存在, 直到父进程调用 wait4() 系统调用后释放)停止(进程收到 SIGSTOP, SIGSTP, SIGTIN, SIGTOU 信号后停止运行)
登录后复制

ps 工具标识进程的5种状态码:

R 运行 runnableS 中断 sleepingD 不可中断 uninterruptible sleepZ 僵死 a defunct processT 停止 traced or stopped
登录后复制
常用参数:-A 显示所有进程-a 显示同一终端下所有进程-f: full 展示进程详细信息-e: every 展示所有进程信息-ax: all 与 -e 同,展示所有进程信息-o: 设置输出格式, 可以指定需要输出的进程信息列-L: 展示线程信息-C: 获取指定命令名的进程信息-t: tty 展示关联指定 tty 的进程--forest: 展示进程数--sort: 按照某个或者某些进程信息列排序展示a 显示所有进程c 显示进程真实名称e 显示环境变量f 显示进程间的关系r 显示当前终端运行的进程-aux 显示所有包含其它使用的进程-ef显示所有当前进程信息ps -C bash显示指定名称的进程信息ps -eLf显示当前系统中的线程信息ps -ef --forest显示进程树
登录后复制

28、Linux指令-top

显示当前系统正在执行的进程的 ID、内存占用率、CPU 占用率等相关信息

常用参数:-c 显示完整的进程命令-s 保密模式-p指定进程显示-n循环显示次数实例:top - 00:05:02 up 204 days,9:56,2 users,load average: 0.00, 0.01, 0.05Tasks:68 total, 1 running,67 sleeping, 0 stopped, 0 zombie%Cpu(s):0.7 us,0.7 sy,0.0 ni, 98.3 id,0.3 wa,0.0 hi,0.0 si,0.0 stKiB Mem :1016168 total,65948 free, 335736 used, 614484 buff/cacheKiB Swap:0 total,0 free,0 used. 517700 avail Mem PID USERPRNIVIRTRESSHR S %CPU %MEM TIME+ COMMAND  7110 root10 -10130476 9416 6116 S1.30.9 141:26.59 AliYunDun 15845 root20 0 47064 4320 2180 S0.30.4 2:51.16 nginx 前五行是当前系统情况整体的统计信息区第一行,任务队列信息,同 uptime 命令的执行结果:00:05:02 — 当前系统时间up 204 days,9:56 — 系统已经连续运行了 204 天 9 小时 56 分钟未重启2 users — 当前有 2 个用户登录系统load average: 0.00, 0.01, 0.05 — load average 后面的三个数分别是 0 分钟、1 分钟、5分钟的负载情况,load average 数据是每隔 5 秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了第二行,Tasks — 任务(进程):系统现在共有 68 个进程,其中处于运行中的有 1 个,休眠中 67 个,停止 0 个,僵死 0个第三行,cpu状态信息:0.7 us — 用户空间占用 CPU 的百分比0.7 sy — 内核空间占用 CPU 的百分比0.0 ni — 改变过优先级的进程占用 CPU 的百分比98.3 id — 空闲CPU百分比0.3 wa — IO 等待占用 CPU 的百分比0.0 hi — 硬中断(Hardware IRQ)占用 CPU 的百分比0.0 si — 软中断(Software Interrupts)占用 CPU 的百分比0.0 st - 虚拟机占用百分比第四行,内存状态:1016168 total — 物理内存总量65948 free — 空闲内存总量335736 used — 使用中的内存总量614484 buff/cache — 缓存的内存量第五行,swap交换分区信息,具体信息说明如下:0 total — 交换区总量0 free — 空闲交换区总量0 used — 使用的交换区总量517700 avail Mem - 可用内存第七行以下:各进程(任务)的状态监控,项目列信息说明如下:PID — 进程idUSER — 进程所有者PR — 进程优先级NI — nice值。负值表示高优先级,正值表示低优先级VIRT — 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RESRES — 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATASHR — 共享内存大小,单位kbS — 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程%CPU — 上次更新到现在的CPU时间占用百分比%MEM — 进程使用的物理内存百分比TIME+ — 进程使用的CPU时间总计,单位1/100秒COMMAND — 进程名称(命令名/命令行)top 交互命令h 显示top交互命令帮助信息c 切换显示命令名称和完整命令行m 以内存使用率排序P 根据CPU使用百分比大小进行排序T 根据时间/累计时间进行排序W 将当前设置写入~/.toprc文件中o或者O 改变显示项目的顺序
登录后复制

29、Linux指令-kill

删除执行中的程序或者工作,发送指定的信号到相应的进程,如果不指定信号的话,将发送sigterm(15)终止指定进程,用‘-KILL’参数,发送信号SIGKILL(9)强制结束进程

常用参数:-l 信号,若不加信号的编号参数,会全部列出信号的名称。-a 当处理当前进程时,不限制命令名和进程号的对应关系-p 指定kill命令只打印相关进程的进程号,而不发送任何信号-s 指定发送信号-u 指定用户示例:kill -l 显示信号kill -KILL 8878 强制杀死进程 8878kill -9 8878 彻底杀死进程8878kill -u tomcat 杀死tomcat用户的进程
登录后复制

30、Linux指令-free

显示系统内存使用情况,包括物理内存、swap内存和内核cache内存

命令参数:-b 以Byte显示内存使用情况-k 以kb为单位显示内存使用情况-m 以mb为单位显示内存使用情况-g 以gb 为单位显示内存使用情况-s持续显示内存-t 显示内存使用总合
登录后复制

总结

以上就是工作中总结的30个常用Linux指令,实在记不住就别硬记了,看这篇就够了的详细内容,更多请关注本站其它相关文章!

更新时间

发表评论

请注意,评论必须在发布之前获得批准。