linux 性能分析,如何优化linux系统性能

各位老铁们好,相信很多人对linux 性能分析都不是特别的了解,因此呢,今天就来为大家分享下关于linux 性能分析以及如何优化linux系统性能的问题知识,还望可以帮助大家,解决大家的一些困惑,下面一起来看看吧!

Linux系统下常用性能分析工具top命令,怎么详解

top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。下面详细介绍它的使用方法。

top- 01:06:48 up 1:22, 1 user, load average: 0.06, 0.60, 0.48

Tasks: 29 total, 1 running, 28 sleeping, 0 stopped, 0 zombie

Cpu(s): 0.3% us, 1.0% sy, 0.0% ni, 98.7% id, 0.0% wa, 0.0% hi, 0.0% si

Mem: 191272k total, 173656k used, 17616k free, 22052k buffers

Swap: 192772k total, 0k used, 192772k free, 123988k cached

PID USER PR NI VIRT RES SHR S%CPU%MEM TIME+ COMMAND

1379 root 16 0 7976 2456 1980 S 0.7 1.3 0:11.03 sshd

14704 root 16 0 2128 980 796 R 0.7 0.5 0:02.72 top

1 root 16 0 1992 632 544 S 0.0 0.3 0:00.90 init

2 root 34 19 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/0

3 root RT 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/0

统计信息区前五行是系统整体的统计信息。第一行是任务队列信息,同 uptime命令的执行结果。其内容如下:

01:06:48当前时间

up 1:22系统运行时间,格式为时:分

1 user当前登录用户数

load average: 0.06, 0.60, 0.48系统负载,即任务队列的平均长度。

三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。

第二、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行。内容如下:

Tasks: 29 total进程总数

1 running正在运行的进程数

28 sleeping睡眠的进程数

0 stopped停止的进程数

0 zombie僵尸进程数

Cpu(s): 0.3% us用户空间占用CPU百分比

1.0% sy内核空间占用CPU百分比

0.0% ni用户进程空间内改变过优先级的进程占用CPU百分比

98.7% id空闲CPU百分比

0.0% wa等待输入输出的CPU时间百分比

0.0% hi

0.0% si

最后两行为内存信息。内容如下:

Mem: 191272k total物理内存总量

173656k used使用的物理内存总量

17616k free空闲内存总量

22052k buffers用作内核缓存的内存量

Swap: 192772k total交换区总量

0k used使用的交换区总量

192772k free空闲交换区总量

123988k cached缓冲的交换区总量。

内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,

该数值即为这些内容已存在于内存中的交换区的大小。

相应的内存再次被换出时可不必再对交换区写入。

进程信息区统计信息区域的下方显示了各个进程的详细信息。首先来认识一下各列的含义。

序号列名含义

a PID进程id

b PPID父进程id

c RUSER Real user name

d UID进程所有者的用户id

e USER进程所有者的用户名

f GROUP进程所有者的组名

g TTY启动进程的终端名。不是从终端启动的进程则显示为?

h PR优先级

i NI nice值。负值表示高优先级,正值表示低优先级

j P最后使用的CPU,仅在多CPU环境下有意义

k%CPU上次更新到现在的CPU时间占用百分比

l TIME进程使用的CPU时间总计,单位秒

m TIME+进程使用的CPU时间总计,单位1/100秒

n%MEM进程使用的物理内存百分比

o VIRT进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES

p SWAP进程使用的虚拟内存中,被换出的大小,单位kb。

q RES进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA

r CODE可执行代码占用的物理内存大小,单位kb

s DATA可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb

t SHR共享内存大小,单位kb

u nFLT页面错误次数

v nDRT最后一次写入到现在,被修改过的页面数。

w S进程状态。

D=不可中断的睡眠状态

R=运行

S=睡眠

T=跟踪/停止

Z=僵尸进程

x COMMAND命令名/命令行

y WCHAN若该进程在睡眠,则显示睡眠中的系统函数名

z Flags任务标志,参考 sched.h

