《Java 后端面试经》专栏文章索引: 《Java 后端面试经》Java 基础篇 《Java 后端面试经》Java EE 篇 《Java 后端面试经》数据库篇 《Java 后端面试经》多线程与并发编程篇 《Java 后端面试经》JVM 篇 《Java 后端面试经》操作系统篇 《Java 后端面试经》Linux 篇 《Java 后端面试经》设计模式篇 《Java 后端面试经》计算机网络篇 《Java 后端面试经》微服务篇
@[TOC](《Java 后端面试经》Linux 篇)
🚀1. Linux 目录树
所有可操作的计算机资源都存在于目录树这个结构中,对计算资源的访问,可以看做是对这棵目录树的访问。
Linux 文件系统的结构层次鲜明,就像一棵倒立的树,最顶层是其根目录,目录结构如下 : 常见目录说明:
- /bin:存放二进制可执行文件(ls、cat、mkdir 等),常用命令一般都在这里
- /etc:存放系统管理和配置文件
- /home:存放所有用户文件的根目录,是用户主目录的基点,比如用户 user 的主目录就是 /home/user,可以用 ~user 表示
- /usr:用于存放系统应用程序
- /opt: 额外安装的可选应用程序包所放置的位置。一般情况下,我们可以把 tomcat 等都安装到这里
- /proc:虚拟文件系统目录,是系统内存的映射,可直接访问这个目录来获取系统信息
- /root:超级用户(系统管理员)的主目录
- /sbin:存放二进制可执行文件,只有 root 才能访问,这里存放的是系统管理员使用的系统级别的管理命令和程序,如 ifconfig 等
- /dev:用于存放设备文件
- /mnt: 系统管理员安装临时文件系统的安装点,系统提供这个目录是让用户临时挂载它的文件系统
- /boot:存放用于系统引导时使用的各种文件
- /lib:存放着和系统运行相关的库文件
- /tmp:用于存放各种临时文件,是公用的临时文件存储点
- /var:用于存放运行时需要改变数据的文件,也是某些大文件的溢出区,比方说各种服务的日志文件(系统启动日志等)
- /lost+found:这个目录平时是空的,系统非正常关机而留下"无家可归"的文件 (windows 下叫什么 .chk) 就在这里
🚀2. Linux 基本命令
🚁2.1 目录切换命令
- cd usr:切换到该目录下 usr 目录
- cd ..(cd../):切换到上一层目录
- cd /:切换到系统根目录
- cd ~:切换到用户主目录
- cd -:切换到上一个操作所在目录
🚁2.2 目录的操作命令(增删改查)
- mkdir 目录名称:增加目录
- ls/ll(ll 是 ls -l 的别名,ll 命令可以看到该目录下的所有目录和文件的详细信息):查看目录信息
- find 目录 参数 :寻找目录(查)。示例:① 列出当前目录及子目录下所有文件和文件夹: find .;② 在 /home 目录下查找以.txt 结尾的文件名:
find /home -name "*.txt"
,忽略大小写:find /home -iname "*.txt"
;③ 当前目录及子目录下查找所有以 .txt 和 .pdf 结尾的文件:find . \( -name "*.txt" -o -name "*.pdf" \)
或find . -name "*.txt" -o -name "*.pdf"
- mv 目录名称 新目录名称:修改目录的名称(改)。注意:mv 的语法不仅可以对目录进行重命名而且也可以对各种文件,压缩包等进行重命名的操作。mv 命令用来对文件或目录重新命名,或者将文件从一个目录移到另一个目录中
- mv 目录名称 目录的新位置:移动目录的位置---剪切(改)。注意:mv 语法不仅可以对目录进行剪切操作,对文件和压缩包等都可执行剪切操作。另外 mv 与 cp 的结果不同,mv 好像文件"搬家",文件个数并未增加,而 cp 对文件进行复制,文件个数增加了
- cp -r 目录名称 目录拷贝的目标位置: 拷贝目录(改),-r 代表递归拷贝。注意:cp 命令不仅可以拷贝目录还可以拷贝文件,压缩包等,拷贝文件和压缩包时不用写 -r 递归
- rm [-rf] 目录 : 删除目录(删)。注意:rm 不仅可以删除目录,也可以删除其他文件或压缩包
🚁2.3 文件的操作命令(增删改查)
- touch 文件名称: 文件的创建(增)
- cat/more/less/tail 文件名称 :文件的查看(查) 。命令
tail -f 文件
可以对某个文件进行动态监控,例如 tomcat 的日志文件, 会随着程序的运行,日志会变化,可以使用tail -f catalina-2016-11-11.log
监控文件的变化 - vim 文件 : 修改文件的内容(改)。vim 编辑器是 Linux 中的强大组件,是 vi 编辑器的加强版。在实际开发中,使用 vim 编辑器主要作用就是修改配置文件,下面是一般步骤:
vim 文件------>进入文件----->命令模式------>按 i 进入编辑模式----->编辑文件 ------->按 Esc 进入底行模式----->输入:wq/q! (输入 wq 代表写入内容并退出,即保存;输入 q! 代表强制退出不保存)
- rm -rf 文件: 删除文件(删)
🚁2.4 压缩文件的操作命令
🪂2.4.1 打包并压缩文件
Linux 中的打包文件一般是以 .tar
结尾的,压缩的命令一般是以 .gz
结尾的。而一般情况下打包和压缩是一起进行的,打包并压缩后的文件的后缀名一般 .tar.gz
. 命令:tar -zcvf
打包压缩后的文件名要打包压缩的文件 ,其中
- z :调用
gzip
压缩命令进行压缩 - c:打包文件
- v:显示运行过程
- f:指定文件名
假如 test
目录下有三个文件分别是:aaa.txt bbb.txt ccc.txt
,如果我们要打包 test 目录并指定压缩后的压缩包名称为 test.tar.gz 可以使用命令:tar -zcvf test.tar.gz aaa.txt bbb.txt ccc.txt 或 tar -zcvf test.tar.gz /test/
🪂2.4.2 解压压缩包
bash
tar [-xvf] 压缩文件 # x:代表解压
例如:
- 将 /test 下的 test.tar.gz 解压到当前目录下可以使用命令:
tar -xvf test.tar.gz
- 将 /test 下的 test.tar.gz 解压到根目录 /usr 下:
tar -xvf test.tar.gz -C /usr
(-C 代表指定解压的位置)
🚁2.5 权限命令
操作系统中每个文件都拥有特定的权限、所属用户和所属组。权限是操作系统用来限制资源访问的机制,在 Linux 中权限一般分为读 (readable)、写 (writable) 和执行 (excutable),分为三组。分别对应文件的属主 (owner),属组 (group) 和其他用户 (other),通过这样的机制来限制哪些用户、哪些组可以对特定的文件进行什么样的操作。
通过 ls -l
命令可以查看某个目录下的文件或目录的权限 第一列的内容的信息解释如下: 文件的类型:
- d:代表目录
- -:代表文件
- l:代表软链接(可以认为是 windows 中的快捷方式)
Linux 中权限分为以下几种:
- r:代表权限是可读,r 也可以用数字 4 表示
- w:代表权限是可写,w 也可以用数字 2 表示
- x:代表权限是可执行,x 也可以用数字 1 表示
文件和目录权限的区别:
1、对于文件:
权限名称 | 可执行操作 |
---|---|
r | 可以使用 cat 查看文件的内容 |
w | 可以修改文件的内容 |
x | 可以将其运行为二进制文件 |
2、对于目录:
权限名称 | 可执行操作 |
---|---|
r | 可以查看目录下列表 |
w | 可以创建和删除目录下文件 |
x | 可以使用 cd 进入目录 |
注意:超级用户可以无视普通用户的权限,即使文件目录权限是 000,依旧可以访问。
在 linux 中的每个用户必须属于一个组,不能独立于组外。在 linux 中每个文件有所有者、所在组、其它组的概念。
- 所有者(u) :一般为文件的创建者,谁创建了该文件,就是该文件的所有者,用
ls ‐ahl
命令可以看到文件的所有者也可以使用chown 用户名 文件名
来修改文件的所有者 - 文件所在组(g) :当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组用
ls ‐ahl
命令可以看到文件的所有组也可以使用chgrp 组名 文件名
来修改文件所在的组 - 其它组(o) :除开文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组
修改文件/目录的权限的命令:chmod
例如,修改 /test 下的 aaa.txt 的权限为文件所有者有全部权限,文件所有者所在的组有读写权限,其他用户只有读的权限
bash
chmod u=rwx,g=rw,o=r aaa.txt 或者 chmod 764 aaa.txt
🚁2.6 用户管理
Linux 系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。
用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。
用户管理相关命令:
bash
useradd 选项 用户名 #添加用户账号
userdel 选项 用户名 #删除用户帐号
usermod 选项 用户名 #修改帐号
passwd 用户名 #更改或创建用户的密码
passwd -S 用户名 #显示用户账号密码信息
passwd -d 用户名 #清除用户密码
使用 useradd
指令所建立的帐号,保存在 /etc/passwd 文本文件中。
🚁2.7 用户组管理
每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同 Linux 系统对用户组的规定有所不同,如 Linux 下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对 /etc/group
文件的更新。
用户组的管理相关命令:
bash
groupadd 选项 用户组 #增加一个新的用户组
groupdel 用户组 #要删除一个已有的用户组
groupmod 选项 用户组 #修改用户组的属性
🚁2.8 其他常用命令
bash
pwd #显示当前所在位置
sudo + 其他命令 #以系统管理者的身份执行指令,也就是说,经由 sudo 所执行的指令就好像是 root 亲自执行
grep 要搜索的字符串 要搜索的文件 --color #搜索命令,--color 代表高亮显示
#两个命令都是查看当前系统正在运行进程,两者的区别是展示格式不同
#如果想要查看特定的进程可以使用这样的格式:ps aux|grep redis (查看包括 redis 字符串的进程),也可使用 pgrep redis -a
ps -ef/ps -aux
kill -9 进程的 pid #杀死进程, -9 表示强制终止
网络通信命令:
bash
ifconfig #查看当前系统的网卡信息
ping #查看与某台机器的连接情况
netstat -an #查看当前系统的端口使用