程序:保存在硬盘、光盘等介质中的可执行代码和数据,属于静态保存的代码
进程:在CPU及内存中运行的程序代码,属于动态执行的代码
一个应用程序可以包含一个或多个进程,一个进程包含一个或多个线程,线程是执行操作的最小单元
ps:对应高并发处理===使用多线程操作
ps 命令——不是Photoshop哈!
man 手册对其作用的描述是这样的:“displays information about a selection of the active processes. If you want a repetitive update of the selection and the displayed information, use top(1) instead.”
其意思为:显示有关活动进程的选择的信息。如果希望对选择和显示的信息进行重复更新,请使用top(这里的top也是查看进程的信息的,但是是动态查看,下面会具体讲述)
ps [选项] [参数]
在man 手册上给出的案例我节选部分常用的出来进行演示和讲述:
-aux :“-”可以省略,表示查看系统中使用BSD语法规则的每个进程
-elf:表示查看系统中使用标准语法的每个进程,不能省略“-”
实例如下:
[root@lokott ~]# ps aux //ps -aux也一样
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.0 0.4 210140 4864 ? Ss 14:23 0:01 /usr/lib/systemd/systemd --switched-root --system --deserialize 21
root 2 0.0 0.0 0 0 ? S 14:23 0:00 [kthreadd]
root 3 0.0 0.0 0 0 ? S 14:23 0:00 [ksoftirqd/0]
root 5 0.0 0.0 0 0 ? S< 14:23 0:00 [kworker/0:0H]
root 6 0.0 0.0 0 0 ? S 14:23 0:00 [kworker/u256:0]
root 7 0.0 0.0 0 0 ? S 14:23 0:00 [migration/0]
root 8 0.0 0.0 0 0 ? S 14:23 0:00 [rcu_bh]
root 9 0.0 0.0 0 0 ? R 14:23 0:00 [rcu_sched]
...
解释:PID表示进程ID,%CPU表示CPU使用率,%MEM表示内存使用率,TTY表示终端,STAT表示的是状态:S 是sleep可中断,s表示父进程,<表示的是优先级高,R正在运行的进程, l表示的是多线性进程,N优先级低,Z僵尸进程,D不可中断休眠进程,+前台进程。
[root@lokott ~]# ps -elf //当前-长格式—完整形式
F S UID PID PPID C PRI NI ADDR SZ WCHAN STIME TTY TIME CMD
4 S root 1 0 0 80 0 - 52535 ep_pol 14:23 ? 00:00:01 /usr/lib/systemd/systemd --switched-root --system --deserialize 21
1 S root 2 0 0 80 0 - 0 kthrea 14:23 ? 00:00:00 [kthreadd]
1 S root 3 2 0 80 0 - 0 smpboo 14:23 ? 00:00:00 [ksoftirqd/0]
1 S root 5 2 0 60 -20 - 0 worker 14:23 ? 00:00:00 [kworker/0:0H]
1 S root 6 2 0 80 0 - 0 worker 14:23 ? 00:00:00 [kworker/u256:0]
1 S root 7 2 0 -40 - - 0 smpboo 14:23 ? 00:00:00 [migration/0]
1 S root 8 2 0 80 0 - 0 rcu_gp 14:23 ? 00:00:00 [rcu_bh]
....
解释:PPID表示父进程 PRI表示的是用户态的优先级 NI表示的是NICE值(内核),范围是(-20~19)值越低越优先
,SZ交换分区占用的空间大小
在ps命令中一般可以结合管道符号和grep等命令组合使用,提高工作效率
[root@lokott ~]# top //每三秒会自动刷新一次
top - 15:58:48 up 1:35, 3 users, load average: 0.00, 0.01, 0.05
Tasks: 190 total, 1 running, 189 sleeping, 0 stopped, 0 zombie
%Cpu(s): 0.0 us, 0.0 sy, 0.0 ni,100.0 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem : 999696 total, 65636 free, 711552 used, 222508 buff/cache
KiB Swap: 4194300 total, 4160824 free, 33476 used. 78272 avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
619 root 20 0 231608 3264 2836 S 0.3 0.3 0:03.25 vmtoolsd
4582 root 20 0 0 0 0 S 0.3 0.0 0:00.20 kworker/0:2
1 root 20 0 210140 4864 3024 S 0.0 0.5 0:01.35 systemd
2 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kthreadd
3 root 20 0 0 0 0 S 0.0 0.0 0:00.06 ksoftirqd/0
5 root 0 -20 0 0 0 S 0.0 0.0 0:00.00 kworker/0:0H
.....
在top命令下,进程的查看是动态变化的,m可以进行内存使用率排序c可以进行cpu排序,q可以退出,或者Ctrl+c直接终止该命令。
pgrep命令
在man手册中pgrep和pkill是放在一起的,如下所示:
NAME //命令名称,根据名字或者其他属性查找进程
pgrep, pkill - look up or signal processes based on name and other attributes
SYNOPSIS //表示的是命令的格式
pgrep [options] pattern
pkill [options] pattern
DESCRIPTION
pgrep looks through the currently running processes and lists the process IDs which match the selection criteria to stdout. All the criteria have to match. For example,
$ pgrep -u root sshd
will only list the processes called sshd AND owned by root. On the other hand,
$ pgrep -u root,daemon
will list the processes owned by root OR daemon.
pkill will send the specified signal (by default SIGTERM) to each process instead of listing them on stdout.
那么我就根据上面给出的例子来进行实验:(pkill下面有讲)
[root@lokott ~]# pgrep -u root sshd //仅仅列出名称为sshd且属于root的进程号
1002
2820
[root@lokott ~]# pgrep -u root,daemon |wc -l //列出属于root或者daemon的所有进程号到管道中统计数量
175
[root@lokott ~]# pgrep -l "log" //查看包含log的进程id和信息
292 xfs-log/sda2
479 xfs-log/sda5
480 xfs-log/sda1
593 abrt-watch-log
596 systemd-logind
601 rsyslogd
602 abrt-watch-log
2735 xfs-log/md0
树型查看——pstree
-aup “-”不可以省略,pstree -ap 用户名
前台启动:用户输入命令,直接执行程序
后台启动:在命令行尾加入“&”符号
进程的前后台调度
Ctrl+z——停止进程
jobs -l ——查看进程状态
fg 序号——将进程掉到前台来执行
bg 序号——将停止的进程在后台继续执行
[root@lokott ~]# umount /mnt
[root@lokott ~]# mount /dev/sr0 /mnt
mount: /dev/sr0 写保护,将以只读方式挂载
[root@lokott ~]# df -hT
文件系统 类型 容量 已用 可用 已用% 挂载点
/dev/sda2 xfs 20G 4.4G 16G 22% /
devtmpfs devtmpfs 474M 0 474M 0% /dev
tmpfs tmpfs 489M 0 489M 0% /dev/shm
tmpfs tmpfs 489M 7.2M 482M 2% /run
tmpfs tmpfs 489M 0 489M 0% /sys/fs/cgroup
/dev/sda5 xfs 10G 37M 10G 1% /home
/dev/sda1 xfs 6.0G 158M 5.9G 3% /boot
tmpfs tmpfs 98M 4.0K 98M 1% /run/user/42
tmpfs tmpfs 98M 24K 98M 1% /run/user/0
/dev/sr0 iso9660 4.3G 4.3G 0 100% /mnt
[root@lokott ~]# cd /mnt/
[root@lokott mnt]# ls
CentOS_BuildTag GPL LiveOS RPM-GPG-KEY-CentOS-7
EFI images Packages RPM-GPG-KEY-CentOS-Testing-7
EULA isolinux repodata TRANS.TBL
[root@lokott mnt]# cd
[root@lokott ~]# cp -r /mnt/Packages/ /opt/ & //&符号就是将该命令放在后台运行
[1] 5354
[root@lokott ~]# jobs -l //查看进程完成状态
[1]+ 5354 完成 cp -i -r /mnt/Packages/ /opt/
[root@lokott ~]# cp -r /mnt/Packages/ /opt/ //删除原来的然后重新再前台执行命令
^Z
[1]+ 已停止 cp -i -r /mnt/Packages/ /opt/
[root@lokott ~]# jobs -l //查看进程状态
[1]+ 5403 停止 cp -i -r /mnt/Packages/ /opt/
[root@lokott ~]# fg 1 //调出后台进程到前台来进行运行
cp -i -r /mnt/Packages/ /opt/
^Z
[1]+ 已停止 cp -i -r /mnt/Packages/ /opt/
[root@lokott ~]# kill -9 5403 //强制kill 掉进程(-9)
[root@lokott ~]# jobs -l
[1]+ 5403 已杀死 cp -i -r /mnt/Packages/ /opt/
Ctrl+c ——中断正在执行的命令
1.kill、killall命令
kill用于终止指定PID号的进程 -9 表示强制终止
killall用于终止指定名称的所有进程
上面的实例中已经给出了kill 的实例,下面看一下killall的实例:
[root@lokott ~]# vim 1.sh &
[3] 5696
[root@lokott ~]# vim 2.sh &
[4] 5697
[3]+ 已停止 vim 1.sh
[root@lokott ~]# jobs -l
[1] 5694 停止 (tty 输出) vim 1.sh
[2] 5695 停止 (tty 输出) vim 1.sh
[3]- 5696 停止 (tty 输出) vim 1.sh
[4]+ 5697 停止 (tty 输出) vim 2.sh
[root@lokott ~]# killall -9 vim
[1] 已杀死 vim 1.sh
[2] 已杀死 vim 1.sh
[3]- 已杀死 vim 1.sh
[4]+ 已杀死 vim 2.sh
[root@lokott ~]#
2.pkill命令
根据特定条件终止相应的进程——pkill命令(实际上用的非常多)
-U:根据进程所属的用户名终止相应进程
-t:根据进程所在的终端终止相应进程
[root@lokott ~]# pgrep -l -U "zhangsan"
1472 gnome-keyring-d
1491 gnome-session-b
1498 dbus-launch
1499 dbus-daemon
1557 gvfsd
1562 gvfsd-fuse
1649 ssh-agent
1668 at-spi-bus-laun
1673 dbus-daemon
1678 at-spi2-registr
1695 gnome-shell
.......
2208 gvfsd-metadata
2211 ibus-engine-sim
[root@lokott ~]# pkill -9 -U zhangsan //前台是本地是张三登录的状态此时服务器那边会将zhangsan用户踢出,然后到登录界面
小结:普通用户是无法用pkill命令踢出root,但可以用pgrep查看
命令格式——at [HH:MM] [yyyy-mm-dd]
注意:这个命令是必须将时间用在之后的时间,例如:at 10:33 2020-08-05
然后输入命令,最后Ctrl+D
date命令——获取当前时间
atq——查看准备被执行的进程列表
atrm 2——删除
请看实例:
[root@lokott ~]# date //显示当前时间
2019年 11月 12日 星期二 17:28:24 CST
[root@lokott ~]# at 17:35 2019-11-12 //设定计划任务
at> pgrep -U root |wc -l > /opt/ps.txt
at> <EOT>
job 1 at Tue Nov 12 17:35:00 2019
[root@lokott ~]# cat /opt/ps.txt //由于时间未到所有没法看到
cat: /opt/ps.txt: 没有那个文件或目录
[root@lokott ~]# atq
1 Tue Nov 12 17:35:00 2019 a root
[root@lokott ~]# at 17:34 2019-11-12
at> echo "123" > 1.txt
at> <EOT>
job 2 at Tue Nov 12 17:34:00 2019
[root@lokott ~]# atq //查看一次性任务命令
1 Tue Nov 12 17:35:00 2019 a root
2 Tue Nov 12 17:34:00 2019 a root
[root@lokott ~]# ls
1.txt note 模板 文档 桌面
anaconda-ks.cfg shell 视频 下载
initial-setup-ks.cfg 公共 图片 音乐
[root@lokott ~]# cat 1.txt
123
[root@lokott ~]# atrm 1 //删除还未执行的任务
[root@lokott ~]# atq
[root@lokott ~]# atrm 1 //已删除和已经完成的任务无法再次删除
Cannot find jobid 1
该序列号是固定的,而不是动态的,这是为了避免多终端时大家删除任务的时候误删
crontab命令(重要)——定时任务(按照预先设置的时间周期重复执行用户指定的命令操作),man手册上的介绍是:crontab - maintains crontab files for individual users
编写格式为分 时 日 月 周 命令,下面的/etc/crontab文件中有显示写入格式
其中*表示该范围内的任意时间,-表示连续的时间
,表示不连续的时间点,/表示频率
对于该命令,我的理解就是——“私人订制”,这个命令可以用来存储一个定时任务制表文件,可以用来对周期性定时任务的设置(-e)删除(-r)和查看(-l)等操作,实例如下:
[root@lokott ~]# which crontab //查看crontab命令的位置
/usr/bin/crontab
[root@lokott ~]# cat /etc/crontab //查看命令的配置文件信息
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
# For details see man 4 crontabs //文件写入格式为——分 时 日 月 周
# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed
[root@lokott ~]# crontab -e //打开一个交互窗口写入命令,命令在下面用-l参数可以显示
no crontab for zhangsan - using an empty one
crontab: installing new crontab
[root@lokott ~]# crontab -l //显示写入的命令代码,表示每分钟写入一次12346
* * * * * echo "12346" >> 1.txt
[root@lokott ~]# cat 1.txt
hello
hello
[root@lokott ~]# cat 1.txt
hello
hello
12346
12346
12346
主要的设置文件位置:
[root@lokott ~]# ls /etc/cron.*/
/etc/cron.d/:
0hourly raid-check sysstat
/etc/cron.daily/:
logrotate man-db.cron mlocate
/etc/cron.hourly/:
0anacron
/etc/cron.monthly/:
/etc/cron.weekly/:
[root@lokott ~]# su - zhangsan
[zhangsan@lokott ~]$ crontab -l
5 10 * * 1-5 echo "haha" > 1.txt //周一至周五10:05执行命令
6 10 * * 2,4,6 echo "ttuu" >> 1.txt //周二、四、六的10:06执行命令
10 10-14/2 * * * echo "sdas" >> 1.txt //每天的10点10分至14点10分每两小时执行一次命令
*/5 * */2 * * ls ./shell //每隔两天,每隔5分钟执行命令
[root@lokott zhangsan]# cat /var/spool/cron/zhangsan //用户定义的设置在该文件中
5 10 * * 1-5 echo "haha" > 1.txt
6 10 * * 2,4,6 echo "ttuu" >> 1.txt
10 10-14/2 * * * echo "sdas" >> 1.txt
*/5 * */2 * * ls ./shell
*/1 * * * * echo "sdsad" >> 1.txt
[zhangsan@lokott ~]$ crontab -e //我准备添加新的计划任务
crontab: installing new crontab
您在 /var/spool/mail/zhangsan 中有新邮件 //提示我有新的内容,其实就是报错的信息,信息如下所示
[zhangsan@lokott ~]$ cat /var/spool/mail/zhangsan
From zhangsan@lokott.localdomain Wed Nov 13 10:05:02 2019
Return-Path: <zhangsan@lokott.localdomain>
X-Original-To: zhangsan
Delivered-To: zhangsan@lokott.localdomain
Received: by lokott.localdomain (Postfix, from userid 1001)
id 04DC131C6EDF; Wed, 13 Nov 2019 10:05:01 +0800 (CST)
From: "(Cron Daemon)" <zhangsan@lokott.localdomain>
To: zhangsan@lokott.localdomain
Subject: Cron <zhangsan@lokott> ls ./shell
Content-Type: text/plain; charset=UTF-8
Auto-Submitted: auto-generated
Precedence: bulk
X-Cron-Env: <XDG_SESSION_ID=149>
X-Cron-Env: <XDG_RUNTIME_DIR=/run/user/1001>
X-Cron-Env: <LANG=zh_CN.UTF-8>
X-Cron-Env: <SHELL=/bin/sh>
X-Cron-Env: <HOME=/home/zhangsan>
X-Cron-Env: <PATH=/usr/bin:/bin>
X-Cron-Env: <LOGNAME=zhangsan>
X-Cron-Env: <USER=zhangsan>
Message-Id: <20191113020502.04DC131C6EDF@lokott.localdomain>
Date: Wed, 13 Nov 2019 10:05:01 +0800 (CST)
本文主要是对Linux中进程和计划任务的管理的介绍和命令演示,包括静态查看(ps)和动态查看(top)进程命令,按条件查看(pgrep)和以树型结构查看(pstree);其次是对进程控制的介绍,包括启动进程,调度进程(Ctrl+Z、jobs、fg、bg)以及终止进程的命令(kill、killall、pkill);最后是对计划任务设置命令的介绍,即at和crontab命令,其中注意at是一次性有效,且需要在当前时间(date命令查看当前时间)之后,有年份设置,而crontab命令是计划性周期命令,没有年份的设置。
最后感谢阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。