Linux进程管理

1. 基本介绍

1.在 LINUX 中,每个执行的程序(代码)都称为一个进程。每一个进程都分配一个 ID 号
2.每一个进程,都会对应一个父进程,而这个父进程可以复制多个子进程
3.每个进程都可能以两种方式存在的。前台与后台,所谓前台进程就是用户目前的屏幕上可以进行操作的。后台进程则是实际在操作,但由于屏幕上无法看到的进程,通常使用后台方式执行
4.一般系统的服务都是以后台进程的方式存在,而且都会常驻在系统中。直到关机才才结束

2. 显示系统执行的进程

2.1 说明

查看进行使用的指令是 ps ,一般来说使用的参数是 ps -aux,ps -ef,正常与grep连用

1569499315049

1569500666120

2.2 ps指令详解

BSD风格 详解

user 			用户名称
pid				进程号
%cpu			进程占用cpu百分比
%%mem			进程占用物理内存的百分比
vsz				进程占用虚拟内存的大小
rss				进程占用物理内存的大小
tty				终端名称(后台则为?)
stat			进程状态
	S:睡眠
	s:会话的先导进程
	N:进程拥有比普通优先级更低的优先级
	R:正在运行
	D:短期等待
	Z:僵尸进程
	T:被跟踪或者被停止
start			进程启动时间
time			使用cpu总时间
command			启动进程所用的命令和参数,如果过长会被截断显示

system V 风格详解

uid 			用户id
pid				进程id
ppid			父进程id
C				进程占cpu百分比
stime			进程启动时间
tty				终端名称(后台则为?)
cmd				启动进程所用的命令和参数
# 例子:
# 1.查看sshd进程的父进程id是多少
	ps --ef | grep sshd

3. 终止进程kill和killall

3.1 说明

若是某个进程执行一半需要停止时,或是已消了很大的系统资源时,此时可以考虑停止该进程。

3.2 基本语法:

kill [选项] 进程号
# 	   -9  强迫进程立即停止
killall 进程名称

3.4 例子

# 1.踢掉某个非法登录用户
	ps -ef | grep sshd		# 查看登录用户进程
	kill 进程号			 # 终止非法登录用户进程 
# 2.终止远程登录服务sshd, 在适当时候再次重启sshd 服务
	kill sshd进程号	# /user/bash/sshd的进程号
	service sshd restart	# 重启ssh服务
# 3.终止多个 gedit 编辑器,使用killall,通过进程名称来终止进程
	killall gedit
# 4.强制杀掉一个终端
	kill -9 进程号

4. 查看进程树 pstree

pstree [选项]
#	-p    查看进程pid
# 	-u	  查看进程所属用户

5. 服务(service)管理

5.1 说明

服务(service) 本质就是进程,但是是运行在后台的,通常都会监听某个端口,等待其它程序的请求,比如(mysql , sshd 防火墙等),因此我们又称为守护进程,是
Linux 中非常重要的知识点。

1569501982809

5.2 基本使用

service 服务名 [start | stop | restart | reload | status]

5.3 例子

1.查看当前防火墙的状况,关闭防火墙和重启防火墙(iptables)

1569502178544

service这种方式关闭或者打开服务只是临时生效

重启后,还是回到以前对服务的设置

5.4 查看服务名

/etc/init.d 此文件夹下放着系统都有哪些服务

ls -l /etc/init.d

1569502573505

5.5 服务器运行级别(runlevel)

# 查看或者修改默认级别:	
vi /etc/inittab

Linux 系统有 7 种运行级别(runlevel):常用的是级别 3 和 5

运行级别 0:系统停机状态,系统默认运行级别不能设为 0,否则不能正常启动

运行级别 1:单用户工作状态,root 权限,用于系统维护,禁止远程登陆

运行级别 2:多用户状态(没有 NFS),不支持网络

运行级别 3:完全的多用户状态(有 NFS),登陆后进入控制台命令行模式

运行级别 4:系统未使用,保留

运行级别 5:X11 控制台,登陆后进入图形 GUI 模式

运行级别 6:系统正常关闭并重启,默认运行级别不能设为 6,否则不能正常启动

5.6 开机流程说明

1569503689170

5.7 chkconfig指令

  • 说明

通过 chkconfig 命令可以给每个服务的各个运行级别设置自启动/关闭

  • 基本语法
chkconfig							  # 查看每个服务的配置
chkconfig --list 服务名	  			 # 查看具体服务的配置
chkconfig 服务名 on/off      			 # 给服务设置所有运行级别下是否自动启动
chkconfig --level 5 服务名 on/off        # 给服务设置运行级别为5时是否自动启动
  • 例子
# 1.请显示当前系统所有服务的各个运行级别的运行状态
	chkconfig
# 2.请查看 sshd 服务的运行状态
	chkconfig --list sshd
# 3.将 sshd 服务在运行级别 5 下设置为不自动启动,看看有什么效果?
	chkconfig --level 5 sshd off
# 4.当运行级别为 5 时,关闭防火墙。
	chkconfig --level 5 iptables off
# 5.在所有运行级别下,关闭防火墙
	chkconfig iptables off
# 6.在所有运行级别下,开启防火墙
	chkconfig iptables on

chkconfig 重新设置服务后自启动或关闭,需要重启机器 reboot 才能生效

6. 动态监控进程

6.1 说明

top 与 ps 命令很相似。它们都用来显示正在执行的进程。top 与 ps 最大的不同之处,在于 top 在执行一段时间可以更新正在运行的的进程

6.2 基本语法

top [选项]
# 	-d			指定每隔几秒更新,默认3秒
# 	-i			不显示任何闲置或者僵尸进程
# 	-p id号		监听指定进程

# 交互操作:
# P		以cpu使用率排序,默认就这个
# M		以内存使用率排序
# N		以pid排序
# u		监听具体用户
# k		终止指定进程
# q		退出top

1569505278226

6.3 例子

# 1.监视特定用户
	# top:输入此命令,按回车键,查看执行的进程。
	# u:然后输入u回车,再输入用户名,即可
# 2.终止指定的进程
	# top:输入此命令,按回车键,查看执行的进程。
	# k:然后输入k回车,再输入要结束的进程ID号
# 3.指定系统状态更新的时间(每隔 10 秒自动更新, 默认是 3 秒)
	top -d 10

7. 监控网络状态

7.1 说明

查看系统网络情况 netstat

7.2 基本语法

netstat [选项]

# 选项说明
# -an 按一定顺序排列输
# -p 显示哪个进程在调

7.3 例子

请查看服务名为 sshd 的服务的信息。检测主机连接命令ping是一种网络检测检测工具,

它主要是用检测远程主机是否正常,或是两部主机间的介质是否为断、网线是否脱落或网卡故障。

如: ping 对方ip

img

img

posted @ 2020-01-10 16:24  油饼er  阅读(179)  评论(0编辑  收藏  举报