Linux 系统管理

目录

1 进程管理

1.1 进程查看

1.1.1 进程简介

1.1.2 进程管理的作用

1.1.3 查看系统中所有进程

1.1.4 查看系统健康状态

1.1.5 查看进程树

1.2 终止进程

1.2.1 kill命令

1.2.2 killall命令

1.2.3 pkill命令

2 工作管理

2.1 把程序放入后台

2.2 查看后台的工作

2.3 将后台暂停的工作恢复到前台执行

2.4 把后台暂停的工作恢复到后台执行

3 系统资源查看

3.1 vmstat命令监控系统资源

3.2 dmesg开机时内核检测信息

3.3 free命令查看内存使用状态

3.4 查看CPU信息

3.5 uptime命令

3.6 uname命令

3.7 判断当前系统的位数

3.8 查询当前Linux系统的发行版本

3.9 列出进程打开或使用的文件信息

4 系统定时任务

4.1 crond服务管理与访问控制

4.2 用户的crontab设置


1 进程管理

1.1 进程查看

1.1.1 进程简介

进程是正在执行的一个程序或命令,每一个进程都是一个运行的实体,都有自己的地址空间,并占用一定的系统资源。

1.1.2 进程管理的作用

  • 判断服务器健康状态

  • 查看系统中所有进程

  • 杀死进程

1.1.3 查看系统中所有进程

命令1: 

ps aux    # 查看系统中所有进程,使用BSD操作系统格式

字段说明

  • USER:该进程是由哪个用户产生的;
  • PID:进程的ID号;

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

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

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

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

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

  • STAT:进程状态。常见的状态有:

    • R:运行

    • S:睡眠

    • T:停止状态

    • s:包含子进程

    • +:位于后台

  • START:该进程的启动时间

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

  • COMMAND:产生此进程的命令名

命令2:

ps -le    # 查看系统中所有进程,使用Linux标准命令格式。

ps aux 和 ps -ef 区别

两者没太大差别,讨论这个问题,要追溯到Unix系统中的两种风格,System V风格和BSD 风格,ps aux最初用到Unix Style中,而ps -ef被用在System V Style中,两者输出略有不同。现在的大部分Linux系统都是可以同时使用这两种方式的。

其中各列的内容意思如下:

  • UID    //用户ID、但输出的是用户名 
  • PID    //进程的ID 
  • PPID    //父进程ID 
  • C      //进程占用CPU的百分比 
  • STIME  //进程启动到现在的时间 
  • TTY    //该进程在那个终端上运行,若与终端无关,则显示? 若为pts/0等,则表示由网络连接主机进程。 
  • CMD    //命令的名称和参数

1.1.4 查看系统健康状态

命令格式:top [ 选项]

选项:

  • - d 秒数: 指定top命令每隔几秒更新。默认是3秒

在top命令的交互模式当中可以执行的命令:

  • ?或h: 显示交互模式的帮助
  • P: 以CPU使用率排序,默认就是此项
  • M: 以内存的使用率排序
  • N: 以PID排序
  • q: 退出top

第一行信息为任务队列信息 [重点关注load average]

内容

说明

10:08:22

系统当前时间

up    7:21

系统的运行时间,本机已经运行0天7小时21分钟

4 users

当前登录了4个用户

load average: 0.01, 0.08, 0.13

系统在之前1分钟,5分钟,15分钟 的平均负载。一般认为小于1时,负载较小。如果大于1,系统已经超出负荷。

第二行为进程信息

内容

说明

Tasks: 232 total

系统中的进程总数

1 running

正在运行的进程数

231 sleeping

睡眠的进程

0 stopped

正在停止的进程

0 zombie

僵尸进程。如果不是0,需要手工检查僵尸进程

第三行为CPU信息 [重点关注 id(空闲cpu百分比)]

内容

说明

%Cpu(s): 0.4 us

用户模式占用的CPU百分比

0.4 sy

系统模式占用的CPU百分比

0.0 ni

改变过优先级的用户进程占用的CPU百分比

98.8 id

空闲CPU的CPU百分比

0.2 wa

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

0.0 hi

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

0.2 si

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

0.0 st

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

第四行为物理内存信息 [重点关注free]

内容

说明

KiB Mem: 3861508 total

物理内存的总量,单位KB

3394776 used

已经使用的物理内存数量

103764 free

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

362968 buff/cache

作为缓冲的内存数量

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

内容

说明

KiB Swap: 2097148 total

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

1901404  used

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

