工作管理---放入后台
把程序放入后台:
tar -zcf etc.tar.gz /etc &
#放入后台 :放入后台的任务还在运行。
[root@localhsot ~]# top
#在top命令执行的过程中,按下 ctrl+z 快捷键
#ctrl +z 放入后台的,是暂停的。
查看后台的工作:
[root@localhost ~]# jobs [-l]
选项:
-l 显示工作的PID
注意:“+” 号代表最近一个放入后台的工作,也是工作恢复时,默认恢复的工作。“-”号代表倒数第二个放入后台的工作
+ 代表默认优先恢复
将后台暂停的工作恢复到前台执行
[root@localhost ~]# fg %工作号
参数:
%工作号: %号可以省略,但是注意工作号和PID的区别
把后台暂停的工作恢复到后台执行:
[root@localhost ~]# bg %工作号
注意:后台恢复执行的命令,是不能和前台有交互的,否则不能恢复到后台执行。
系统定时任务
特别要注意的是:%在定时任务中是由特殊含义的,所以如果在定时任务中使用:比如:日期 date=$(date +\%y\%m\%d) 必须转义百分号才会被识别。
定时任务不一定就会在设定的时间执行,如果系统比较繁忙,任务会错开,会有一个前后的延迟。
crond服务管理与访问控制
其中后面的d:代表的是:后台守护进程。
[root@localhost ~]# service crond restart
[root@localhost ~]# chkconfig crond on
用户的crontab设置:
[root@localhost ~]# crontab [选项]
选项:
-e 编辑crontab定时任务
-l 查询crontab任务
-r 删除当前用户所有的crontab任务
项目 | 含义 | 范围 |
第一个“*” | 一小时当中的第几分钟 | 0-59 |
第二个“*” | 一天当中的第几个小时 | 0-23 |
第三个“*” | 一个月当中的第几天 | 1-31 |
第四个“*” | 一年当中的第几月 | 1-12 |
第五个“*” | 一周当中的星期几 | 0-6(0代表星期日) |
案例:
45 22 * * * 命令 | 每天在22点45分执行命令 |
0 17 * * 1 命令 | 每周1的17点0分执行命令 |
0 5 1,15 * * 命令 | 每月1号和15号的凌晨5点0分执行命令 |
40 4 * * 1-5 命令 | 每周一到周五的凌晨4点40分执行命令 |
*/10 4 * * * 命令 | 在每天的凌晨4点,每隔10分钟执行一次命令 |
0 0 1,15 * 1 命令 | 每月1号和15号,每周1的0点0分都会执行命令。注意:星期几和几号最好不要同时出现,因为他们定义的都是天。非常容易还乱。 每个月的1号和15号,凌晨0点0分执行,每周一的凌晨0点0分也执行。 |
特殊符号 | 含义 |
* | 代表任何时间。比如第一个“*”就代表一小时中每分钟都执行依次的意思 |
, | 代表不连续的时间,比如“0 8,12,16 * * * 命令” ,就代表在每天的8点0分,12点0分,16点0分都执行一次命令 |
- | 代表连续的时间范围。比如“0 5 * * 1-6 命令”,代表在每周一到周六的凌晨5点0分执行命令 |
*/n | 代表每隔多久执行一次。比如“*/10 * * * * 命令”,代表每隔10分钟就执行一次命令 |
修改日期:
[root@localhost ~]# date -s 04:59:32
系统资源查看
查看CPU信息:
1、dmesg | grep CPU
dmesg可以判断硬件的信息。
2、cat /proc/cpuinfo
vmstat命令监控系统资源:
[root@localhsot ~]# vmstat [刷新延时 刷新次数]
例子:
[root@localhsot ~]# vmstat 1 3
#监听3次系统资源,每次间隔1秒钟。
dmesg开机时内核检测信息:Linux判断硬件的信息,dmesg就是一个信息查看命令
[root@localhost ~]# dmesg
[root@localhost ~]# dmesg | grep CPU
#小写cpu,查询不一样。
free命令查看内存使用状态
[root@localhost ~]# free [-b|-k|-m|-g]
选项:
-b 以字节为单位显示
-k 一KB为单位显示,默认就是
-m 以MB为单位显示
-g 以GB为单位显示
缓存和缓冲的区别:
简单来说缓存(cache)是用来加速数据从硬盘中“读取”的,而缓冲(buffer)是用来加速数据“写入”硬盘的。
查看CPU信息
[root@localhost ~]# cat /proc/cpuinfo
#保存了更详细的信息。每次开机都会检测,检测后写入的文件。
dmesg | grep CPU ---看到的是自检信息。
uptime命令
[root@localhost ~]# uptime
#显示系统的启动时间和平均负载,也就是 top 命令的第一行。w 命令也可以看到这个数据。
查看系统与内核相关信息
[root@localhost ~]# uname [选项]
选项:
-a 查看系统所有相关的信息
-r 查看内核版本
-s 查看内核名称
判断当前系统的位数:
[root@localhost ~]# file /bin/ls
#file---查看文件类型,
#file查看系统的外部命令,是外部命令,不能是内部命令;看这个外部命令是什么类型,就会顺带显示系统的操作位数
查询当前Linux系统的发行版本
[root@localhost ~]# lsb_release -a
列出进程打开或使用的文件信息
[root@localhost ~]# lsof [选项]
#列出进程调用或打开的文件的信息
选项:
-c 字符串 只列出以字符串开头的进程开头的文件
-u 用户名 只列出某个用户的进程打开的文件
-p pid 列出某个PID进程打开的文件
进程管理
进程查看
进程:进程是正在执行的一个程序或命令,每一个进程都是一个运行的实体,都有自己的地址空间,并占用一定的系统资源。
正在运行中的程序。
进程管理的作用:
1、判断服务器健康状态---最主要的工作。--静态的
2、查看系统中所有进程
3、杀死进程
1、 不管是不是占用资源的进程,是不是正行进程,都不能终止了事。其实每个进程都是有正确终止的手段的,
当正常终止进程的手段时间失效的时候,再考虑去杀死进程。
2、服务器多的时候,需要搭建监控服务器,如:CACTI,AIBATIJ,类似的监控软件。
监控工具,只有当服务器的数量多的时候,人为很难控制监控,才考虑去搭建。监控工具,属于网络服务的
3、别轻易关闭杀掉进程,当正确关闭不生效的时候,再去杀死。
注意:如果发现非法进程,不可以直接在进程中直接杀,需要找到主体
查看系统中所有进程:
[root@localhost ~]# ps aux ---常见用法
#查看系统中所有进程,使用BSD操作系统格式(Unix格式)
#因为遵守的是Unix中BSD的操作格式,不需要加“-”所以选项调用不需要加“-”
#可以加“-”,虽然有警告错误,但不影响程序的正确执行,
执行后每一列的作用:
USER | 该进程是由哪个用户产生的 |
PID | 进程的ID号 |
%CPU | 该进程占用CPU资源的百分比,占用越高,进程越耗费资源 |
%MEM | 该进程占用物理内存的百分比,占用越高,进程越耗费资源 |
VSZ | 该进程占用虚拟内存的大小,单位KB |
RSS | 该进程占用实际物理内存的大小,单位KB |
TTY | 该进程实在哪个终端中运行的。其中tty1-tty7代表本地控制台终端,tty1-tty6是本地的字符界面终端,tty7是图形终端。pts/0-255代表虚拟终端。 默认支持256个远程登录终端。 |
STAT | 进程状态。常见的状态有:R:运行、 S:睡眠、T:停止状态、s:包含子进程、+:位于后台 |
START | 该进程的启动时间 |
TIME | 该进程占用CPU的运算时间,注意不是系统时间。 值越大,越耗费资源。 |
COMMAND | 产生此进程的命令名。 |
注意:CentOS6.3之所以还有init进程,是为了兼容以前的版本。
多米诺骨牌---排好一个图案,推翻第一张后面的会依次倒下
TTY:对应的列中之所以有“?”问号,是因为这些进程是由内核产生的。
[root@localhost ~]# ps -le
#查看系统中所有进程,使用Linux标准命令格式。
查看系统健康状态:
最重要的是:头5行;
[root@localhost ~]# top [选项]
选项:
-d 秒数 指定top命令每隔几秒更新。默认是3秒
在top命令的交互模式当中可以执行的命令
?或h 显示交互模式的帮助
P 以CPU使用率排序,默认就是此选项
M 以内存的使用率排序
N 以PID排序
q 退出top
第一行信息为任务队列信息
内容 | 说明 |
12:26:46 | 系统当前时间 |
up 1 day, 13:32 | 系统的运行时间,本机已运行1天13小时32分钟 三百多天多位厉害的了。 |
2 users | 当前登录了俩个用户 |
load average: 0.00,0.00,0.00 ---重要 | 系统在之前 1分钟,5分钟,15分钟的平均负载。一般认为小于1小时,负载较小。如果大于1,系统已经超出负载。 多少核可以大于几后,高负载了 |
第二行为进程信息
内容 | 说明 |
Tasks: 95 total | 系统中的进程总数 |
1 running | 正在运行的进程数 |
94 sleeping | 睡眠的进程 |
0 stopped | 正在停止的进程 |
0 zombie | 僵尸进程。如果不是0,需要手工检查僵尸进程 |
僵尸进程:这个进程正在终止,但是还没有终止完全,如果有一俩个,先不用干预,可能是服务正在停止,还没有完全停止,可以过会再看,如果还在,表明这个进程在终止的过程当中报错,卡死了,没有正确终止掉。需要手工终止。
第三行为CPU信息
内容 | 说明 |
Cpu(s): 0.1%us | 用户模式占用的CPU百分比 |
0.1%sy | 系统模式占用的CPU百分比 |
0.0%ni | 改变过优先级的用户进程占用的CPU百分比 |
99.7%id---重要 | 空闲CPU的CPU百分比---如果非常低说明服务器负载高,需要搭建集群。 |
0.1%wa | 等待输入/输出的进程的占用CPU百分比 |
0.0%hi | 硬中断请求服务占用的CPU百分比 |
0.1%si | 软中断请求服务占用的CPU百分比 |
0.0%st | st(Steal time)虚拟时间百分比。就是当有虚拟机时,虚拟CPU等待实际CPU的时间百分比 |
第四行为物理内存信息
内容 | 说明 |
Mem: 625344k total | 物理内存的总容量,单位为KB |
538405k free ---重要 | 空闲的物理内存数量,我们使用的是虚拟机,总共只分配了625MB内存,所以只有53MB的空闲内存 |
65800k buffers | 作为缓冲的内存数量 |
第五行为交换分区(swap)信息
内容 | 说明 |
Swap: 524280k total | 交换分区(虚拟内存)的总大小 |
0k used | 已经使用的交换分区的大小 |
5342580k free | 空闲交换分区的大小 |
409280k cached | 作为缓存的交换分区的大小 |
查看进程树
[root@localhost ~]# pstree [选项]
选项:
-p 显示进程的PID
-u 显示进程的所属用户
杀死进程
[root@localhost ~]# kill -l
#查看可用的进程信号
常用的代号
信号代号 | 信号名称 | 说明 |
1 | SIGHUP | 该信号让进程立即关闭,然后重新读取配置文件之后重启。 |
2 | SIGINT | 程序终止信号,用于终止前台进程。相当于输出ctrl+c快捷键 |
8 | SIGFPE | 在发生致命的算术运算错误时发生,不仅包括浮点运算错误,还包括溢出及除数为0等其他所有的算术错误。 |
9 | SIGKILL | 用来立即结束程序的运行,本信号不能被阻塞、处理和忽略。一般用于强制终止进程 |
14 | SIGALRM | 时钟定时信号,计算的是实际的时间或时钟时间,alarm函数使用该信号 |
15 | SIGTERM | 正常结束进程的信号,kill命令的默认信号。有时如果进程已经发生问题,这个信号是无法正常终止进程的,我们才会尝试SIGKILL信号,也就是信号9. |
18 | SIGCONT | 该信号可以让暂停的进程恢复执行,本信号不能被阻断。 |
19 | SIGSTOP | 该信号可以暂停前台进程,相当于输入ctrl+z快捷键。本信号不能被阻断。 |
[root@localhost ~]# kill -1 22354
#重启进程
[root@localhost ~]# kill -9 22368
#强制杀死进程
killall命令:
[root@localhost ~]# killalll [选项][信号] 进程名
#按照进程明杀死进程
#一般是 killall -9 进程名
选项:
-i 交互式,询问是否要杀死某个进程
-I 忽略进程名的大小写
pkill命令:
[root@localhost ~]# pkill [选项][信号] 进程名
#按照进程名终止进程
选项:
-t 终端号: 按照终端号踢出用户
[root@localhost ~]# w
#使用 w 命令查询本机已经登录的用户 还可以看到的是平均负载
[root@localhost ~]# pkill -t -9 pts/1
#强制杀死从 pts/1 虚拟终端登录的进程