find 指令将从指定目录向下递归地遍历其各个子目录,将满足条件的文件显示在终端
find [搜索范围] [选项]
选项 | 功能 |
---|---|
-name<查询方式> | 按照指定的文件名查找模式查找文件 |
-user<用户名> | 查找属于指定用户名所有文件 |
-size<文件大小> | 按照指定的文件大小查找文件,单位为: b —— 块(512 字节) c —— 字节 w —— 字(2 字节) k —— 千字节 M —— 兆字节 G —— 吉字节 |
locate 指令利用事先建立的系统中所有文件名称及路径的 locate 数据库实现快速定位给 定的文件。Locate 指令无需遍历整个文件系统,查询速度较快。为了保证查询结果的准确 度,管理员必须定期更新 locate 时刻。
locate 搜索文件
由于 locate 指令基于数据库进行查询,所以第一次运行前,必须使用 updatedb 指令创 建 locate 数据库。
管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理
grep 选项 查找内容 源文件
选项 | 功能 |
---|---|
-n | 显示匹配行及行号 |
gzip 文件 (功能描述:压缩文件,只能将文件压缩为*.gz 文件)
gunzip 文件.gz (功能描述:解压缩文件命令)
(1)只能压缩文件不能压缩目录
(2)不保留原来的文件
(3)同时多个文件会产生多个压缩包
zip [选项] XXX.zip 将要压缩的内容 (功能描述:压缩文件和目录的命令)
unzip [选项] XXX.zip (功能描述:解压缩文件)
zip 选项 | 功能 |
---|---|
-r | 压缩目录 |
unzip 选项 | 功能 |
---|---|
-d<目录> | 指定解压后文件的存放目录 |
zip 压缩命令在windows/linux都通用,可以压缩目录且保留源文件。
[root@hadoop100 home]# zip mymy.zip xue.txt bigbig.txt
[root@hadoop100 home]# unzip mymy.zip
[root@hadoop100 home]# unzip mymy.zip -d /home/pig
tar [选项] XXX.tar.gz 将要打包进去的内容 (功能描述:打包目录,压缩后的 文件格式.tar.gz)
选项 | 功能 |
---|---|
-c | 产生.tar 打包文件 |
-C | 解压到指定目录 |
-v | 显示详细信息 |
-f | 指定压缩后的文件名 |
-z | 打包同时压缩 |
-x | 解包.tar 文件 |
[root@hadoop100 home]# tar -zcvf mymy.tar.gz xue.txt bigbig.txt
[root@hadoop100 home]# tar -zcvf ddd.tar.gz ddd/
[root@hadoop100 home]# tar -zxvf ddd.tar.gz
[root@hadoop100 home]# tar -zxvf mymy.tar.gz -C /home/pig
du: disk usage 磁盘占用情况
du 目录/文件 (功能描述:显示目录下每个子目录的磁盘使用情况)
选项 | 功能 |
---|---|
-h | 以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示 |
-a | 不仅查看子目录大小,还要包括文件 |
-c | 显示所有的文件和子目录大小后,显示总和 |
-s | 只显示总和 |
–max-depth=n | 指定统计子目录的深度为第 n 层 |
[root@hadoop100 ~]# du --max-depth=1 -ah
df: disk free 空余磁盘
df 选项 (功能描述:列出文件系统的整体磁盘使用量,检查文件系统的磁盘空间占 用情况)
选项 | 功能 |
---|---|
-h | 以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示 |
lsblk (功能描述:查看设备挂载情况)
选项 | 功能 |
---|---|
-f | 查看详细的设备挂载情况,显示文件系统信息 |
如果硬盘使用了IDE则这里的命名为hda
fdisk -l (功能描述:查看磁盘分区详情)
fdisk 硬盘设备名 (功能描述:对新增硬盘进行分区操作)
选项 | 功能 |
---|---|
-l | 显示所有硬盘的分区列表 |
该命令必须在 root 用户下才能使用
Device:分区序列
Boot:引导
Start:从X磁柱开始
End:到Y磁柱结束
Blocks:容量
Id:分区类型ID
System:分区类型
m:显示命令列表
p:显示当前磁盘分区
n:新增分区
w:写入分区信息并退出
q:不保存分区信息直接退出
a toggle a bootable flag(切换可引导标志)
b edit bsd disklabel (编辑bsd磁盘标签)
c toggle the dos compatibility flag (切换dos兼容性标志)
d delete a partition (删除分区)
g create a new empty GPT partition table (创建新的空GPT分区表)
G create an IRIX (SGI) partition table (创建IRIX(SGI)分区表)
l list known partition types (列出已知分区类型)
m print this menu (打印此菜单)
n add a new partition (添加新分区)
o create a new empty DOS partition table (创建一个新的空DOS分区表)
p print the partition table (打印分区表)
q quit without saving changes (退出而不保存更改)
s create a new empty Sun disklabel (创建新的空Sun磁盘标签)
t change a partition’s system id (更改分区的系统id)
u change display/entry units (更改显示/输入单位)
v verify the partition table (验证分区表)
w write table to disk and exit (将表写入磁盘并退出)
x extra functionality (experts only) (额外功能(仅限专家))
然后在命令中输入n开始添加新分区
p primary 是主分区
e extended 是扩展分区
linux目前有4个主分区,可以将用扩展分区替代主分区,这样的话可以扩展出若干个逻辑分区,最多有12个逻辑分区,主分区的编号为1-4, 逻辑分区的编号为5-16,可以说是sdb1-sdb16,选择了p之后,要是没有什么改动的话就一直回车就是默认值,如下图:
现在分区表有内容了
然后保存退出w
这时候在查看分区sdb就有内容了
用lsblk -f可以查看文件系统信息这时候sdb1是没有任何信息的,因为没有对sdb1格式化
接下来对sdb1指定文件系统,对他格式化
mkfs(make file system)命令用于在特定的分区上建立 linux 文件系统
使用方式
选项 | 功能 |
---|---|
device | 预备检查的硬盘分区,例如:/dev/sdb1 |
-V | 详细显示模式 |
-t | 给定档案系统的型式,Linux 的预设值为 xfs |
-c | 在制做档案系统前,检查该partition 是否有坏轨 |
-l bad_blocks_file | 将有坏轨的block资料加到 bad_blocks_file 里面 |
block | 给定 block 的大小 |
[root@hadoop100 ~]# mount /dev/sdb1 /home/pig
挂载到home下的pig,这样的话凡是放到pig下面的文件都是存到sdb1里,而不会占用sda的内存,当把sdb1的卸载之后,在sdb1里的文件也就没有了
可以使用df -h查看磁盘占用情况,
[root@hadoop100 ~]# umount /dev/sdb1
可以使用名称/dev/sdb1或者挂载点/home/pig
卸载之后再使用lsblk -f的时候就看不到sdb1的挂载点了
使用df -h也看不到sdb1的磁盘占用情况了
对于Linux用户来讲,不论有几个分区,分别分给哪一个目录使用,它总归就是一个根 目录、一个独立且唯一的文件结构。 Linux中每个分区都是用来组成整个文件系统的一部分,它在用一种叫做“挂载”的处理 方法,它整个文件系统中包含了一整套的文件和目录,并将一个分区和一个目录联系起来, 要载入的那个分区将使它的存储空间在这个目录下获得
快捷键ctrl+d
因为要手动挂载,则在操作这个步骤的时候要先将虚拟机注销
mount [-t vfstype] [-o options] device dir (功能描述:挂载设备)
umount 设备文件名或挂载点 (功能描述:卸载设备)
参数 | 功能 |
---|---|
-t vfstype | 指定文件系统的类型,通常不必指定。mount 会自动选择正确的类 型。常用类型有 光盘或光盘镜像:iso9660 DOS fat16 文件系统:msdos Windows 9x fat32 文件系统:vfat Windows NT ntfs 文件系统:ntfs Mount Windows 文件网络共享:smbfs UNIX(LINUX) 文件网络共享:nfs |
-o options | 主要用来描述设备或档案的挂接方式。常用的参数有: loop:用来把一个文件当成硬盘分区挂接上系统 ro:采用只读方式挂接设备 rw:采用读写方式挂接设备 iocharset:指定访问文件系统所用字符集 |
device | 要挂接(mount)的设备 |
dir | 设备在系统上的挂接点(mount point) |
[root@hadoop100 ~]# mkdir /mnt/cdrom
[root@hadoop100 ~]# mount /dev/cdrom /mnt/cdrom/
[root@hadoop100 ~]# vim /etc/fstab
然后加一条下面的语句就可以了
一般守护进程是以d结尾的
在Centos7里面服务在/usr/lib/systemd/system里面
利用管道筛选以d.service结尾的服务
这些基本上都是守护进程了
ps:process status 进程状态
ps aux | grep xxx (功能描述:查看系统中所有进程)
ps -ef | grep xxx (功能描述:可以查看子父进程之间的关系)
选项 | 功能 |
---|---|
a | 列出带有终端的所有用户的进程 |
x | 列出当前用户的所有进程,包括没有终端的进程 |
u | 面向用户友好的显示风格 |
-e | 列出所有进程 |
-u | 列出某个用户关联的所有进程 |
-f | 显示完整格式的进程列表 |
(1)ps aux 显示信息说明
USER:该进程是由哪个用户产生的
PID:进程的 ID 号
%CPU:该进程占用 CPU 资源的百分比,占用越高,进程越耗费资源; %MEM:该进程占用物理内存的百分比,占用越高,进程越耗费资源; VSZ:该进程占用虚拟内存的大小,单位 KB;
RSS:该进程占用实际物理内存的大小,单位 KB;
TTY:该进程是在哪个终端中运行的。对于 CentOS 来说,tty1 是图形化终端, tty2-tty6 是本地的字符界面终端。pts/0-255 代表虚拟终端。
STAT:进程状态。常见的状态有:R:运行状态、S:睡眠状态、T:暂停状态、 Z:僵尸状态、s:包含子进程、l:多线程、+:前台显示 、<:表示当前进程是比较高的优先级、N:表示当前进程是比较低的优先级
START:该进程的启动时间
TIME:该进程占用 CPU 的运算时间,注意不是系统时间
COMMAND:产生此进程的命令名
(2)ps -ef 显示信息说明
UID:用户 ID
PID:进程 ID
PPID:父进程 ID
C:CPU 用于计算执行优先级的因子。数值越大,表明进程是 CPU 密集型运算, 执行优先级会降低;数值越小,表明进程是 I/O 密集型运算,执行优先级会提高
STIME:进程启动的时间
TTY:完整的终端名称
TIME:CPU 时间
CMD:启动进程所用的命令和参数
如果想查看进程的 CPU 占用率和内存占用率,可以使用 aux;
如果想查看进程的父进程 ID 可以使用 ef
最近最少使用(最长时间)淘汰算法(Least Recently Used)。LRU是淘汰最长时间没有被使用的页面
LRU 关键是看页面最后一次被使用到发生替换的时间长短,时间越长,页面就会被置换
[root@hadoop100 ~]# ps -ef
[root@hadoop100 ~]# ps -ef | grep sshd
在开一个进程
在以cat用户开一个进程
kill [选项] 进程号 (功能描述:通过进程号杀死进程)
killall 进程名称 (功能描述:通过进程名称杀死进程,也支持通配符,这 在系统因负载过大而变得很慢时很有用)
选项 | 功能 |
---|---|
-9 | 表示强迫进程立即停止 |
不管杀死2827还是2823都是把cat用户登录删除,作用是一样的
这时候没有了sshd守护进程了,那么远程登录就都登录不上了,只有再把sshd守护进程开启才可以再次远程登录,如果没有开启sshd守护进程,把所有的root进程的远程登录关掉,那么只能用主机操作了
用这个的时候一定要谨慎使用
比如将sshd全部杀死,这样的话远程登录的全部停了,而且也不能再次远程登录了,只能在主机上打开sshd守护进程才可以,这个就不演示了
命令是killall sshd
有兴趣的小伙伴可以去尝试一下
pstree [选项]
选项 | 功能 |
---|---|
-p | 显示进程的 PID |
-u | 显示进程的所属用户 |
top [选项]
选项 | 功能 |
---|---|
-d 秒数 | 指定 top 命令每隔几秒更新。默认是 3 秒在 top 命令的交互模式当 中可以执行的命令 |
-i | 使 top 不显示任何闲置或者僵死进程。 |
-p | 通过指定监控进程 ID 来仅仅监控某个进程的状态。 |
操作 | 功能 |
---|---|
P | 以 CPU 使用率排序,默认就是此项 |
M | 以内存的使用率排序 |
N | 以 PID 排序 |
q | 退出 top |
内容 | 说明 |
---|---|
18:16:49 | 系统当前时间 |
up 1:27 | 系统的运行时间,本机1 小时 27 分钟 |
4 users | 当前登录了四个用户 |
load average:0.00,0.01,0.05 | 系统在之前 1 分钟,5 分钟,15 分钟的平均负 载。一般认为小于 1 时,负载较小。如果大于 1,系统已经超出负荷。 |
内容 | 说明 |
---|---|
Tasks: 224 total | 系统中的进程总数 |
1 running | 正在运行的进程数 |
223 sleeping | 睡眠的进程 |
0 stopped | 正在停止的进程 |
0 zombie | 僵尸进程。如果不是 0,需要手工检查僵尸进程 |
内容 | 说明 |
---|---|
%Cpu(s): 0.1%us | 用户模式占用的 CPU 百分比 |
0.1%sy | 系统模式占用的 CPU 百分比 |
0.0%ni | 改变过优先级的用户进程占用的 CPU 百分比 |
99.8%id | 空闲 CPU 的 CPU 百分比 |
0.0%wa | 等待输入/输出的进程的占用 CPU 百分比 |
0.0%hi | 硬中断请求服务占用的 CPU 百分比 |
0.0%si | 软中断请求服务占用的 CPU 百分比 |
0.0%st | st(Steal time)虚拟时间百分比。就是当有虚拟 机时,虚拟 CPU 等待实际 CPU 的时间百分比 |
内容 | 说明 |
---|---|
Mem: 4026156k total | 物理内存的总量,单位 KB |
1772056k free | 空闲的物理内存数量 |
901876k used | 已经使用的物理内存数量 |
1352224k buffers | 作为缓冲的内存数量 |
内容 | 说明 |
---|---|
Swap: 4194300k total | 交换分区(虚拟内存)的总大小 |
4194300k free | 空闲交换分区的大小 |
0k used | 已经使用的交互分区的大小 |
2854860k avail Men | 作为缓存的交互分区的大小 |
shift+m 从大到小
shift + n 从大到下
d
在top里按k然后杀死4148进程然后再输入9,(9是kill -l中的一个命令下面一会附上图)
netstat -anp | grep 进程号 (功能描述:查看该进程网络信息)
netstat –nlp | grep 端口号 (功能描述:查看网络端口号占用情况)
选项 | 功能 |
---|---|
-a | 显示所有正在监听(listen)和未监听的套接字(socket) |
-n | 拒绝显示别名,能显示数字的全部转化成数字 |
-l | 仅列出在监听的服务状态 |
-p | 表示显示哪个进程在调用 |
选项 | 功能 |
---|---|
Proto | 协议 |
Recv-Q | 还没有拷贝出来的字节数量 |
Send-Q | 远程主机还没有确认收到的字节数量 |
Local Address | 本地地址 |
Foreign Address | 远程地址 |
State | 状态 |
PID/Program name | PID和进程的名字 |
crontab [选项]
选项 | 功能 |
---|---|
-e | 编辑 crontab 定时任务 |
-l | 查询 crontab 任务 |
-r | 删除当前用户所有的 crontab 任务 |
* * * * * 执行的任务
项目 | 含义 | 范围 |
---|---|---|
第一个“*” | 一小时当中的第几分钟 | 0-59 |
第二个“*” | 一天当中的第几小时 | 0-23 |
第三个“*” | 一个月当中的第几天 | 1-31 |
第四个“*” | 一年当中的第几月 | 1-12 |
第五个“*” | 一周当中的星期几 | 0-7( 0 和 7 都 代 表 星 期 日) |
特殊符号 | 含义 |
---|---|
* | 代表任何时间。比如第一个“*”就代表一小时中每分钟 都执行一次的意思。 |
, | 代表不连续的时间。比如“0 8,12,16 * * * 命令”,就代表 在每天的 8 点 0 分,12 点 0 分,16 点 0 分都执行一次命令 |
- | 代表连续的时间范围。比如“0 5 * * 1-6 命令”,代表在 周一到周六的凌晨 5 点 0 分执行命令 |
*/n | 代表每隔多久执行一次。比如“*/10 * * * * 命令”,代 表每隔 10 分钟就执行一遍命令 |
时间 | 含义 |
---|---|
30 18 * * * 命令 | 每天18点30分执行命令 |
20 5 * * 1 命令 | 每周一的5点20分执行命令 |
20 5 1,20 * * 命令 | 每月1号和20号的凌晨5点20执行命令 |
20 5 * * 1-5 命令 | 每周一到周五凌晨5点20执行命令 |
*/10 5 * * * 命令 | 每天的凌晨5点每隔10分钟执行一次命令 |
20 5 1,20 * 1命令 | 每月1号和20号,每周1的5点20分都会执行命令 |
注 意:星期几和几号最好不要同时出现,因为他们定义的都 是天。非常容易让管理员混乱
*/1 * * * * echo “hello,linux!” >> /root/hellolinux