195744 free

空闲交换分区的大小

130800 avail Mem

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

1.1.5 查看进程树

命令格式:pstree [选项]

选项:

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

1.2 终止进程

1.2.1 kill命令

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快捷键。本信号不能被阻断。

常用命令

kill -1 22354    # 重启进程

kill -9 22368    # 强制杀死进程

1.2.2 killall命令

按照进程名杀死进程

命令格式:killall [ 选项][信号] 进程名

选项:

  • - i : 交互式,询问是否要杀死某个进程
  • - I : 忽略进程名的大小写

1.2.3 pkill命令

按照进程名终止进程

命令格式:pkill [ 选项] [信号] 进程名

选项:

  • - t 终端号: 按照终端号踢出用户

常用命令:按照终端号踢出用户

w    # 使用w命令查询本机已经登录的用户

pkill -t -9 pts/1    # 强制杀死从pts/1虚拟终端登录的进程

2 工作管理

2.1 把程序放入后台

方法1:在命令后边加“&”

  • tar -zcf etc.tar.gz /etc & [程序在后台运行]

方法2:在命令执行的过程中,按下ctrl+z快捷键

  • top    # 按下ctrl+z快捷键 [程序暂停,除非恢复]

2.2 查看后台的工作

命令格式:jobs [-l]

选项:

  • -l:显示工作的PID

小贴士:

"+"号表示最近一个放入后台的工作,也是工作恢复时,默认恢复的工作。

"-"号代表倒数第二个放入后台的工作

2.3 将后台暂停的工作恢复到前台执行

命令格式:fg %工作号

参数:

  • %工作号:%号可以省略,但是注意工作号和PID的区别

2.4 把后台暂停的工作恢复到后台执行

命令格式:bg %工作号

小贴士:

后台恢复执行的命令,是不能和前台有交互的,否则不能恢复到后台执行。

即:命令和前台有交互是不能恢复到后台运行。例如:top

3 系统资源查看

3.1 vmstat命令监控系统资源

命令格式:vmstat [刷新延时 刷新次数]

常用命令:

vmstat 1 3

3.2 dmesg开机时内核检测信息

常用命令

dmesg

dmesg | grep CPU

3.3 free命令查看内存使用状态

命令格式:free [-b|-k|-m|-g]

选项:

  • -b: 以字节为单位显示
  • -k: 以KB为单位显示,默认就是以 KB为单位显示
  • -m: 以MB为单位显示
  • -g: 以GB为单位显示

缓存和缓冲的区别

简单来说缓存(cache)是用来加速数据从硬盘中“读取”的,而缓冲(buffer)是用来加速数据“写入”硬盘的。

小贴士:向硬盘写入数据的时候,先存在缓冲中,达到一定规模,写入到硬盘,减少写入写出操作。

3.4 查看CPU信息

命令:cat /proc/cpuinfo

3.5 uptime命令

显示系统的启动时间和平均负载,也就是top命令的第一行。w命令也可以看到这个数据。

3.6 uname命令

查看系统与内核相关信息

命令格式:uname [选项]

选项:

  • -a: 查看系统所有相关信息;
  • -r: 查看内核版本;
  • -s: 查看内核名称。

3.7 判断当前系统的位数

命令:file /bin/ls

3.8 查询当前Linux系统的发行版本

命令:lsb_release -a

小贴士:

 

使用yum安装这个包:yum install -y redhat-lsb 

3.9 列出进程打开或使用的文件信息

列出进程调用或打开的文件的信息

命令格式:lsof [ 选项]

选项:

  • - c 字符串: 只列出以字符串开头的进程打开的文件
  • - u 用户名: 只列出某个用户的进程打开的文 件
  • - p pid : 列出某个PID进程打开的文件

4 系统定时任务

4.1 crond服务管理与访问控制

启动命令

service crond restart

自启动命令

chkconfig crond on

4.2 用户的crontab设置

命令格式:crontab [选项]

选项:

  • -e: 编辑crontab定时任务
  • -l: 查询crontab任务
  • -r: 删除当前用户所有的crontab任务

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

crontab -e

其中*号代表

项目

含义

范围

第一个“*”

一小时当中的第几分钟

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分钟就执行一遍命令

常用定时任务:

时间

含义

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分都会 执行命令。注意:星期几和几号最好 不要同时出现,因为他们定义的都是 天。非常容易让管理员混乱。

注意:在crontab -e 编辑下 %有特殊含义,所以就应该加转义符

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值