默认情况下仅显示比较重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND列。可以通过下面的快捷键来更改显示内容。

更改显示内容通过 f键可以选择显示的内容。按 f键之后会显示列的列表,按 a-z即可显示或隐藏对应的列,最后按回车键确定。

按 o键可以改变列的显示顺序。按小写的 a-z可以将相应的列向右移动,而大写的 A-Z可以将相应的列向左移动。最后按回车键确定。

按大写的 F或 O键,然后按 a-z可以将进程按照相应的列进行排序。而大写的 R键可以将当前的排序倒转。

命令使用

1.工具(命令)名称

top

2.工具(命令)作用

显示系统当前的进程和其他状况; top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止.比较准确的说,top命令提供了实时的对系统处理器的状态监视.它将显示系统中CPU最“敏感”的任务列表.该命令可以按CPU使用.内存使用和执行时间对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定.

3.环境设置

在Linux下使用。

4.使用方法

4.1使用格式

top [-] [d]

[q] [c] [C] [S] [s] [n]

4.2参数说明

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

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

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

S指定累计模式

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

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

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

4.3其他

下面介绍在top命令执行过程中可以使用的一些交互命令。从使用角度来看,熟练的掌握这些命令比掌握选项还重要一些。这些命令都是单字母的,如果在命令行选项中使用了s选项,则可能其中一些命令会被屏蔽掉。

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

h或者?显示帮助画面,给出一些简短的命令总结说明。

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文件中。这是写top配置文件的推荐方法

怎样分析linux的性能指标

LR

监控

UNIX/Linux

系统方法

一、准备工作:

1.

可以通过两种方法验证服务器上是否配置

rstatd

守护程序:

①使用

rup

命令,它用于报告计算机的各种统计信息,其中就包括

rstatd

的配置信息。使用命

rup

10.130.61.203,

此处

10.130.61.203

是要监视的

linux/Unix

服务器的

IP

,如果该命令返回相关的

统计信息。则表示已经配置并且激活了

rstatd

守护进程;若未返回有意义的统计信息,或者出现一

条错误报告,则表示

rstatd

守护进程尚未被配置或有问题。

②使用

find

命令

#find/-name rpc.rstatd,

该命令用于查找系统中是否存在

rpc.rstatd

文件,如果没有,说明系统没

有安装

rstatd

守护程序。

2

linux

需要下载

3

个包:

1

rpc.rstatd-4.0.1.tar.gz

2

rsh-0.17-14.i386.rpm

3

rsh-server-0.17-14.i386.rpm

3

.下载并安装

rstatd

如果服务器上没有安装

rstatd

程序(一般来说

LINUX

都没有安装)

,需要下载一个包才有这个服

,

rpc.rstatd-4.0.1.tar.gz.

,

,

rstatd

这个地址下载)下载后,开始安装,安装步骤如下:

tar-xzvf rpc.rstatd-4.0.1.tar.gz

cd rpc.rstatd-4.0.1/

./configure

—配置操作

make

—进行编译

make install

—开始安装

rpc.rstatd

—启动

rstatd

进程

rpcinfo-p

”命令来查看当前系统是否已经启动了

rstatd

守护进程

只要保证

Linux

机器上的进程里有

rstatd

xinetd

这二个服务就可以用

LR

去监视了,通过以下

两点可以检查是否启动:

1

)检查是否启动

: rsh server

监听的

TCP

514

[root@mg04 root]# netstat-an|grep 514

tcp 0 0 0.0.0.0:514 0.0.0.0:* LISTEN

如果能看到

514

在监听说明

rsh

服务器已经启动。

2

)检查是否启动

: rstatd

输入命令

: rpcinfo-p

如果能看到类似如下信息:

程序版本协议端口

100001

5

udp

937

rstatd

100001

4

udp

937

rstatd

100001

3

udp

937

rstatd

100001

2

udp

937

rstatd

100001

1

udp

937

rstatd

那就说明

rstatd

服务启动了

