Linux常见面试题

题目说明:

参考多处Linux总结,整理了一下

原文链接:
https://blog.csdn.net/weixin_41755830/article/details/80519390
https://www.cnblogs.com/zjfjava/p/10513399.html
https://www.jianshu.com/p/7cdf8e724e0a

基础命令:

1.查找文件

find / -name filename.txt
根据名称查找/目录下的 filename.txt 文件。

2.查看一个程序是否运行(进程)

ps –ef|grep tomcat
查看所有有关 tomcat 的进程(“-e”参数代表显示所有进程,“-f”参数代表全格式。)

3.终止线程

kill -9 19979
终止线程号位 19979 的线程

4.查看文件,包含隐藏文件

ls -al

5.当前工作目录

pwd

6.复制文件包括其子文件到自定目录

cp -r sourceFolder targetFolder

7.创建目录

mkdir newfolder

8.删除目录(此目录是空目录)

rmdir deleteEmptyFolder

9.删除文件包括其子文件

rm -rf deleteFile

10.移动文件

mv /temp/movefile /targetFolder
扩展重命名 mv oldNameFile newNameFile

11.切换用户

su -username

12.修改文件权限

chmod 777 file.java
//file.java 的权限-rwxrwxrwx,r 表示读、w 表示写、x 表示可执行

13.压缩文件

tar -czf test.tar.gz /test1 /test2
14.列出压缩文件列表
tar -tzf test.tar.gz

15.解压文件

tar -xvzf test.tar.gz

16.查看文件头 10 行

head -n 10 example.txt
17.查看文件尾 10 行
tail -n 10 example.txt

18.查看日志文件

tail -f exmaple.log
//这个命令会自动显示新增内容,屏幕只显示 10 行内容的(可设置)。

19.启动 Vi 编辑器

vi
20.查看系统当前时间
date
命令会输出 周几 几月 几日 时间 和 时间显示格式 和年份
Sat Jan 20 04:39:49 CST 2018
date +”%Y-%m-%d”
显示如下:
[root@ming xxx]# date +"%Y-%m-%d"
2018-01-20
21、cd
用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路
径。
cd /opt :绝对路径 cd opt :相对路径

22、ls 查看文件与目录的命令

ls -l (也可以直接 ll ) :列出长数据串,包含文件的属性与权限数据等
ls -a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)

23、grep文本搜索

语法:grep 参数 查找条件 文件名(注:是文件名,目录名下查找不行)
主要参数:
-i:不区分大小写(只适用于字母字符。)
-l:查询多文件时只输出包含匹配字符的 文件名。
-n:显示匹配行内容及行号。
比如我的/opt 目录下有文件 test1.txtgrep -i “teacher” test1.txt : 查询包含 teachergrep -l
“teacher” test1.txt test2.txt : 在文件 test1/test2 中查找是否有“teacher”grep teacher *.txt : 显
示当前目录下包含“teacher”且以.txt 结尾的文件(grep 命令支持正则表达式,如 grep
‘[a-z]{7}’ *.txt)
ps -ef|grep java:查找指定进程(这里指定 java 进程)
ls -l|grep -i test:把 ls -l 的输出中包含字母 test(不区分大小写)的内容输出 (如果查询的
是目录可以使用正则表达式,但是文件不行)
24、find
查找
-mtime +n : 列出在 n 天之前(不含 n 天本身)被更改过的文件名; -mtime -n : 列出在 n
天之内(含 n 天本身)被更改过的文件名;
find /root(路径) -mtime 0 : 在当前目录下查找今天之内有改动的文件
find -name 文件名 :找匹配的文件名
在某一文件中查找日志(比方方法 login):可以 vi 打开日志文件,然后“/login”,enter,按
n 键向下继续搜索;
25、mkdir
创建指定的名称的目录
-m, --mode=模式,设定权限<模式> (类似 chmod),而不是 rwxrwxrwx 减 umask
-p, --parents 可以是一个路径名称。此时若路径中的某些目录尚不存在,加上此选项后,系统
将自动建立好那些尚不存在的目录,即一次可以建立多个目录; mkdir test1 : 创建一个空目
录 mkdir -p test2/test22 :递归创建多个目录 mkdir -m 777 test3 :创建权限为 777 的目录
26、cp
复制文件,还可以把多个文件一次性地复制到一个目录下
cp -a file1 file2 :连同文件的所有特性把文件 file1 复制成文件 file2
cp file1 file2 file3 dir :把文件 file1、file2、file3 复制到目录 dir 中
27、mv
移动文件、目录或更名
mv file1 file2 file3 dir : 把文件 file1、file2、file3 移动到目录 dir 中
mv file1 file2 : 把文件 file1 重命名为 file2
28、rm
删除文件或目录
-f :就是 force 的意思,忽略不存在的文件,不会出现警告消息 -i :互动模式,在删除前
会询问用户是否操作 -r :递归删除,最常用于目录删除,它是一个非常危险的参数 rm -i
file : 删除文件 file,在删除之前会询问是否进行该操作
rm -fr dir : 强制删除目录 dir 中的所有文件
29、ps
列出系统中当前运行的进程
a 显示所有用户的所有进程(包括其它用户)
-e 显示所有进程,环境变量 f 用树形格式来显示进程;
ps -ef|grep java : 找出所有 java 进程
30、kill
终止指定的进程。需要先使用 ps/pidof/pstree/top 等工具获取进程 PID,然后使用 kill 命令来
杀掉该进程。
kill -9 进程号 : 彻底杀死某个进程

