《Java 后端面试经》专栏文章索引:
《Java 后端面试经》Java 基础篇
《Java 后端面试经》Java EE 篇
《Java 后端面试经》数据库篇
《Java 后端面试经》多线程与并发编程篇
《Java 后端面试经》JVM 篇
《Java 后端面试经》操作系统篇
《Java 后端面试经》Linux 篇
《Java 后端面试经》设计模式篇
《Java 后端面试经》计算机网络篇
《Java 后端面试经》微服务篇
所有可操作的计算机资源都存在于目录树这个结构中,对计算资源的访问,可以看做是对这棵目录树的访问。
Linux 文件系统的结构层次鲜明,就像一棵倒立的树,最顶层是其根目录,目录结构如下:
常见目录说明:
find /home -name "*.txt"
,忽略大小写: find /home -iname "*.txt"
;③ 当前目录及子目录下查找所有以 .txt 和 .pdf 结尾的文件: find . \( -name "*.txt" -o -name "*.pdf" \)
或 find . -name "*.txt" -o -name "*.pdf"
tail -f 文件
可以对某个文件进行动态监控,例如 tomcat 的日志文件, 会随着程序的运行,日志会变化,可以使用 tail -f catalina-2016-11-11.log
监控文件的变化vim 文件------>进入文件----->命令模式------>按 i 进入编辑模式----->编辑文件 ------->按 Esc 进入底行模式----->输入:wq/q! (输入 wq 代表写入内容并退出,即保存;输入 q! 代表强制退出不保存)
Linux 中的打包文件一般是以 .tar
结尾的,压缩的命令一般是以 .gz
结尾的。而一般情况下打包和压缩是一起进行的,打包并压缩后的文件的后缀名一般 .tar.gz
. 命令:tar -zcvf
打包压缩后的文件名要打包压缩的文件 ,其中
gzip
压缩命令进行压缩假如 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/
tar [-xvf] 压缩文件 # x:代表解压
例如:
tar -xvf test.tar.gz
tar -xvf test.tar.gz -C /usr
(-C 代表指定解压的位置)操作系统中每个文件都拥有特定的权限、所属用户和所属组。权限是操作系统用来限制资源访问的机制,在 Linux 中权限一般分为读 (readable)、写 (writable) 和执行 (excutable),分为三组。分别对应文件的属主 (owner),属组 (group) 和其他用户 (other),通过这样的机制来限制哪些用户、哪些组可以对特定的文件进行什么样的操作。
通过 ls -l
命令可以查看某个目录下的文件或目录的权限
第一列的内容的信息解释如下:
文件的类型:
Linux 中权限分为以下几种:
文件和目录权限的区别:
1、对于文件:
权限名称 | 可执行操作 |
---|---|
r | 可以使用 cat 查看文件的内容 |
w | 可以修改文件的内容 |
x | 可以将其运行为二进制文件 |
2、对于目录:
权限名称 | 可执行操作 |
---|---|
r | 可以查看目录下列表 |
w | 可以创建和删除目录下文件 |
x | 可以使用 cd 进入目录 |
注意:超级用户可以无视普通用户的权限,即使文件目录权限是 000,依旧可以访问。
在 linux 中的每个用户必须属于一个组,不能独立于组外。在 linux 中每个文件有所有者、所在组、其它组的概念。
ls ‐ahl
命令可以看到文件的所有者也可以使用 chown 用户名 文件名
来修改文件的所有者ls ‐ahl
命令可以看到文件的所有组也可以使用 chgrp 组名 文件名
来修改文件所在的组修改文件/目录的权限的命令:chmod
例如,修改 /test 下的 aaa.txt 的权限为文件所有者有全部权限,文件所有者所在的组有读写权限,其他用户只有读的权限
chmod u=rwx,g=rw,o=r aaa.txt 或者 chmod 764 aaa.txt
Linux 系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。
用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。
用户管理相关命令:
useradd 选项 用户名 #添加用户账号
userdel 选项 用户名 #删除用户帐号
usermod 选项 用户名 #修改帐号
passwd 用户名 #更改或创建用户的密码
passwd -S 用户名 #显示用户账号密码信息
passwd -d 用户名 #清除用户密码
使用 useradd
指令所建立的帐号,保存在 /etc/passwd 文本文件中。
每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同 Linux 系统对用户组的规定有所不同,如 Linux 下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对 /etc/group
文件的更新。
用户组的管理相关命令:
groupadd 选项 用户组 #增加一个新的用户组
groupdel 用户组 #要删除一个已有的用户组
groupmod 选项 用户组 #修改用户组的属性
pwd #显示当前所在位置
sudo + 其他命令 #以系统管理者的身份执行指令,也就是说,经由 sudo 所执行的指令就好像是 root 亲自执行
grep 要搜索的字符串 要搜索的文件 --color #搜索命令,--color 代表高亮显示
#两个命令都是查看当前系统正在运行进程,两者的区别是展示格式不同
#如果想要查看特定的进程可以使用这样的格式:ps aux|grep redis (查看包括 redis 字符串的进程),也可使用 pgrep redis -a
ps -ef/ps -aux
kill -9 进程的 pid #杀死进程, -9 表示强制终止
网络通信命令:
ifconfig #查看当前系统的网卡信息
ping #查看与某台机器的连接情况
netstat -an #查看当前系统的端口使用