Linux常用的基本命令13

简介:

uname
作用:查看系统相关信息
常用选项:
    -a或–all 详细输出所有信息,依次为内核名称,主机名,内核版本号,内核版本,硬件名,处理器类型,硬件平台类型,操作系统名称 
    -m或–machine 显示主机的硬件(CPU)名 
    -n或-nodename 显示主机在网络节点上的名称或主机名称 
    -r或–release 显示linux操作系统内核版本号 
    -s或–sysname 显示linux内核名称 
    -v 显示显示操作系统是第几个 version 版本 
    -p 显示处理器类型或unknown 
    -i 显示硬件平台类型或unknown 
    -o 显示操作系统名 
实例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
[root@jacken ~] # uname -a
Linux jacken 2.6.32-504.el6.x86_64  #1 SMP Wed Oct 15 04:27:16 UTC 2014 x86_64 x86_64 x86_64 GNU/Linux
[root@jacken ~] # uname -m
x86_64
[root@jacken ~] # uname -n
jacken
[root@jacken ~] # uname -r
2.6.32-504.el6.x86_64
[root@jacken ~] # uname -s
Linux
[root@jacken ~] # uname -v
#1 SMP Wed Oct 15 04:27:16 UTC 2014
[root@jacken ~] # uname -p
x86_64
[root@jacken ~] # uname -i
x86_64
[root@jacken ~] # uname -o
GNU /Linux
[root@jacken ~] #

ps
作用:ps(Process Status)查看进程状态
注释:
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 显示同一终端下的所有程序
    -A 显示所有进程
    c  显示进程的真实名称
    -N 反向选择
    -e 等于“-A”
    e  显示环境变量
    f  显示程序间的关系
    -H 显示树状结构
    r  显示当前终端的进程
    T  显示当前终端的所有程序
    u  启动这个进程的用户和它的启动时间
    -au 显示较详细的资讯
    -aux 显示所有包含其他使用者的行程 
实例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
[root@jacken ~] # ps 
   PID TTY          TIME CMD
  2654 pts /1     00:00:00  bash
  4557 pts /1     00:00:00  ps
[root@jacken ~] # ps a
   PID TTY      STAT   TIME COMMAND
  1862 tty1     Ss+    0:00  /sbin/mingetty  /dev/tty1
  1864 tty2     Ss+    0:00  /sbin/mingetty  /dev/tty2
  1866 tty3     Ss+    0:00  /sbin/mingetty  /dev/tty3
  1870 tty4     Ss+    0:00  /sbin/mingetty  /dev/tty4
  1872 tty5     Ss+    0:00  /sbin/mingetty  /dev/tty5
  1874 tty6     Ss+    0:00  /sbin/mingetty  /dev/tty6
  1882 pts /0     Ss+    0:00 - bash
  2654 pts /1     Ss     0:00 - bash
  3926 pts /2     Ss+    0:00 - bash
  4492 pts /2     R      9:14  cat  /dev/zero
  4558 pts /1     R+     0:00  ps  a
[root@jacken ~] # ps -a
   PID TTY          TIME CMD
  4492 pts /2     00:09:16  cat
  4559 pts /1     00:00:00  ps
  [root@jacken ~] # ps -A
   PID TTY          TIME CMD
     1 ?        00:00:01 init
     2 ?        00:00:00 kthreadd
     3 ?        00:00:00 migration /0
     4 ?        00:00:00 ksoftirqd /0
     ......
     ......
     3909 ?        00:00:00 sshd
     3926 pts /2     00:00:00  bash
     4393 ?        00:00:00 dhclient
     4492 pts /2     00:09:30  cat
     4561 pts /1     00:00:00  ps
[root@jacken ~] # ps -ef  
UID        PID  PPID  C STIME TTY          TIME CMD
root         1     0  0 21:19 ?        00:00:01  /sbin/init
root         2     0  0 21:19 ?        00:00:00 [kthreadd]
root         3     2  0 21:19 ?        00:00:00 [migration /0 ]
.........
root      4393     1  0 22:24 ?        00:00:00  /sbin/dhclient  -1 -q -lf  /var/lib/dhclient/dhclient-eth1 .leases -pf  /var/run/dhclient-eth1 .pid eth1
root      4492  3926 99 22:36 pts /2     00:17:00  cat  /dev/zero
root      4618  2654  0 22:53 pts /1     00:00:00  ps  -ef
root      4619  2654  0 22:53 pts /1     00:00:00  tail  -4
[root@jacken ~] # ps -aux | head -4
Warning: bad syntax, perhaps a bogus  '-' ? See  /usr/share/doc/procps-3 .2.8 /FAQ
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root         1  0.0  0.1  19364  1536 ?        Ss   21:19   0:01  /sbin/init
root         2  0.0  0.0      0     0 ?        S    21:19   0:00 [kthreadd]
root         3  0.0  0.0      0     0 ?        S    21:19   0:00 [migration /0 ]
........
root      4393  0.0  0.0   9120  1008 ?        Ss   22:24   0:00  /sbin/dhclient  -1 -q -lf  /var/lib/dhclient/dhclient-eth1 .leases -pf  /var/run/dhclient-eth1 .pid eth1
root      4492 99.1  0.0 100936   584 pts /2     R    22:36  18:00  cat  /dev/zero
root      4625  0.0  0.1 110240  1136 pts /1     R+   22:54   0:00  ps  -aux
root      4626  0.0  0.0 100944   664 pts /1     S+   22:54   0:00  tail  -4
[root@jacken ~] #