31、tar

对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程
序(如 gzip 和 bzip 等)进行压缩和解压。
语法:tar [主选项+辅选项] 文件或者目录
使用该命令时,主选项是必须要有的,它告诉 tar 要做什么事情,辅选项是辅助使用的,可
以选用。
主选项:c 创建新的档案文件。如果用户想备份一个目录或是一些文件,就要选择这
个选项。相当于打包。
x 从档案文件中释放文件。相当于拆包。
t 列出档案文件的内容,查看已经备份了哪些文件。
**在参数的下达中, c/x/t 仅能存在一个!不可同时存在!因为不可能同时压缩与解压缩。
辅助选项:-z :是否同时具有 gzip 的属性?亦即是否需要用 gzip 压缩或解压? 一般格
式为 xx.tar.gz 或 xx. tgz
-j :是否同时具有 bzip2 的属性?亦即是否需要用 bzip2 压缩或解压?一般格式为
xx.tar.bz2
-v :压缩的过程中显示文件!这个常用
-f :使用档名,请留意,在 f 之后要立即接档名喔!不要再加其他参数!
-p :使用原文件的原来属性(属性不会依据使用者而变)
–exclude FILE:在压缩的过程中,不要将 FILE 打包!
压缩:tar -jcv -f filename.tar.bz2 filename
查询:tar -jtv -f filename.tar.bz2
解压:tar -jxv -f filename.tar.bz2 (解压成目录为 filename 的目录)
注:文件名并不定要以后缀 tar.bz2 结尾,这里主要是为了说明使用的压缩程序为 bzip2

32、chmod

