×

linux linux命令 linux进程 进程 linux定时任务 linux服务

从零学习大数据,第四节,进程线程,服务管理,定时任务。

我的笔记 我的笔记 发表于2018-10-24 21:20:33 浏览3199 评论0

抢沙发发表评论

1、进程线程

(1)、查看系统中所有进程

    语法:

ps –aux          (功能描述:查看系统中所有进程)

  功能说明:

       USER:该进程是由哪个用户产生的

       PID:进程的ID

%CPU:该进程占用CPU资源的百分比,占用越高,进程越耗费资源;

%MEM:该进程占用物理内存的百分比,占用越高,进程越耗费资源;

VSZ:该进程占用虚拟内存的大小,单位KB

RSS:该进程占用实际物理内存的大小,单位KB

TTY:该进程是在哪个终端中运行的。其中tty1-tty7代表本地控制台终端,tty1-tty6是本地的字符界面终端,tty7是图形终端。pts/0-255代表虚拟终端。

STAT:进程状态。常见的状态有:R:运行、S:睡眠、T:停止状态、s:包含子进程、+:位于后台

START:该进程的启动时间

TIME:该进程占用CPU的运算时间,注意不是系统时间

COMMAND:产生此进程的命令名

    

    eg:

[root@hadoop102 datas]# ps –aux

clip_image002.jpg


(2)、查看系统健康状态

    语法:

top [选项]

  选项:

              -d 秒数:指定top命令每隔几秒更新。默认是3秒在top命令的交互模式当中可以执行的命令:

-i:使top不显示任何闲置或者僵死进程。

-p:通过指定监控进程ID来仅仅监控某个进程的状态。

-s  使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。

  操作选项:(就是在top进程直接按所对应按键)

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

空闲CPUCPU百分比

0.1%wa

等待输入/输出的进程的占用CPU百分比

0.0%hi

硬中断请求服务占用的CPU百分比

0.1%si

软中断请求服务占用的CPU百分比

0.0%st

stSteal  time)虚拟时间百分比。就是当有虚拟机时,虚拟CPU等待实际CPU的时间百分比。

第四行为物理内存信息

Mem:      625344k total

物理内存的总量,单位KB

571504k used

已经使用的物理内存数量

53840k free

空闲的物理内存数量,我们使用的是虚拟机,总共只分配了628MB内存,所以只有53MB的空闲内存了

65800k buffers

作为缓冲的内存数量

第五行为交换分区(swap)信息

Swap:     524280k total

交换分区(虚拟内存)的总大小

0k used

已经使用的交互分区的大小

524280k free

空闲交换分区的大小

409280k cached

作为缓存的交互分区的大小


    eg:执行以下命令后,可以按PMN对查询出的进程结果进行排序

[root@hadoop101 root]# top –d 1
[root@hadoop101 root]# top -i
[root@hadoop101 root]# top –p 2575
[root@hadoop101 root]# top –s


(3)、查看进程树

    语法:

pstree [选项]

  选项:

        -p:  显示进程的PID 

         -u:  显示进程的所属用户

    eg:

[root@hadoop102 datas]# pstree -u
[root@hadoop102 datas]# pstree -p

(4)、终止进程

    语法:(-9 表示强迫进程立即停止)

kill -9 pid进程号

    eg:

[root@hadoop102 桌面]# kill -9 5102

(5)、显示网络统计信息

    语法:

netstat –anp		(功能描述:此命令用来显示整个系统目前的网络情况。例如目前的连接、数据包传递数据、或是路由表内容)

    eg: 查看端口50070的使用情况

 [root@hadoop106 hadoop-2.7.2]# netstat -anp | grep 50070

2、服务管理

(1)、查看指定服务的状态

    语法:

service 服务名称 status

    eg:

 [root@hadoop106 root]# service network status

(2)、停止指定服务

    语法:

service 服务名称 stop

    eg: 

 [root@hadoop106 root]# service network stop

(3)、启动指定服务

    语法:

service 服务名称 start

    eg:

 [root@hadoop106 root]# service network start

(4)、重启指定服务

    语法:

service 服务名称 restart

    eg: 

 [root@hadoop106 root]# service network restart

(5)、查看系统中所有的后台服务

    语法:

service --status-all

    eg: 

 [root@hadoop106 root]# service --status-all

(6)、查看所有服务器自启配置

    语法:

chkconfig   			

    eg: 

 [root@hadoop106 root]#chkconfig   			

(7)、关掉指定服务的自动启动

    语法:

chkconfig 服务名称 off

    eg: 

 [root@hadoop106 root]#chkconfig iptables off

(8)、开启指定服务的自动启动

    语法:

chkconfig 服务名称 on

    eg: 

[root@hadoop106 root]#chkconfig iptables on

3、定时任务

(1)、重启定时任务服务

    语法:

service crond restart 			(重新启动服务)

    eg: 

[root@localhost ~]# service crond restart

(2)、定时任务

    语法:

crontab [选项]

选项:

  -e    编辑crontab定时任务

  -l    查询crontab任务

  -r    删除当前用户所有的crontab任务

   参数说明

1)进入crontab编辑界面。会打开vim编辑你的工作。

* * * * * 执行的任务

项目 

含义 

范围

第一个“*

一小时当中的第几分钟

0-59

第二个“*

一天当中的第几小时

0-23

第三个“*

一个月当中的第几天

1-31

第四个“*

一年当中的第几月

1-12

第五个“*

一周当中的星期几

0-707都代表星期日)

2)特殊符号

特殊符号

含义

*

代表任何时间。比如第一个“*”就代表一小时中每分钟都执行一次的意思。

代表不连续的时间。比如“0   8,12,16 * * * 命令”,就代表在每天的80分,120分,160分都执行一次命令

-

代表连续的时间范围。比如“0 5  *  *    1-6命令”,代表在周一到周六的凌晨50分执行命令

*/n

代表每隔多久执行一次。比如“*/10  *  *    *  *  命令”,代表每隔10分钟就执行一遍命令

3)特定时间执行命令

时间 

含义

45 22 * * * 命令

2245分执行命令

0 17 * * 1 命令

每周1 170分执行命令

0 5 1,15 * * 命令

每月1号和15号的凌晨50分执行命令

40 4 * * 1-5 命令

每周一到周五的凌晨440分执行命令

*/10 4 * * * 命令

每天的凌晨4点,每隔10分钟执行一次命令

0 0 1,15 * 1 命令

每月1号和15号,每周100分都会执行命令。注意:星期几和几号最好不要同时出现,因为他们定义的都是天。非常容易让管理员混乱。

     eg: 

[root@localhost ~]# crontab -e

image.png

image.png

我的笔记博客版权我的笔记博客版权