kill
作用:杀掉系统某一进程
常用选项:
    -l  信号,若果不加信号的编号参数,则使用“-l”参数会列出全部的信号名称
    -a  当处理当前进程时,不限制命令名和进程号的对应关系
    -p  指定kill 命令只打印相关进程的进程号,而不发送任何信号
    -s  指定发送信号
    -u  指定用户 
实例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
[root@jacken ~] # kill -l
  1) SIGHUP     2) SIGINT     3) SIGQUIT     4) SIGILL     5) SIGTRAP
  6) SIGABRT     7) SIGBUS     8) SIGFPE     9) SIGKILL    10) SIGUSR1
11) SIGSEGV    12) SIGUSR2    13) SIGPIPE    14) SIGALRM    15) SIGTERM
16) SIGSTKFLT    17) SIGCHLD    18) SIGCONT    19) SIGSTOP    20) SIGTSTP
21) SIGTTIN    22) SIGTTOU    23) SIGURG    24) SIGXCPU    25) SIGXFSZ
26) SIGVTALRM    27) SIGPROF    28) SIGWINCH    29) SIGIO    30) SIGPWR
31) SIGSYS    34) SIGRTMIN    35) SIGRTMIN+1    36) SIGRTMIN+2    37) SIGRTMIN+3
38) SIGRTMIN+4    39) SIGRTMIN+5    40) SIGRTMIN+6    41) SIGRTMIN+7    42) SIGRTMIN+8
43) SIGRTMIN+9    44) SIGRTMIN+10    45) SIGRTMIN+11    46) SIGRTMIN+12    47) SIGRTMIN+13
48) SIGRTMIN+14    49) SIGRTMIN+15    50) SIGRTMAX-14    51) SIGRTMAX-13    52) SIGRTMAX-12
53) SIGRTMAX-11    54) SIGRTMAX-10    55) SIGRTMAX-9    56) SIGRTMAX-8    57) SIGRTMAX-7
58) SIGRTMAX-6    59) SIGRTMAX-5    60) SIGRTMAX-4    61) SIGRTMAX-3    62) SIGRTMAX-2
63) SIGRTMAX-1    64) SIGRTMAX    
[root@jacken ~] # kill -l QUIT
3
[root@jacken ~] # kill -l STOP
19
[root@jacken ~] # ps -ef | grep cat
root      4492  3926 99 22:36 pts /2     00:22:18  cat  /dev/zero
root      4646  2654  0 22:59 pts /1     00:00:00  grep  cat
[root@jacken ~] # kill 4492
[root@jacken ~] # kill 4492
- bash kill : (4492) - No such process
[root@jacken ~] # ps -ef | grep cat
jacken    4861  4699 99 23:37 pts /3     00:08:26  cat  /dev/zero
root      4944  2654  0 23:46 pts /1     00:00:00  grep  cat
[root@jacken ~] # kill -s 9 4861
[root@jacken ~] # ps -ef | grep cat
root      4946  2654  0 23:46 pts /1     00:00:00  grep  cat
[root@jacken ~] #

top
作用:实时显示系统中各个进程的资源占用状况、
常用选项:
    -d 指定每两次屏幕信息刷新之间的时间间隔,当然用户可以使用s交互命令来改变之(单位秒“.2”为0.2秒)。
    -p 通过指定监控进程ID来仅仅监控某个进程的状态
    -i 使top不显示任何闲置或者僵死进程
    -c 显示整个命令行而不只是显示命令名
    -s 使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险
[root@jacken ~]# top -d .5 //每隔0.5秒刷新一次
[root@jacken ~]# top -p 10 //只检测pid为10的状态视图
[root@jacken ~]# top -i    //不显示任何闲置或者僵死进程