改变文件的权限
语法:chmod [options] mode files
options:-R 可递归遍历子目录,把修改应到目录下所有文件和子目录
who:u 用户 、 g 组 、o 其他 、a 所有用户
opcode:+ 增加权限 、 - 删除权限 、= 重新分配权限
permission: r 读 、w 写 、 x 执行
我们多数用三位八进制数字的形式来表示权限,第一位指定属主的权限,第二位指定组权限,
第三位指定其他用户的权限,每位通过 4(读)、2(写)、1(执行)三种数值的和来确定权限。如
6(4+2)代表有读写权,7(4+2+1)有读、写和执行的权限
chmod u+x file :给 file 的属主增加执行权限
chmod 751 file :给 file 的属主分配读、写、执行(7)的权限,给 file 的所在组分配读、执行
(5)的权限,给其他用户分配执行(1)的权限
chmod u=rwx,g=rx,o=x file :上例的另一种形式
33、tail
查阅正在改变的日志文件
语法:tail[必要参数][选择参数][文件]
-f 循环读取
-n<行数> 显示行数
tail -f 20160921.logs :查看正在改变的日志文件;
tail -3000 catalina.out:查看倒数前 3000 行的数据;
tail -3000 catalina.out | grep ‘AA’:查看倒数前 3000 行包含字母’AA’的数据;
ctrl+z 可退出
34、查看进程 pid
lsof -i:8080:根据端口查看进程 pid:
35、显示目录和文件的命令
Ls:用于查看所有文件夹的命令。
Dir:用于显示指定文件夹和目录的命令 Tree: 以树状图列出目录内容
Du:显示目录或文件大小
35、修改目录,文件权限和属主及数组命令
Chmod:用于改变指定目录或文件的权限命令。
Chown:用于改变文件拥有属性的命令。
Chgrp:用于改变文件群组的命令。
Chattr:用于设置文件具有不可删除和修改权限。
Lsattr:用于显示文件或目录的隐藏属性。
36、创建和删除目录的命令
Mkdir:用于创建目录
Rmdir:用于删除空的目录
Rm -f:用于删除不为空的目录
37、创建和删除,重命名,复制文件的命令
Touch:创建一个新的文件
Vi:创建一个新的文件
Rm:删除文件或目录
Mv:重命名或移动文件的命令
Cp:复制命令
Scp:用于将本地的文件或目录复制到远程服务器
Wget:用于下载 ftp 或 http 服务器文件到本地。

38、显示文件内容的命令

Cat:用于显示指定文件的全部内容
More:用分页的形式显示指定文件的内容
Less:用分页的形式显示指定文件的内容,区别是 more 和 less 翻页使用的操作键不同。
Head:用于显示文件的前 n 行内容。
Tail:用于显示文件的后 n 行内容。
Tail -f:用于自动刷新的显示文件后 n 行数据内容。
39、查找命令
Find:查找指定目录或文件的命令。
Whereis:查找指定的文件源和二进制文件和手册等
Which:用于查询命令或别名的位置。
Locate:快速查找系统数据库中指定的内容。
Grep:在指定的文件或标准输出,标准输入内,查找满足条件的内容。

40、关机和重启计算机的命令

Shutdown:-r 关机后立即重启
-k 并不真正的关机,而只是发出警告信息给所有用户
-h 关机后不重新启动
Poweroff:用于关机和关闭电源
Init:改变系统运行级别
0 级用于关闭系统
1 级用于单一使用者模式
2 级用来进行多用户使用模式(但不带网络功能)
3 级用来进行多用户使用模式(带网络全功能)
4 级用来进行用户自定义使用模式
5 级表示进入 x windows 时的模式
6 级用来重启系统
Reboot: 用于计算机重启
Halt:用于关闭计算机系统
41、压缩和打包命令
Tar:用于多个文件或目录进行打包,但不压缩,同时也用命令进行解包
Gzip:用于文件进行压缩和解压缩命令,文件扩展名为.gz 结尾。
Gunzip:用于对 gzip 压缩文档进行解压缩。
Bzip2:用于对文件或目录进行压缩和解压缩
Bzcat:用于显示压缩文件的内容。
Compress/un compress: 压缩/解压缩.Z 文件
Zcat:查看 z 或 gz 结尾的压缩文件内容。
Gzexe:压缩可执行的文件
Unarg:解压缩.arj 文件
Zip/unzip:压缩解压缩.zip 文件

42、用户操作命令

