热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

linux常用命令服务/内存/进程/磁盘/挂载【service/free/top/df/mount】

服务service:用于运行SystemVinit脚本,这些脚本一般位于etcinit.d文件下,这个命令可以直接运行这个文件夹里面的脚本,而不用加上路径1、查看所有服务状态ser

 服务 service:用于运行System V init脚本,这些脚本一般位于/etc/init.d文件下,这个命令可以直接运行这个文件夹里面的脚本,而不用加上路径

 1、查看所有服务状态

 service --status-all


 2、查看指定服务的状态

 service status


 3、打印指定服务的命令行帮助

 service


 4、启动指定的系统服务

 service start


 5、停止指定的系统服务

 service stop


 6、重启指定的系统服务,即先停止(stop),然后在启动(start)

 service restart


 7、查看系统服务列表,以及每个服务的运行级别

 chkconfig --list


 8、设置指定的服务开机时 自动启动/不自动启动

 chkconfig on / off


 free:这个命令用于显示系统当前内存的使用情况,包括已用内存、可用内存和交换内存的情况

 1、以g为单位输出内存的使用量,-g为GB,-m为MB,-k为KB,-b为字节

 free -g


 2、显示内存的使用情况

 free


 3、以总和的形式显示内存的使用情况

 free -t


 4、每10秒执行一次命令

 free -s 10


 5、显示版本信息

 free -V


 top:显示当前系统中占用资源最多的一些进程

 1、top参数详解

 技术分享图片

 

 



  •  第一行,任务队列信息,同 uptime 命令的执行结果

    系统时间:07:27:05

    运行时间:up 1:57 min,

    当前登录用户:  3 user

    负载均衡(uptime)  load average: 0.00, 0.00, 0.00

         average后面的三个数分别是1分钟、5分钟、15分钟的负载情况。

    load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了



  • 第二行,Tasks — 任务(进程)

    总进程:150 total, 运行:1 running, 休眠:149 sleeping, 停止: 0 stopped, 僵尸进程: 0 zombie



  • 第三行,cpu状态信息

    0.0%us【user space】— 用户空间占用CPU的百分比。

    0.3%sy【sysctl】— 内核空间占用CPU的百分比。

    0.0%ni【】— 改变过优先级的进程占用CPU的百分比

    99.7%id【idolt】— 空闲CPU百分比

    0.0%wa【wait】— IO等待占用CPU的百分比

    0.0%hi【Hardware IRQ】— 硬中断占用CPU的百分比

    0.0%si【Software Interrupts】— 软中断占用CPU的百分比



  • 第四行,内存状态

    1003020k total,   234464k used,   777824k free,    24084k buffers【缓存的内存量】



  • 第五行,swap交换分区信息

    2031612k total,      536k used,  2031076k free,   505864k cached【缓冲的交换区总量】



  • 备注:

    可用内存=free + buffer + cached

    对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。

    第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,

    第四行中空闲内存总量(free)是内核还未纳入其管控范围的数量。

    纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。



  • 第六行,空行



  • 第七行以下:各进程(任务)的状态监控



    PID — 进程id
    USER — 进程所有者
    PR — 进程优先级
    NI — nice值。负值表示高优先级,正值表示低优先级
    VIRT — 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
    RES — 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
    SHR — 共享内存大小,单位kb
    S —进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程
    %CPU — 上次更新到现在的CPU时间占用百分比
    %MEM — 进程使用的物理内存百分比
    TIME+ — 进程使用的CPU时间总计,单位1/100秒
    COMMAND — 进程名称(命令名/命令行)



  • 详解

    VIRT:virtual memory usage 虚拟内存
      1、进程“需要的”虚拟内存大小,包括进程使用的库、代码、数据等
      2、假如进程申请100m的内存,但实际只使用了10m,那么它会增长100m,而不是实际的使用量

    RES:resident memory usage 常驻内存
      1、进程当前使用的内存大小,但不包括swap out
      2、包含其他进程的共享
      3、如果申请100m的内存,实际使用10m,它只增长10m,与VIRT相反
      4、关于库占用内存的情况,它只统计加载的库文件所占内存大小

    SHR:shared memory 共享内存
      1、除了自身进程的共享内存,也包括其他进程的共享内存
      2、虽然进程只使用了几个共享库的函数,但它包含了整个共享库的大小
      3、计算某个进程所占的物理内存大小公式:RES – SHR
      4、swap out后,它将会降下来

    DATA
      1、数据占用的内存。如果top没有显示,按f键可以显示出来。
      2、真正的该程序要求的数据空间,是真正在运行中要使用的。

    top 运行中可以通过 top 的内部命令对进程的显示方式进行控制。内部命令如下:
      s – 改变画面更新频率
      l – 关闭或开启第一部分第一行 top 信息的表示
      t – 关闭或开启第一部分第二行 Tasks 和第三行 Cpus 信息的表示
      m – 关闭或开启第一部分第四行 Mem 和 第五行 Swap 信息的表示
      N – 以 PID 的大小的顺序排列表示进程列表
      P – 以 CPU 占用率大小的顺序排列进程列表
      M – 以内存占用率大小的顺序排列进程列表
      h – 显示帮助
      n – 设置在进程列表所显示进程的数量
      q – 退出 top
      s – 改变画面更新周期


 2、top使用方法

 使用格式:

  top [-] [d] [p] [q] [c] [C] [S] [s] [n]