top命令执行过程中可以使用的一些交互命令
    h或者? 显示帮助画面,给出一些简短的命令总结说明
    k 终止一个进程。系统将提示用户输入需要终止的进程PID,以及需要发送给该进程什么样的信号。
        一般的终止进程可以使用15信号;如果不能正常结束那就使用信号9强制结束该进程。默认值是信号15。在安全模式中此命令被屏蔽。
    i 忽略闲置和僵死进程。这是一个开关式命令。
    q 退出程序
    W 将当前设置写入~/.toprc文件中(隐藏文件)。这是写top配置文件的推荐方法。
    t 切换显示进程和CPU状态信息
    c 切换显示命令名称和完整命令行
    P 根据CPU使用百分比大小进行排序
    T 根据时间/累计时间进行排序
    Shift+M 可按内存占用情况进行排序
top - 23:54:18 up  2:35,  3 users,  load average: 1.18, 0.64, 0.42
Tasks:  96 total,   3 running,  93 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.0%us, 18.5%sy,  0.0%ni,  0.0%id, 75.9%wa,  3.5%hi,  2.1%si,  0.0%st
Mem:   1012292k total,   951588k used,    60704k free,      116k buffers
Swap:  2097148k total,   235984k used,  1861164k free,     2332k cached

  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                                                       
 4965 root      20   0 1126m 824m  240 R 15.0 83.5   0:31.11 dd                                                                                                             
   16 root      20   0     0    0    0 R  3.3  0.0   0:04.40 kblockd/0                                                                                                      
   30 root      20   0     0    0    0 S  2.0  0.0   0:05.05 kswapd0                                                                                                        
    1 root      20   0 19364  408  408 S  0.0  0.0   0:01.23 init                                                                                                           
    2 root      20   0     0    0    0 S  0.0  0.0   0:00.01 kthreadd                                                                                                       
    3 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 migration/0                                                                                                    
    4 root      20   0     0    0    0 S  0.0  0.0   0:00.10 ksoftirqd/0                                                                                                    
    5 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 stopper/0                                                                                                      
    6 root      RT   0     0    0    0 S  0.0  0.0   0:00.02 watchdog/0                                                                                                     
    7 root      20   0     0    0    0 S  0.0  0.0   0:11.78 events/0                                                                                                       
    8 root      20   0     0    0    0 S  0.0  0.0   0:00.00 cgroup    
第一行是队列信息,同uptime命令的执行结果
    23:54:18 up        当前系统时间
    2:35            系统运行时间,时间格式为分
    3 users            当前登录用户数
    load average: 1.18, 0.64, 0.42     系统负载,队列的平均长度
第二行为行为进程
    96 total        进程总数
    3 running                正在运行的进程数
    93 sleeping                睡眠的进程数
    0 stopped                停止的进程数
    0 zombie                僵尸进程数
第三行为CPU信息
    0.0%us            用户空间占用CPU的百分比
    19.6%sy                    内核占用CPU的百分比
    0.0%ni                    用户进程空间内改变过优先级的进程占用CPU百分比
    0.0%id                    空闲CPU百分比
    71.6%wa                    等待输入输出的CPU百分比
    4.4%hi                    cpu处理硬件中断的时间
    4.4%si                    cpu处理软中断的时间
    0.0%st                    用于有虚拟cpu的情况,用来指示被虚拟机偷掉的cpu时间
第四行为物理内存信息
    1012292k total            物理内存总量
    951588k used            使用的物理内存总量
    60704k free                空闲内存总量
    116k buffers            用作内核缓存的内存量
第五行为交换分区信息
    2097148k total            交换分区总大小
    235984k used            使用的交换分区大小
    1861164k free            空闲交换分区大小
    2332k cached            缓冲的交换分区总量
buffers和cached的区别需要说明一下,buffers指的是块设备的读写缓冲区,cached指的是文件系统本身的页面缓存。
它们都是linux操作系统底层的机制,目的就是为了加速对磁盘的访问。
第六行为内容视图
PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND    
PID(进程号)、 USER(运行用户)、PR(优先级)、NI(任务nice值)、VIRT(虚拟内存用量)VIRT=SWAP+RES 、RES(物理内存用量)、SHR(共享内存用量)、
S(进程状态)、%CPU(CPU占用比)、%MEM(物理内存占用比)、TIME+(累计CPU占用时间)、 COMMAND 命令名/命令行

netstat
作用:显示各种网络相关信息
常用选项:
    -a (all)显示所有选项,默认不显示LISTEN相关
    -t (tcp)仅显示tcp相关选项
    -u (udp)仅显示udp相关选项
    -n 拒绝显示别名,能显示数字的全部转化成数字。
    -l 仅列出有在 Listen (监听) 的服务状态
    -p 显示建立相关链接的程序名
    -r 显示路由信息,路由表
    -e 显示扩展信息,例如uid等
    -s 按各个协议进行统计
    -c 每隔一个固定时间,执行该netstat命令
实例:

1
2
3
4
[root@jacken ~] # netstat -a //列出所有端口
[root@jacken ~] # netstat -at //列出所有TCP端口
[root@jacken ~] # netstat -au //列出所有UDP端口
[root@jacken ~] # netstat -s //显示所有端口的统计信息