Su:切换用户命令
Sudo:一系统管理员的身份执行命令
Passwd:用于修改用户的密码
43、改变目录和查看当前目录命令
Cd:进入工作目录
Cd …:会退到上一级命令
Pwd:显示当前用户所在工作目录位置
44、文件连接命令
Ln:为源文件创建一个连接,并不将源文件复制一份,即占用的空间很小。
可以分为软件连接和硬链接。
软连接:也称为符号连接,即为文件或目录创建一个快捷方式。
硬链接:给一个文件取多于一个名字,放在不同目录中,方便用户使用。
45、Ln 命令参数如下:
-f:在创建连接时,先将与目的对象同名的文件或目录删除。
-d:允许系统管理者硬链接自己的目录。
-i:在删除与目的对象同名文件或目录时先询问用户。
-n:在创建软连接时,将目的对象视为一般的文件。
-s:创建软连接,即符号连接。
-v:在连接之前显示文件或目录名。
-b:将在连接时会被覆盖或删除的文件进行备份。
46、帮助命令-----man
47、其他命令
Who:显示系统中有那些用户在使用。
-ami 显示当前用户
-u:显示使用者的动作/工作
-s:使用简短的格式来显示
-v:显示程序版本
Free:查看当前系统的内存使用情况
Uptime:显示系统运行了多长时间
Ps:显示瞬间进程的动态
Pstree:以树状方式显示系统中所有的进程
Date:显示或设定系统的日期与时间。
Last:显示每月登陆系统的用户信息
Kill: 杀死一些特定的进程
Logout:退出系统
Useradd/userdel:添加用户/删除用户
Clear:清屏
Passwd:设置用户密码
vi 编辑器
首先用 vi 命令打开一个文件
末行模式命令:
:n,m w path/filename 保存指定范围文档( n 表开始行,m 表结束行)
:q! 对文件做过修改后,强制退出
:q 没有对文件做过修改退出
Wq 或 x 保存退出
dd 删除光标所在行
: set number 显示行号
:n 跳转到 n 行
:s 替换字符串 : s/test/test2/g /g 全局替换 /也可以用%代替
/ 查找字符串
网络通信常用的命令
Arp:网络地址显示及控制
ftp:文件传输
Lftp:文件传输
Mail:发送/接收电子邮件
Mesg:允许或拒绝其他用户向自己所用的终端发送信息
Mutt E-mail 管理程序
Ncftp :文件传输
Netstat:显示网络连接.路由表和网络接口信息
Pine:收发电子邮件,浏览新闻组
Ping:用于查看网络是否连接通畅
Ssh:安全模式下远程登陆
Telnet:远程登录
Talk:与另一用户对话
Traceroute:显示到达某一主机所经由的路径及所使用的时间。
Wget:从网路上自动下载文件
Write:向其它用户终端写信息 Rlogin:远程登录
面试官常问的 linux 问题

如何暂停一个正在运行的进程,把其放在后台(丌运行)?
答案:为了停止正在运行的进程,让其在后台运行,我们可以使用组合键 Ctrl+Z。
什么是安装 Linux 所需的最小分区数量,以及如何查看系统启动信息?
答案:单独一个/root 分区足以执行所有的系统任务,但是强烈建议安装 Linux 时,需要至少
三个分区:/root,/boot,/swap。一个 IDE 硬盘驱动器支持高达 63 个分区,SCSI 硬盘驱动器支
持超过 15 个分区。
为了检查启动信息,我们可以使用 cat 或者 dmesg 命令,如下所示:
cat /var/log/messages
或者