参数说明:

  d:指定每两次屏幕信息刷新之间的时间间隔。当然用户可以使用s交互命令来改变之。

  p:通过指定监控进程ID来仅仅监控某个进程的状态。

  q:该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行。

  S:指定累计模式。

  s:使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。

  i:使top不显示任何闲置或者僵死进程。

  c:显示整个命令行而不只是显示命令名。


 3、常用命令说明

 Ctrl+L:擦除并且重写屏幕

 K:终止一个进程。系统将提示用户输入需要终止的进程PID,以及需要发送给该进程什么样的信号。一般的终止进程可以使用15信号;如果不能正常结束那就使用信号9强制结束该进程。默认值是信号15。在安全模式中此命令被屏蔽。

 i:忽略闲置和僵死进程。这是一个开关式命令。

 q:退出程序

 r:重新安排一个进程的优先级别。系统提示用户输入需要改变的进程PID以及需要设置的进程优先级值。输入一个正值将使优先级降低,反之则可以使该进程拥有更高的优先权。默认值是10。

 S:切换到累计模式。

 s:改变两次刷新之间的延迟时间。系统将提示用户输入新的时间,单位为s。如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5 s。需要注意的是如果设置太小的时间,很可能会引起不断刷新,从而根本来不及看清显示的情况,而且系统负载也会大大增加。

 f或者F:从当前显示中添加或者删除项目。

 o或者O:改变显示项目的顺序

 l:切换显示平均负载和启动时间信息。

 m:切换显示内存信息。

 t:切换显示进程和CPU状态信息。

 c:切换显示命令名称和完整命令行。

 M:根据驻留内存大小进行排序。

 P:根据CPU使用百分比大小进行排序。

 T:根据时间/累计时间进行排序。

 W:将当前设置写入~/.toprc文件中。


 4、显示当前系统中占用资源最多的一些进程, shift+m 按照内存大小查看

 top


 df:显示文件系统的磁盘使用情况

 1、显示文件系统的磁盘使用情况

 df

第一列指定文件系统的名称,

第二列指定一个特定的文件系统1K-块1K是1024字节为单位的总内存。

用和可用列正在使用中,

分别指定的内存量。

使用列指定使用的内存的百分比,

而最后一栏"安装在"指定的文件系统的挂载点。


 2、df显示磁盘使用的文件系统信息

 df /media


 3、用一个-i选项的df命令的输出显示inode信息而非块使用量

 df -i


 4、显示所有的信息

 df --total

我们看到输出的末尾,包含一个额外的行,显示总的每一列。


 5、-h选项,通过它可以产生可读的格式df命令的输出【一种易看的显示】

 df -h

我们可以看到输出显示的数字形式的‘G‘(千兆字节),"M"(兆字节)和"K"(千字节)。

这使输出容易阅读和理解,从而使显示可读的。请注意,第二列的名称也发生了变化,为了使显示可读的"大小"。


 mount:挂载

 1、将 /dev/hda1 挂载 /mnt之下

 mount /dev/hda1 /mnt


 2、将 /dev/hda1 用唯读模式挂在 /mnt 之下

 mount -o ro /dev/hda1 /mnt


 3、将 /tmp/image.iso 这个光碟的 image 档使用 loop 模式挂在 /mnt/cdrom之下。用这种方法可以将一般网络上可以找到的 Linux 光 碟 ISO 档在不烧录成光碟的情况下检视其内容

 mount -o loop /tmp/image.iso /mnt/cdrom


 4、添加到fstab中进行自动挂载,这样任何时候系统重启的时候,文件系统都会被加载

 /dev/hda1 /mnt ext2 defaults 0 2


推荐阅读
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文内容为asp.net微信公众平台开发的目录汇总,包括数据库设计、多层架构框架搭建和入口实现、微信消息封装及反射赋值、关注事件、用户记录、回复文本消息、图文消息、服务搭建(接入)、自定义菜单等。同时提供了示例代码和相关的后台管理功能。内容涵盖了多个方面,适合综合运用。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 本文讲述了作者通过点火测试男友的性格和承受能力,以考验婚姻问题。作者故意不安慰男友并再次点火,观察他的反应。这个行为是善意的玩人,旨在了解男友的性格和避免婚姻问题。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • JVM 学习总结(三)——对象存活判定算法的两种实现
    本文介绍了垃圾收集器在回收堆内存前确定对象存活的两种算法:引用计数算法和可达性分析算法。引用计数算法通过计数器判定对象是否存活,虽然简单高效,但无法解决循环引用的问题;可达性分析算法通过判断对象是否可达来确定存活对象,是主流的Java虚拟机内存管理算法。 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
author-avatar
sexy-domey
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有