,(

当然这里也可以用

ps ax

代替

)

4

.安装

rsh

rsh-server

两个服务包方法

a.

卸载

rsh

# rpm

q

rsh----------

查看版本号

# rpm

-e

版本号

---------

卸载该版本。

b

.安装

# rpm

ivh rsh-0.17-14.i386.rpm rsh-server-0.17-14.i386.rpm

在启动

rpc.rstatd

时,

会报错

Cannot register service: RPC: Unable to receive; errno= Ction refused

解决方法如下:

#/etc/init.d/portmap start

#/etc/init.d/nfs start

然后再次启动

rpc.rstatd

就好了。

5

.安装

xinetd

方法:

①查看

xinetd

服务:

[root@localhost~]# rpm-q xinetd

xinetd-2.3.14-10.el5

②安装

xinetd

服务:

[root@localhost~]# yum install xinetd

如果安装不起

xinetd

服务,执行下列操作命令后再次执行

yum install xinetd

命令进行安装:

yum clean packages

清除缓存目录下的软件包

yum clean headers

清除缓存目录下的

headers

yum clean oldheaders

清除缓存目录下旧的

headers

yum clean, yum clean all(= yum clean packages; yum clean oldheaders)

清除缓存目录下的软件包

及旧的

headers

6

.启动

xinetd

服务:

在有的系统中,通过如下命令重启:

# service xinetd reload

#/sbin/service xinetd rstart

suse linux

中如下操作:

cd/etc/init.d/xinetd restart

2

安装完成后配置

rstatd

目标守护进程

xinetd,

它的主配置文件是

/etc/xinetd.conf,

它里面内容是

一些如下的基本信息:

#

# xinetd.conf

#

# Copyright(c) 1998-2001 SuSE GmbH Nuernberg, Germany.

# Copyright(c) 2002 SuSE Linux AG, Nuernberg, Germany.

#

defaults

{

log_type

= FILE/var/log/xinetd.log

log_on_success= HOST EXIT DURATION

log_on_failure= HOST ATTEMPT

#

only_from

= localhost

instances

= 30

cps

= 50 10

#

# The specification of an interface is interesting, if we are on a firewall.

# For example, if you only want to provide services from an internal

# network interface, you may specify your internal interfaces IP-Address.

#

#

interface

= 127.0.0.1

}

includedir/etc/xinetd.d

我们这里需要修改的是

/etc/xinetd.d/

下的三个

conf

文件

rlogin

,rsh,rexec

这三个配置文件

,

打这

三个文件里的

disable= yes

都改成

disable= no( disabled

用在默认的

{}

中禁止服务

)

或是把

# default:

off

都设置成

on

这个的意思就是在

xinetd

启动的时候默认都启动上面的三个服务

!

说明:我自己在配置时,没有

disable= yes

这项,我就将

# default: off

改为:

default: on

,重启后

(cd/etc/init.d/./xinetd restart

)通过

netstat-an|grep 514

查看,没有返回。然后,我就手动在三个文

件中最后一行加入

disable

=

no

,再重启

xinetd

,再使用

netstat

-an

|grep

514

查看,得到

tcp

0

0

0.0.0.0:514 0.0.0.0:* LISTEN

结果,表明

rsh

服务器已经启动。

看到网上有的地方说使用如下命令:

# service xinetd reload

#/sbin/service xinetd rstart

不知道是在什么系统用的。

二、监控

linux

资源:

controller

中,将

System resource Graphs

中的

Unix resources

拖到右侧的监控区域中,并单击

鼠标右键选择“

Add

Measurements

,

在弹出的对话框中输入被监控的

linux

系统的

IP

地址,然后选

择需要监控的性能指标,并点击“确定”

,出现如下结果:

Monitor name:UNIX Resources. Cannot initialize the monitoring on 10.10.15.62.

Error while creating the RPC client. Ensure that the machine can be connected and that it runs the

rstat daemon(use rpcinfo utility for this verification).

Detailed error: RPC: Failed to create RPC client.