dmesg
在你的 Linux 机器上跟踪系统事件的守护进程名是什么?
答案:’syslogd’,它负责跟踪系统信息,并将跟踪日志存储在特定的日志文件里。
在/root 分区运行’fsck’命令的最低要求是什么?
答案:/root 分区必须挂载为只读模式,而不是读写模式
如何分层复制/home 目录到另一个目录?
答案:Linux 的’cpio’命令起到了效果。’cpio’可以分层地复制文件和目录层次结构到另
一个位置。
在 Linux 中,怎样实现日志文件的自动替换?
答案:’logrotate’提供日志自动替换功能。
怎样知道 Linux 中是谁在安排工作?
答案:使用’at’命令加上’-l’选项,就可以查出。
如何在丌解压 tar 包的前提下,查看包里的内容?
答案:使用’tar -tvf’。选项‘t’(显示内容),‘v’(详细报告 tar 处理的文件信息),‘f’(使
用档案文件或者设备)
什么是页面错误,它是怎么发生的?
答案:当一个程序请求内存中不存在的数据时,就会产生页面错误,导致的结果就是程序停
止。
什么是在程序中返回代码?
答案:返回代码是 shell 的特性。返回代码显示了程序的状态,一个成功的程序执行后返回
‘0’,&&可以用来决定那个应用程序先执行。
11.如何选择 Linux 操作系统版本?
一般来讲,桌面用户首选 Ubuntu;服务器首选 RHEL 或 CentOS,两者中首选 CentOS。
根据具体要求:
①安全性要求较高,则选择 Debian 或者 FreeBSD。
②需要使用数据库高级服务和电子邮件网络应用的用户可以选择 SUSE。
③想要新技术新功能功能可以选择 Feddora,Feddora 是 RHEL 和 CentOS 的一个测试版和预
发布版本。
④根据现有状况,绝大多数互联网公司选择 CentOS。现在比较常用的是 6 系列,现在市场
占有大概一半左右。另外的原因是 CentOS 更侧重服务器领域,并且无版权约束。
12.请描述 Linux 系统优化的 12 个步骤。
⑴登录系统:不使用 root 登录,通过 sudo 授权管理,使用普通用户登录。
⑵禁止 SSH 远程:更改默认的远程连接 SSH 服务及禁止 root 远程连接。
⑶时间同步:定时自动更新服务器时间。
⑷配置 yum 更新源,从国内更新下载安装 rpm 包。
⑸关闭 selinux 及 iptables(iptables 工作场景如有 wan ip,一般要打开,高并发除外)
⑹调整文件描述符数量,进程及文件的打开都会消耗文件描述符。
⑺定时自动清理/var/spool/clientmquene/目录垃圾文件,防止节点被占满(c6.4 默认没有
sendmail,因此可以不配。)
⑻精简开机启动服务(crond、sshd、network、rsyslog)
⑼Linux 内核参数优化/etc/sysctl.conf,执行 sysct -p 生效。
更改字符集,支持中文,但是还是建议使用英文,防止乱码问题出现。
⑾锁定关键系统文件(chattr +i /etc/passwd /etc/shadow /etc/group /etc/gshadow /etc/inittab
处理以上内容后,把 chatter 改名,就更安全了。)
⑿清空/etc/issue,去除系统及内核版本登陆前的屏幕显示。
13.描述 Linux 运行级别 0-6 的各自含义
0:关机模式
1:单用户模式<==破解 root 密码
2:无网络支持的多用户模式
3:有网络支持的多用户模式(文本模式,工作中最常用的模式)
4:保留,未使用
5:有网络支持的 X-windows 支持多用户模式(桌面)
6: 重新引导系统,即重启
14.描述 Linux 系统从开机到登陆界面的启动过程
⑴开机 BIOS 自检,加载硬盘。
⑵读取 MBR,MBR 引导。
⑶grub 引导菜单(Boot Loader)。
⑷加载内核 kernel。
⑸启动 init 进程,依据 inittab 文件设定运行级别
⑹init 进程,执行 rc.sysinit 文件。
⑺启动内核模块,执行不同级别的脚本程序。
⑻执行/etc/rc.d/rc.local
⑼启动 mingetty,进入系统登陆界面。
15.如果一台办公室内主机无法上网(打丌开网站),请给出你的排查步骤?
①首先确定物理链路是否联通正常。
②查看本机 IP,路由,DNS 的设置情况是否达标。
③telnet 检查服务器的 WEB 有没有开启以及防火墙是否阻拦。
④ping 一下网关,进行最基础的检查,通了,表示能够到达服务器。
⑤测试到网关或路由器的通常情况,先测网关,然后再测路由器一级一级的测试。
⑥测试 ping 公网 ip 的通常情况(记住几个外部 IP),
⑦测试 DNS 的通畅。ping 出对应 IP。
⑧通过以上检查后,还在网管的路由器上进行检查。
16.描述 Linux shell 中单引号、双引号及丌加引号的简单区别
单引号:所见即所得,即将单引号内的内容原样输出,或者描述为单引号里面看到的是什么
就输出什么。
双引号:把双引号里面的内容给输出出来,如果内容中有命令、变量等,会先把,变来那个、
命令解析出结果,然后输出最终内容。
双引号内的命令或者变量写法’命令或变量’或$(命令或变量)
无引号:把内容输出出来,可能不会键含有空格的字符串,视为一个整体输出,如果内容中
有命令、变量等,会先把变量、命令解析出来,然后输出最终内容,如果字符串中带有空格
等特殊字符,则不能完整输出,需要改加双引号。一般连续的字符串,数字,路径等可以用,
不过最好用双引号,替代之。

