目录
重要的命令:
ac,apt-get,apt-cache bzip2, cat,cd,chgrp,chmod,chown,clear,compress,cp, dd,ddd,df,diff,du,dump, env, find,finger,free, gcc,gdb,grep,gzip, head, kill, less,ln,locate,l,ls, make,man,mkdir,more,mount,mt,mv, netstat,nslookup, od,objdump passwd,patch,ps,pstop,pwd, rm,rmdir shell,sort,ssh,stty, tail,tar,telnet,touch,tree, umask,uname,unzip, vi,vim, whereis,which,who,write
来源:www.nowcoder.com/discuss/151562
本文章总结了 21 条最频繁使用的 Linux 命令,也是面试官考察你对 Linux 系统熟不熟常问的面试题,可以收藏本文章,作为一个 Linux 命令速查手册。
一、文件和目录
1. cd命令
它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径:
-
cd /home 进入 '/ home' 目录
-
cd .. 返回上一级目录
-
cd ../.. 返回上两级目录
-
cd 进入个人的主目录
-
cd ~user1 进入个人的主目录
-
cd - 返回上次所在的目录
2. pwd命令
pwd 显示工作路径
3. ls命令
查看文件与目录的命令,list之意:
-
ls 查看目录中的文件
-
ls -l 显示文件和目录的详细资料
-
ls -a 列出全部文件,包含隐藏文件
-
ls -R 连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来
-
ls [0-9] 显示包含数字的文件名和目录名
4. cp 命令
用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下:
-
-a :将文件的特性一起复制
-
-p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份
-
-i :若目标文件已经存在时,在覆盖时会先询问操作的进行
-
-r :递归持续复制,用于目录的复制行为
-
-u :目标文件与源文件有差异时才会复制
5. mv命令
用于移动文件、目录或更名,move之意:
-
-f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖
-
-i :若目标文件已经存在,就会询问是否覆盖
-
-u :若目标文件已经存在,且比目标文件新,才会更新
6. rm 命令
用于删除文件或目录,remove之意:
-
-f :就是force的意思,忽略不存在的文件,不会出现警告消息
-
-i :互动模式,在删除前会询问用户是否操作
-
-r :递归删除,最常用于目录删除,它是一个非常危险的参数
7. tree命令
本文主要讲解如何查看Linux的目录结构,有时我们需要查看某目录里的结构,使用cd命令一层层查看显然不实际,效率也不高,这是可以使用tree命令,Linux tree命令用于以树状形式列出目标目录及其底下所有子目录和文件。类似于Windows上的资源管理器。
2. 安装tree
以CentOS7.5最小化安装为例,系统并不包括tree命令,需要手动安装。
yum -y install tree
3. 使用tree /var/log/的结构
二、查看文件内容
7. cat命令
用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用:
-
cat file1 从第一个字节开始正向查看文件的内容
-
tac file1 从最后一行开始反向查看一个文件的内容
-
cat -n file1 标示文件的行数
-
more file1 查看一个长文件的内容
-
head -n 2 file1 查看一个文件的前两行
-
tail -n 2 file1 查看一个文件的最后两行
-
tail -n +1000 file1 从1000行开始显示,显示1000行以后的
-
cat filename | head -n 3000 | tail -n +1000 显示1000行到3000行
-
cat filename | tail -n +3000 | head -n 1000 从第3000行开始,显示1000(即显示3000~3999行)
三、文件搜索
8. find命令()
-
find / -name file1 从 '/' 开始进入根文件系统搜索文件和目录
-
find / -user user1 搜索属于用户 'user1' 的文件和目录
-
find /usr/bin -type f -atime +100 搜索在过去100天内未被使用过的执行文件
-
find /usr/bin -type f -mtime -10 搜索在10天内被创建或者修改过的文件
-
whereis halt 显示一个二进制文件、源码或man的位置
-
which halt 显示一个二进制文件或可执行文件的完整路径
删除大于50M的文件:
find /var/mail/ -size +50M -exec rm {} \;
四、文件的权限
使用 "+" 设置权限,使用 "-" 用于取消
9. chmod 命令
-
ls -lh 显示权限
-
chmod ugo+rwx directory1 设置目录的所有人(u)、群组(g)以及其他人(o)以读(r,4 )、写(w,2)和执行(x,1)的权限
-
chmod go-rwx directory1 删除群组(g)与其他人(o)对目录的读写执行权限
10. chown 命令
改变文件的所有者:
-
chown user1 file1 改变一个文件的所有人属性
-
chown -R user1 directory1 改变一个目录的所有人属性并同时改变改目录下所有文件的属性
-
chown user1:group1 file1 改变一个文件的所有人和群组属性
11. chgrp 命令
改变文件所属用户组:
-
chgrp group1 file1 改变文件的群组
五、文本处理
12. grep 命令
分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等:
-
grep Aug /var/log/messages 在文件 '/var/log/messages'中查找关键词"Aug"
-
grep ^Aug /var/log/messages 在文件 '/var/log/messages'中查找以"Aug"开始的词汇
-
grep [0-9] /var/log/messages 选择 '/var/log/messages' 文件中所有包含数字的行
-
grep Aug -R /var/log/* 在目录 '/var/log' 及随后的目录中搜索字符串"Aug"
-
sed 's/stringa1/stringa2/g' example.txt 将example.txt文件中的 "string1" 替换成 "string2"
-
sed '/^$/d' example.txt 从example.txt文件中删除所有空白行(搜索公众号Java知音,回复“2021”,送你一份Java面试题宝典)
13. paste 命令
-
paste file1 file2 合并两个文件或两栏的内容
-
paste -d '+' file1 file2 合并两个文件或两栏的内容,中间用"+"区分
14. sort 命令
-
sort file1 file2 排序两个文件的内容
-
sort file1 file2 | uniq 取出两个文件的并集(重复的行只保留一份)
-
sort file1 file2 | uniq -u 删除交集,留下其他的行
-
sort file1 file2 | uniq -d 取出两个文件的交集(只留下同时存在于两个文件中的文件)
15. comm 命令
-
comm -1 file1 file2 比较两个文件的内容只删除 'file1' 所包含的内容
-
comm -2 file1 file2 比较两个文件的内容只删除 'file2' 所包含的内容
-
comm -3 file1 file2 比较两个文件的内容只删除两个文件共有的部分
六、打包和压缩文件
16. tar 命令
对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压:
-
-c :新建打包文件
-
-t :查看打包文件的内容含有哪些文件名
-
-x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中
-
-j :通过bzip2的支持进行压缩/解压缩
-
-z :通过gzip的支持进行压缩/解压缩
-
-v :在压缩/解压缩过程中,将正在处理的文件名显示出来
-
-f filename :filename为要处理的文件
-
-C dir :指定压缩/解压缩的目录dir
-
压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称
-
查询:tar -jtv -f filename.tar.bz2
-
解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录
-
bunzip2 file1.bz2 解压一个叫做 'file1.bz2'的文件
-
bzip2 file1 压缩一个叫做 'file1' 的文件
-
gunzip file1.gz 解压一个叫做 'file1.gz'的文件
-
gzip file1 压缩一个叫做 'file1'的文件
-
gzip -9 file1 最大程度压缩
-
rar a file1.rar test_file 创建一个叫做 'file1.rar' 的包
-
rar a file1.rar file1 file2 dir1 同时压缩 'file1', 'file2' 以及目录 'dir1'
-
rar x file1.rar 解压rar包
-
zip file1.zip file1 创建一个zip格式的压缩包
-
unzip file1.zip 解压一个zip格式压缩包
-
zip -r file1.zip file1 file2 dir1 将几个文件和目录同时压缩成一个zip格式的压缩包
七、系统和关机 (系统的关机、重启以及登出 )
-
shutdown -h now 关闭系统(1)
-
init 0 关闭系统(2)
-
telinit 0 关闭系统(3)
-
shutdown -h hours:minutes & 按预定时间关闭系统
-
shutdown -c 取消按预定时间关闭系统
-
shutdown -r now 重启(1)
-
reboot 重启(2)
-
logout 注销
-
time 测算一个命令(即程序)的执行时间
八、进程相关的命令
17 jps命令
显示当前系统的java进程情况,及其id号:
-
jps(Java Virtual Machine Process Status Tool)是JDK 1.5提供的一个显示当前所有java进程pid的命令,简单实用,非常适合在linux/unix平台上简单察看当前java进程的一些简单情况。
18 ps命令
用于将某个时间点的进程运行情况选取下来并输出,process之意:
-
-A :所有的进程均显示出来
-
-a :不与terminal有关的所有进程
-
-u :有效用户的相关进程
-
-x :一般与a参数一起使用,可列出较完整的信息
-
-l :较长,较详细地将PID的信息列出
-
ps aux # 查看系统所有的进程数据
-
ps ax # 查看不与terminal有关的所有进程
-
ps -lA # 查看系统所有的进程数据
-
ps axjf # 查看连同一部分进程树状态
19 kill命令
用于向某个工作(%jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用:
20 killall命令
(向一个命令启动的进程发送一个信号)
21 top命令
是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。
如何杀死进程:
-
图形化界面的方式
-
kill -9 pid (-9表示强制关闭)
-
killall -9 程序的名字
-
pkill 程序的名字
查看进程端口号:
netstat -tunlp|grep 端口号
九、网络相关
1.netstat查询端口号
netstat -anp命令简单说明:
-a,显示所有
-n,不用别名显示,只用数字显示
-p,显示进程号和进程名
1.netstat -anp |grep 端口号
如下,我以3306为例,netstat -anp |grep 3306(此处备注下,我是以普通用户操作,故加上了sudo,如果是以root用户操作,不用加sudo即可查看),如下图1:
图1
图1中主要看监控状态为LISTEN表示已经被占用,最后一列显示被服务mysqld占用,查看具体端口号,只要有如图这一行就表示被占用了。
2.netstat -nultp(此处不用加端口号)
该命令是查看当前所有已经使用的端口情况,如图2:
图2
图中可以看出我的82端口没有被占用
3.netstat -anp |grep 82查看82端口的使用情况,如图3:
图3
可以看出并没有LISTEN那一行,所以就表示没有被占用。此处注意,图中显示的LISTENING并不表示端口被占用,不要和LISTEN混淆哦,查看具体端口时候,必须要看到tcp,端口号,LISTEN那一行,才表示端口被占用了
2.ss查询
ss -l 显示本地打开的所有端口
ss -pl 显示每个进程具体打开的socket
ss -t -a 显示所有tcp socket
ss -u -a 显示所有的UDP Socekt
ss -o state established '( dport = :smtp or sport = :smtp )' 显示所有已建立的SMTP连接
ss -o state established '( dport = :http or sport = :http )' 显示所有已建立的HTTP连接
ss -x src /tmp/.X11-unix/* 找出所有连接X服务器的进程
ss -s 列出当前socket详细信息:
3.lsof -i
linux lsof命令详解 - ggjucheng - 博客园
lsof `which httpd` //那个进程在使用apache的可执行文件 lsof /etc/passwd //那个进程在占用/etc/passwd lsof /dev/hda6 //那个进程在占用hda6 lsof /dev/cdrom //那个进程在占用光驱 lsof -c sendmail //查看sendmail进程的文件使用情况 lsof -c courier -u ^zahn //显示出那些文件被以courier打头的进程打开,但是并不属于用户zahn lsof -p 30297 //显示那些文件被pid为30297的进程打开 lsof -D /tmp 显示所有在/tmp文件夹中打开的instance和文件的进程。但是symbol文件并不在列 lsof -u1000 //查看uid是100的用户的进程的文件使用情况 lsof -utony //查看用户tony的进程的文件使用情况 lsof -u^tony //查看不是用户tony的进程的文件使用情况(^是取反的意思) lsof -i //显示所有打开的端口 lsof -i:80 //显示所有打开80端口的进程 lsof -i -U //显示所有打开的端口和UNIX domain文件 lsof -i UDP@[url]www.akadia.com:123 //显示那些进程打开了到www.akadia.com的UDP的123(ntp)端口的链接 lsof -i tcp@ohaha.ks.edu.tw:ftp -r //不断查看目前ftp连接的情况(-r,lsof会永远不断的执行,直到收到中断信号,+r,lsof会一直执行,直到没有档案被显示,缺省是15s刷新) lsof -i tcp@ohaha.ks.edu.tw:ftp -n //lsof -n 不将IP转换为hostname,缺省是不加上-n参数