面试官常考的 21 条 Linux 命令
阅读本文大概需要 6 分钟。
来自:www.nowcoder.com/discuss/151562
一、文件和目录
1. cd命令
- cd /home 进入 '/ home' 目录 
- cd .. 返回上一级目录 
- cd ../.. 返回上两级目录 
- cd 进入个人的主目录 
- cd ~user1 进入个人的主目录 
- cd - 返回上次所在的目录 
2. pwd命令
3. ls命令
- ls 查看目录中的文件 
- ls -l 显示文件和目录的详细资料 
- ls -a 列出全部文件,包含隐藏文件 
- ls -R 连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来 
- ls [0-9] 显示包含数字的文件名和目录名 
4. cp 命令
- -a :将文件的特性一起复制 
- -p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份 
- -i :若目标文件已经存在时,在覆盖时会先询问操作的进行 
- -r :递归持续复制,用于目录的复制行为 
- -u :目标文件与源文件有差异时才会复制 
5. mv命令
- -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖 
- -i :若目标文件已经存在,就会询问是否覆盖 
- -u :若目标文件已经存在,且比目标文件新,才会更新 
6. rm 命令
- -f :就是force的意思,忽略不存在的文件,不会出现警告消息 
- -i :互动模式,在删除前会询问用户是否操作 
- -r :递归删除,最常用于目录删除,它是一个非常危险的参数 
二、查看文件内容
7. cat命令
- 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显示一个二进制文件或可执行文件的完整路径
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文件中删除所有空白行
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 命令
- -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命令
- jps(Java Virtual Machine Process Status Tool)是JDK 1.5提供的一个显示当前所有java进程pid的命令,简单实用,非常适合在linux/unix平台上简单察看当前java进程的一些简单情况。 
18 ps命令
- -A :所有的进程均显示出来 
- -a :不与terminal有关的所有进程 
- -u :有效用户的相关进程 
- -x :一般与a参数一起使用,可列出较完整的信息 
- -l :较长,较详细地将PID的信息列出 
ps aux # 查看系统所有的进程数据
ps ax # 查看不与terminal有关的所有进程
ps -lA # 查看系统所有的进程数据
ps axjf # 查看连同一部分进程树状态
19 kill命令
20 killall命令
21 top命令
- 图形化界面的方式 
- kill -9 pid (-9表示强制关闭) 
- killall -9 程序的名字 
- pkill 程序的名字 
netstat -tunlp|grep 端口号
抽两个干饭红包,每个25元,点击小卡片,回复“抽奖”即可参与,周二晚上20点开奖。
推荐阅读:
内容包含Java基础、JavaWeb、MySQL性能优化、JVM、锁、百万并发、消息队列、高性能缓存、反射、Spring全家桶原理、微服务、Zookeeper、数据结构、限流熔断降级......等技术栈!
⬇戳阅读原文领取!                                       朕已阅 
评论