目前面试遇到的题:

1.Linux系统上查看服务器日志方法

(1)查看日志前n行: cat 文件名 | head -n 数量

demo: cat catalina.out | head -n 200  # 查看catalina.out前200行

(2)查看日志尾n行: cat 文件名 | tail -n 数量

demo: cat catalina.out | tail -n 200  # 查看catalina.out倒数200行

(3)根据 关键词 查看日志并返回 关键词 所在行:

    -n选项显示行号

方法一:cat -n 路径/文件名 | grep 关键词

demo:cat -n catalina.out | grep “http”  # 返回catalina.out中包含http的所有行

方法二:grep -n 关键词 路径/文件名 (与方法一效果相同,不同写法而已)

demo: grep -n “http” catalina.out   # 返回catalina.out中包含http的所有行

(4)查看日志范围: sed -n ‘开始行,结束行p’ 文件名

 demo: sed -n '200,300p' catalina.out  # 查看catalina.out第200行到第300行范围内的内容

 如果是查看某一行:   demo: sed -n '300p' catalina.out  # 查看catalina.out第300行的内容

(5)grep 关键字 范围查看:

demo:

        grep -C 5 'false' catalina.out 显示文件里匹配false那行以及上下5行
        grep -B 5 'false' catalina.out 显示false及前5行
        grep -A 5 'false' catalina.out 显示false及后5行

.
.

查看服务器日志

tail:查看后面几行

n 显示行数
f 持续侦测后面的内容,查看服务器日志常用
查看最新的服务日志(静态)

命令格式:tail -n 行数 日志文件

查看nginx错误日志

root@123:/var/log/nginx# tail -n 10 error.log
查看最新的服务器日志(动态),如果有新内容写入,则持续读取
命令格式:tail -n 行数 -f 日志文件

持续查看nginx错误日志

root@123:/var/log/nginx# tail -n 10 -f error.log
使用关键字查找日志内容
命令格式:tail -n 行数 -f 日志文件 | grep 关键字

关键字查找日志内容

root@123:/var/log/th/order# tail -n 10 | grep TH201805987162

2.查看端口

(1)netstat - atulnp会显示所有端口和所有对应的程序,用grep管道可以过滤出想要的字段

在这里插入图片描述

-a :all,表示列出所有的连接,服务监听,Socket资料
-t :tcp,列出tcp协议的服务
-u :udp,列出udp协议的服务
-n :port number, 用端口号来显示
-l :listening,列出当前监听服务
-p :program,列出服务程序的PID
Proto :网络传输协议,主要为tcp和udpLocal Address :本地的ip:portForeign Address:远程主机的ip:portState :连线状态,主要有监听( LISTEN )和建立(ESTABLISED)PID :服务的进程编号Program name:服务名称
查看某一端口的占用情况: lsof -i:端口号

(2) lsof -i:端口号 用于查看某一端口的占用情况
需要注意的是,centos默认是没有安装lsof(list open files)的,需要手动安装

yum install lsof

在这里插入图片描述

各列代表的含义:

COMMAND:进程的名称
PID:进程标识符
USER:进程所有者
FD:文件描述符,应用程序通过文件描述符识别该文件。如cwd、txt等
TYPE:文件类型,如DIR、REG等
DEVICE:指定磁盘的名称
SIZE:文件的大小
NODE:索引节点(文件在磁盘上的标识)
NAME:打开文件的确切名称

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值