自己写的Linux基础笔记

工作管理---放入后台

 

把程序放入后台:

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  虚拟终端登录的进程

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值