[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. 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' 的文件和目录
whereis halt               显示一个二进制文件、源码或man的位置
which halt                 显示一个二进制文件或可执行文件的完整路径
find  . -type f  "*.js"    查找本目录下.js结尾的文件
find /home -type f -name document.pdf      在/home目录中搜索名为document.pdf的文件
find /var/log/nginx -type f -name '*.log.gz'     查找 /var/log/nginx目录下以.log.gz结尾的所有文件
find / -user myfreax    搜索myfreax用户拥有的所有文件和目录
find /usr/bin -type f -atime +100     搜索在过去100天内未被使用过的执行文件
find /usr/bin -type f -mtime -10      搜索在10天内被创建或者修改过的文件
find /etc/dovecot/conf.d -name "*.conf" -mtime 5    查找/etc/dovecot/conf.d/目录下过去5天内修改过以.conf为后缀的文件
find /var/mail/ -size +50M -exec rm {};     删除大于50M的文件

四、文件的权限

使用 “+” 设置权限,使用 “-” 用于取消

9. chmod 命令

ls -lh 显示权限

chmod ugo+rwx /directory1    给予directory1目录UGO三种身份均赋予读(r,4 )、写(w,2)和执行(x,1)的权限
chmod -R 756 /directory1     给予directory1目录下所有文件均赋予读写执行权限
chmod go-rwx directory1      删除群组(g)与其他人(o)对目录的读写执行权限

10. chown 命令

(改变文件的所有者)

chown user1 file1          改变一个文件的所有人属性
chown -R user1 directory1  改变一个目录的所有人属性并同时改变改目录下所有文件的属性
chown user1:group1 file1   改变一个文件的所有人和群组属性

11. chgrp 命令

(改变文件所属用户组)

chgrp group1 file1 改变文件的群组
chgrp -R group1 file1 改变目录里所有文件的群组

12、文件属性权限详解

场景1:

[root@test]# ls -l
total 4848
-rwxrw-r-- 1 test test1     194 Jun 15  2021 check_crc.v
-rw-rw-r-- 1 test test1    3713 Jun 13  2021 cshrc.v
drwxr-xr-x 4 test test1   4096 Sep 29  2021 dc_test_run
drwx------ 2 test test1    4096 Jun  1  2021 Desktop
drwxr-xr-x 4 test test1    4096 Jun  3  2021 ftc_pcs_fpga
drwxr-xr-x 3 test test1    4096 May 27  2021 ftc_sata_fpga

第一行属性解读:

【-rwxrw-r–】代表文件类型和权限;
【1】表示i-node连接数 ;
【test】表示所有者 ;
【test1】表示所属用户组 ;
【194】表示文件大小;
【Jun 15 2021】表示文件创建日期 ;
【check_crc.v】表示文件名;

【-】的位置代表此文件的类型(常用类型):

【-】代表是一般文件;
【d】代表是目录;
【l】代表链接文件;

【rwx】代表文件所有者权限:

三个位置分别表示该身份对文件权限:
【r】代表是否可读
【w】代表是否可写
【x】代表是否可执行

出现rwx相应的字母就表示有相应的权限,出现【-】则表示该用户对该文件没有相应操作的权限。

场景2:

[root@test]# ls -l
total 4848
-rw-rw-r-- 1 test test1    3713 Jun 13  2021 cshrc.v

【rw-】表示该文件所属用户组test的成员对该文件有:
【r】读取、【w】写的权限,没有【x】执行的权限。

查看test1 分组成员:

[root@test]# cat group test1 
test1:x:501:test,mrzhao,shaoz

说明了test,mrzhao,shaoz这几个人对文件check_crc.v有读和写的权限,没有执行的权限。

Others组

是除了root(root拥有最高权限)、文件所有者、文件所属用户组以外的所有用户。

drwxr-xr-x 4 test test1 4096 Sep 29 2013 dc_test_run

拿上面输出来说,代表test对文件夹dc_test_run有读写执行的权限,test组对文件夹有读取和执行的权限(如果对文件夹只有读取而没有执行的权限,那么也无法列出),除用户User(test)和组Group(test1)以外的组和用户(Other)对文件夹也具有读取和执行的权限。

五、文本处理

13. 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"

14. sed 命令

sed 可依照脚本的指令来处理、编辑文本文件。主要用来自动编辑一个或多个文件、简化对文件的反复操作、编写转换程序等sed -i 可直接对文本操作。

sed '/^$/d' example.txt                      从example.txt文件中删除所有空白行
sed 's/stringa1/stringa2/g' example.txt      将example.txt文件中的 "string1" 替换成 "string2"
sed -i '/TEST/i\\name = test' /home/1.conf   在1.conf文件中TEST后面插入name = test
sed -i 's/d/7523/' /home/1.txt               替换1.txt中第一个字母d为7523
sed -i 's/d/7523/g' /home/1.txt              替换1.txt中所有字母d为7523
sed -i 's/^@//' file                         去掉 “行首” 带“@”的首字母@ 
sed -i '/特定字符串/i 新行字符串' file         特定字符串的行前插入新行
sed -i '/特定字符串/a 新行字符串' file         特定字符串的行后插入新行
sed -i '/字符串/d' file                       特定字符串的删除      

15. paste 命令

paste file1 file2             合并两个文件或两栏的内容
paste -d '+' file1 file2      合并两个文件或两栏的内容,中间用"+"区分

16. sort 命令

sort file1 file2              排序两个文件的内容
sort file1 file2 | uniq       取出两个文件的并集(重复的行只保留一份)
sort file1 file2 | uniq -u    删除交集,留下其他的行
sort file1 file2 | uniq -d    取出两个文件的交集(只留下同时存在于两个文件中的文件)

17. comm 命令

comm -1 file1 file2 比较两个文件的内容只删除 'file1' 所包含的内容
comm -2 file1 file2 比较两个文件的内容只删除 'file2' 所包含的内容
comm -3 file1 file2 比较两个文件的内容只删除两个文件共有的部分

六、打包和压缩文件

18. tar 命令

(对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压)

-c :新建打包文件
-t :查看打包文件的内容含有哪些文件名
-x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中
-j :通过bzip2的支持进行压缩/解压缩
-z :通过gzip的支持进行压缩/解压缩
-v :在压缩/解压缩过程中,将正在处理的文件名显示出来
-f filename :filename为要处理的文件
-C dir :指定压缩/解压缩的目录dir

常用压缩解压缩:

tar -cvf -f /opt/test.tar  /opt     打包/opt目录存放于/opt名为test.tar,仅仅打包不压缩

tar -zcvf /opt/test.tar.gz /opt     打包/opt目录以gzip压缩存放于/opt下名为test

tar -zcvf /opt/test.tar.bzgz /opt   打包/opt目录以gzip压缩存放于/opt下名为test

tar -zxvf /opt/test.tar.gz /opt     解压/opt/test.tar.gz存放于/opt下

tar -ztvf /tmp/etc.tar.gz           查阅上述 /opt/test.tar.gz 文件内有哪些文件

tar -zxvf /opt/test.tar.gz test/passwd     只解压 opt/test.tar.gz 内的test/passwd目录

tar -zxvpf /tmp/test.tar.gz /opt           将/opt/内的所有文件备份下来,并且保存其原有权限

tar -N '2005/06/01' -zcvf home.tar.gz /home   只备份/home当中,比时间2005/06/01更新的文件

tar --exclude /home/dmtsai -zcvf myfile.tar.gz /home/* /etc 我要备份/home, /etc,但不要/home/dmtsai

cd /tmp
tar -cvf - /etc | tar -xvf -/etc/打包后直接解开在/tmp 底下,而不产生文件!

其他压缩解压缩工具:

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      关闭系统
init 0               关闭系统
telinit 0            关闭系统
shutdown -c          取消按预定时间关闭系统
shutdown -r now      重启
reboot               重启
logout               注销
time                 测算一个命令(即程序)的执行时间
shutdown -h hours:minutes &       按预定时间关闭系统

八、进程相关的命令

19 jps命令

(显示当前系统的java进程情况,及其id号)jps(Java Virtual Machine Process StatusTool)是JDK1.5提供的一个显示当前所有java进程pid的命令,简单实用,非常适合在linux/unix平台上简单察看当前java进程的一些简单情况。

20 ps命令

(用于将某个时间点的进程运行情况选取下来并输出,process之意)

-A         所有的进程均显示出来
-a         不与terminal有关的所有进程
-u         有效用户的相关进程
-x         一般与a参数一起使用,可列出较完整的信息
-l         较长,较详细地将PID的信息列出
ps aux     查看系统所有的进程数据
ps ax      查看不与terminal有关的所有进程
ps -lA     查看系统所有的进程数据
ps axjf    查看连同一部分进程树状态

21 kill命令

(kill 用于向某个工作(%jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用)

(killall 向一个命令启动的进程发送一个信号)

如何杀死进程:

kill -9 pid  (-9表示强制关闭)
killall -9 程序的名字
pkill 程序的名字
查看进程端口号:netstat -tunlp|grep 端口号 

22 top命令

是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。

你可能感兴趣的:(Linux,Linux,Linux基础命令,Linux面试)