RPC-TCP: Failed to establish RPC server address.

RPC-TCP: Failed to communicate with the portmapper on host'10.10.15.62'.

RPC: RPC call failed.

RPC-TCP: recv()/recvfrom() failed.

RPC-TCP: Timeout reached.(entry point: CFactory::Initialize). [MsgId: MMSG-47190]

检查原因,发现是

Linux

系统中的防火墙开启了并且阻挡了

LoadRunner

监控

Linux

系统的资源,

因此要将防火墙关闭。

关闭防火墙:

[root@localhost~]#/etc/init.d/iptables stop;

三、监控

UNIX

lr

监控

UNIX

UNIX

先启动一

rstatd

服务

以下是在

IBM AIX

系统中启动

rstatd

服务的方法:

1

.使用

telnet

root

用户的身份登录入

AIX

系统

2

.在命令行提示符下输入:

vi/etc/inetd.conf

3

.查找

rstatd

,找到

#rstatd

sunrpc_udp

udp

wait

root/usr/sbin/rpc.rstatd rstatd 100001 1-3

4

、将

#

去掉

5

:wq

保存修改结果

6

、命令提示符下输入:

refresh

s inetd

重新启动服务。

这样使用

loadrunner

就可以监视

AIX

系统的性能情况了。

注:在

HP UNIX

系统上编辑完

inetd.conf

后,重启

inetd

服务需要输入

inetd-c

UNIX

上也可以用

rup

命令查看

rstatd

程序是否被配置并激活

rstatd

程序已经运行,

重启时,

先查看进程

ps-ef|grep inet

然后杀掉进程,

refresh

s inetd

进行重启。

Linux查看网络流量

在Linux运维日常中,监控服务器的网络流量状况至关重要。本文将深入探讨几个实用的Linux命令,帮助你轻松掌握网络流量的查看和分析。这些命令涵盖了总流量、实时速率、连接/进程流量等多个维度,无论你是初学者还是经验丰富的运维人员,都能从中受益。

查看网络总流量- ip命令</

iproute2util包中的ip命令,作为ifconfig的升级版,提供了强大的网络配置和流量查看功能。ip命令在多数系统中已经预装,若需安装可通过yum install-y iproute。例如,使用ip-s-h link可以清晰地查看各网卡的总流量。

实时速率监控- nload</

nload,一个来自EPEL库的实用工具,不仅显示当前网络设备速率,还提供总流量统计。在CentOS系统中,先安装EPEL库再安装nload:yum install-y epel-release&& yum install-y nload。通过nload eth0命令,你可以实时查看eth0网卡的流量情况。

全面性能分析- dstat</

作为一款多功能工具,可替代多个传统命令,提供实时数据刷新。默认未安装时,可通过yum install-y dstat获取。使用dstat-tnf 1 10,你将获得接下来10秒内的每秒网络数据。

系统活动洞察- sar命令</

sysstat包中的sar工具,是Linux系统性能分析的得力助手。安装sysstat包后,sar-n TCP 1 10将为你揭示接下来10秒内的TCP数据细节。

连接与进程流量监控- ss和netstat</

ss是netstat的高效替代,性能更优。它通常预装在iproute2util包中,若需要更新,执行yum install-y iproute。而netstat则需要额外安装,如yum install-y net-tools。ss的使用示例如下:

ss-tuln</

实时流量分析利器- iftop

iftop是EPEL库的又一实用工具,通过yum install-y epel-release&& yum install-y iftop安装后,iftop-nN-i eth0将为eth0网卡的实时连接和速率提供清晰视图。

进程流量分解- nethogs</

nethogs专为单个进程流量监控而设计,安装EPEL库并运行nethogs-d 2 eth0,你可以每2秒刷新一次eth0网卡上各个进程的流量信息。

以上就是Linux服务器网络流量查看和管理的常用工具,希望对你有所帮助。如果你在使用过程中遇到任何疑问,欢迎随时向我咨询。

阅读剩余
THE END