🗺️博客地图
1. date命令
显示或设定系统的日期与时间。
- 命令参数
-d< 字符串 >: 显示字符串所指的日期与时间,字符串前后必须加上双引号-s< 字符串 >:根据字符串来设置日期与时间,字符串前后必须加上双引号-u: 显示 GMT%H: 小时 ( 00-23)%I: 小时 (00-12)%M: 分钟 (以 00-59 来表示 )%s: 总秒数,起算时间为 1970-01-01 00:00:00 UTC%S: 秒 ( 以本地的惯用法来表示)%a: 星期的缩写%A: 星期的完整名称%d: 日期 ( 以 01-31 来表示 )%D: 日期 ( 含年月日 )%m: 月份 ( 以01-12来表示 )%y: 年份 ( 以 00-99 来表示 )%Y: 年份 ( 以四位数来表示 )
- 实例
① 显示下一天的日期
date +%Y%m%d --date="+1 day"
② -d参数使用
#今年的11月22日
date -d "nov 22"
#2周后的日期
date -d '2 weeks'
#下周一的日期
date -d 'next monday'
#明天的日期
date -d next-day +%Y%m%d
或者
date -d tomorrow +%Y%m%d
#昨天的日期
date -d last-day +%Y%m%d
或者
date -d yesterday +%Y%m%d
#上个月是几月
date -d last-month +%Y%m
#下个月是几月
date -d next-month +%Y%m
2. free 命令
显示系统内存使用情况,包括物理内存、交互区内存(swap)和内核缓冲区内存。
- 命令参数
-b:以Byte显示内存使用情况-k:以kb为单位显示内存使用情况-m:以mb为单位显示内存使用情况-g:以gb为单位显示内存使用情况-h:使输出转化为可读的格式-s <间隔秒数>:持续显示内存-t:显示内存使用总和
- 实例
① 显示内存使用情况
free -k
或
free -m
或
free -h
② 以总和的形式显示内存的使用信息
free -t
③ 周期性查询内存使用情况
free -s 10
3. ps 命令
ps(process status),用来查看当前运行的进程状态,一次性查看,如果需要动态连续结果使用 top。
linux上进程有5种状态:
1. 运行(正在运行或在运行队列中等待)
2. 中断(休眠中, 受阻, 在等待某个条件的形成或接受到信号)
3. 不可中断(收到信号不唤醒和不可运行, 进程必须等待直到有中断发生)
4. 僵死(进程已终止, 但进程描述符存在, 直到父进程调用wait4()系统调用后释放)
5. 停止(进程收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU信号后停止运行运行)
ps 工具标识进程的5种状态码:
D:不可中断 uninterruptible sleep (usually IO)
R:运行 runnable (on run queue)
S:中断 sleeping
T:停止 traced or stopped
Z:僵死 a defunct (”zombie”) process
- 命令参数
-A:显示所有进程
-a:显示同一终端下所有进程
-c:显示进程真实名称
-e:显示环境变量
-f:显示进程间的关系
-r:显示当前终端运行的进程
-aux:显示所有包含其它使用的进程
- 示例
① 显示当前所有进程环境变量及进程间关系
ps -ef
② 显示当前所有进程
ps -A
③ 与grep联用查找某进程
ps -aux | grep apache
④ 找出与 cron 与 syslog 这两个服务有关的 PID 号码
ps aux | grep '(cron|syslog)'
4. kill 命令
发送指定的信号到相应进程。不指定型号将发送SIGTERM(15)终止指定进程。如果任无法终止该程序,可用"-KILL" 参数,其发送的信号为SIGKILL(9),将强制结束进程,使用ps命令或者jobs 命令可以查看进程号。root用户将影响用户的进程,非root用户只能影响自己的进程。
- 常用参数
-l:信号,若果不加信号的编号参数,则使用 -l 参数会列出全部的信号名称
-a:当处理当前进程时,不限 制命令名和进程号的对应关系
-p:指定kill 命令只打印相关进程的进程号,而不发送任何信号
-s:指定发送信号
-u:指定用户
- 示例
使用ps查找nginx进程后用kill杀掉
kill -9 $(ps -ef | grep nginx)
5. rpm 命令
rpm 命令用于管理套件。rpm(redhat package manager) 原本是 Red Hat Linux 发行版专门用来管理 Linux 各项套件的程序,由于它遵循 GPL 规则且功能强大方便,因而广受欢迎。逐渐受到其他发行版的采用。RPM 套件管理方式的出现,让 Linux 易于安装、升级,间接提升了 Linux 的适用度。
- 示例
① 查看系统自带jdk版本信息
rpm -qa | grep jdk
② 删除系统自带jdk
rpm -e --nodeps java-1.7.0-openjdk-headless-1.7.0.75-2.5.4.2.el7.x86_64
③ 安装jdk
rpm -ivh jdk-7u80-linux-x64.rpm
6. top 命令
显示当前系统正在执行的进程的相关信息,包括进程 ID、内存占用率、CPU 占用率等。
- 常用参数
-c:显示完整的进程命令
-s:保密模式
-p:指定进程显示
-n: 循环显示次数
- 示例
[root@localhost ~]# top
top - 14:06:23 up 70 days, 16:44, 2 user, load average: 1.15, 1.42, 1.44
Tasks: 206 total, 1 running, 205 sleeping, 0 stopped, 0 zombie
%Cpu(s): 5.9 us, 3.4 sy, 0.0 ni, 90.4 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem : 4026156 total, 3649340 free, 273556 used, 103260 buff/cache
KiB Swap: 52428796 total, 52428796 free, 0 used. 3574424 avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
30 root 20 0 0 0 0 S 0.3 0.0 0:00.16 kworker/0:1
前五行是当前系统情况整体的统计信息区:
- 第一行,任务队列信息,同 uptime 命令的执行结果,具体参数说明情况如下:
14:06:23 — 当前系统时间
up 70 days, 16:44 — 系统已经运行了70天16小时44分钟(在这期间系统没有重启过哦)
2 users — 当前有2个用户登录系统
load average: 1.15, 1.42, 1.44 — load average后面的三个数分别是1分钟、5分钟、15分钟的负载情况。load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。
- 第二行:
Tasks — 任务(进程),具体信息说明如下:系统现在共有206个进程,其中处于运行中的有1个,205个在休眠(sleep),stoped状态的有0个, zombie状态(僵尸进程)有0个。
- 第三行,cpu状态信息,具体属性说明如下:
5.9 us — 用户空间占用CPU的百分比。
3.4 sy — 内核空间占用CPU的百分比。
0.0 ni — 改变过优先级的进程占用CPU的百分比
90.4 id — 空闲CPU百分比
0.0 wa — IO等待占用CPU的百分比
0.0 hi — 硬中断(Hardware IRQ)占用CPU的百分比
0.0 si — 软中断(Software Interrupts)占用CPU的百分比
0.0 st — 虚拟机偷取的时间。一台物理是可以虚拟化出多台虚拟机,在其中一台虚拟机上用top查看发现st不为0,就说明本来有这么多个cpu时间是安排给我这个虚拟机的,但是由于某种虚拟技术,把这个cpu时间分配给了其他的虚拟机了,这就叫做偷取。
注意:在这里CPU的使用比率和windows概念不同,需要理解linux系统用户空间和内核空间相关理论。
- 第四行,内存状态,具体信息如下:
KiB Mem : 4026156 total, 3649340 free, 273556 used, 103260 buff/cache
4026156 total — 物理内存总量
3649340 free — 使用中的内存总量
273556 used — 空闲内存总量
103260 buff/cache — 缓存的内存量
buff/cached 代表了buff和cache总共用了多少,buff代表buffer cache占了多少空间,由于它主要用来缓存磁盘上文件的元数据,所以一般都比较小,跟cache比可以忽略不计;cache代表page cache和其它一些占用空间比较小且大小比较固定的cache的总和,基本上cache就约等于page cache,page cache的准确值可以通过查看/proc/meminf中的Cached得到。由于page cache是用来缓存磁盘上文件内容的,所以占有空间很大,Linux一般会尽可能多的将空闲物理内存用于page cache
- 第五行,swap交换分区信息,具体信息说明如下:
KiB Swap: 52428796 total, 52428796 free, 0 used. 3574424 avail Mem
32764556k total — 交换区总量
52428796 free — 空闲交换区总量
0 used — 使用的交换区总量
3574424 avail Mem — 可用于进程下一次分配的物理内存数量
- 第六行,空行
- 第七行以下:各进程(任务)的状态监控,项目列信息说明如下:
PID — 进程id
USER — 进程所有者
PR — 进程优先级
NI — nice值,负值表示高优先级,正值表示低优先级
VIRT — 进程使用的虚拟内存总量,单位kb
VIRT=SWAP+RESRES — 进程使用的、未被换出的物理内存大小,单位kb
RES=CODE+DATASHR — 共享内存大小,单位kb
S — 进程状态
- D=不可中断的睡眠状态
- R=运行
- S=睡眠
- T=跟踪/停止
- Z=僵尸进程
%CPU — 上次更新到现在的CPU时间占用百分比
%MEM — 进程使用的物理内存百分比
TIME+ — 进程使用的CPU时间总计,单位1/100秒
COMMAND — 进程名称(命令名/命令行)
- top 交互命令
h:显示top交互命令帮助信息
c:切换显示命令名称和完整命令行
m:以内存使用率排序
P:根据CPU使用百分比大小进行排序
T:根据时间/累计时间进行排序
W:将当前设置写入~/.toprc文件中
o或者O:改变显示项目的顺序
7. yum 命令
yum( Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器。基於RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软体包,无须繁琐地一次次下载、安装。yum提供了查找、安装、删除某一个、一组甚至全部软件包的命令,而且命令简洁而又好记。
- 列出所有可更新的软件清单命令:yum check-update
- 更新所有软件命令:yum update
- 仅安装指定的软件命令:yum install <package_name>
- 仅更新指定的软件命令:yum update <package_name>
- 列出所有可安裝的软件清单命令:yum list
- 删除软件包命令:yum remove <package_name>
- 查找软件包 命令:yum search
- 清除缓存命令:
yum clean packages:清除缓存目录下的软件包
yum clean headers:清除缓存目录下的 headers
yum clean oldheaders:清除缓存目录下旧的 headers
yum clean, yum clean all (= yum clean packages; yum clean oldheaders):清除缓存目录下的软件包及旧的headers
- 示例
安装 pam-devel
[root@www ~]# yum install pam-devel