本文转自Jacken_yang 51CTO博客,原文链接:http://blog.51cto.com/linuxnote/1635826,如需转载请自行联系原作者
相关文章
|
3月前
|
Linux 应用服务中间件 Shell
二、Linux文本处理与文件操作核心命令
熟悉了Linux的基本“行走”后,就该拿起真正的“工具”干活了。用grep这个“放大镜”在文件里搜索内容,用find这个“探测器”在系统中寻找文件,再用tar把东西打包带走。最关键的是要学会使用管道符|,它像一条流水线,能把这些命令串联起来,让简单工具组合出强大的功能,比如 ps -ef | grep 'nginx' 就能快速找出nginx进程。
二、Linux文本处理与文件操作核心命令
|
3月前
|
Linux
linux命令—stat
`stat` 是 Linux 系统中用于查看文件或文件系统详细状态信息的命令。相比 `ls -l`,它提供更全面的信息,包括文件大小、权限、所有者、时间戳(最后访问、修改、状态变更时间)、inode 号、设备信息等。其常用选项包括 `-f` 查看文件系统状态、`-t` 以简洁格式输出、`-L` 跟踪符号链接,以及 `-c` 或 `--format` 自定义输出格式。通过这些选项,用户可以灵活获取所需信息,适用于系统调试、权限检查、磁盘管理等场景。
296 137
|
3月前
|
安全 Ubuntu Unix
一、初识 Linux 与基本命令
玩转Linux命令行,就像探索一座新城市。首先要熟悉它的“地图”,也就是/根目录下/etc(放配置)、/home(住家)这些核心区域。然后掌握几个“生存口令”:用ls看周围,cd去别处,mkdir建新房,cp/mv搬东西,再用cat或tail看文件内容。最后,别忘了随时按Tab键,它能帮你自动补全命令和路径,是提高效率的第一神器。
687 57
|
6月前
|
JSON 自然语言处理 Linux
linux命令—tree
tree是一款强大的Linux命令行工具,用于以树状结构递归展示目录和文件,直观呈现层级关系。支持多种功能,如过滤、排序、权限显示及格式化输出等。安装方法因系统而异常用场景包括:基础用法(显示当前或指定目录结构)、核心参数应用(如层级控制-L、隐藏文件显示-a、完整路径输出-f)以及进阶操作(如磁盘空间分析--du、结合grep过滤内容、生成JSON格式列表-J等)。此外,还可生成网站目录结构图并导出为HTML文件。注意事项:使用Tab键补全路径避免错误;超大目录建议限制遍历层数;脚本中推荐禁用统计信息以优化性能。更多详情可查阅手册mantree。
513 143
linux命令—tree
|
2月前
|
存储 安全 Linux
Linux卡在emergency mode怎么办?xfs_repair 命令轻松解决
Linux虚拟机遇紧急模式?别慌!多因磁盘挂载失败。本文教你通过日志定位问题,用`xfs_repair`等工具修复文件系统,三步快速恢复。掌握查日志、修磁盘、验重启,轻松应对紧急模式,保障系统稳定运行。
423 2
|
3月前
|
缓存 监控 Linux
Linux内存问题排查命令详解
Linux服务器卡顿?可能是内存问题。掌握free、vmstat、sar三大命令,快速排查内存使用情况。free查看实时内存,vmstat诊断系统整体性能瓶颈,sar实现长期监控,三者结合,高效定位并解决内存问题。
285 0
Linux内存问题排查命令详解
|
3月前
|
Unix Linux 程序员
Linux文本搜索工具grep命令使用指南
以上就是对Linux环境下强大工具 `grep` 的基础到进阶功能介绍。它不仅能够执行简单文字查询任务还能够处理复杂文字处理任务,并且支持强大而灵活地正则表达规范来增加查询精度与效率。无论您是程序员、数据分析师还是系统管理员,在日常工作中熟练运用该命令都将极大提升您处理和分析数据效率。
278 16
|
5月前
|
监控 Linux 网络安全
Linux命令大全:从入门到精通
日常使用的linux命令整理
826 13
|
6月前
|
Linux 网络安全 数据安全/隐私保护
使用Linux系统的mount命令挂载远程服务器的文件夹。
如此一来,你就完成了一次从你的Linux发车站到远程服务器文件夹的有趣旅行。在这个技术之旅中,你既探索了新地方,也学到了如何桥接不同系统之间的距离。
976 21
|
6月前
|
监控 Linux
Linux系统中使用df命令详解磁盘使用情况。
`df`命令是Linux系统管理员和用户监控和管理磁盘空间使用的重要工具。掌握它的基本使用方法和选项可以帮助在必要时分析和解决空间相关问题。简洁但功能丰富,`df`命令确保了用户可以快速有效地识别和管理文件系统的空间使用情况。
437 13