全面了解Linux 服务器
-------------------------------------------------------------------------------------------------------------------------
查看系统的版本信息
一。查看内核版本命令:
1) [root@SOR_SYS ~]# cat /proc/version
Linux version 2.6.18-238.el5 (mockbuild@x86-012.build.bos.redhat.com) (gcc version 4.1.2 20080704 (Red Hat 4.1.2-50)) #1 SMP Sun Dec 19 14:22:44 EST 2010
[root@SOR_SYS ~]#
2)[root@SOR_SYS ~]# uname -r
2.6.18-238.el5
3)[root@SOR_SYS ~]# uname -a
Linux SOR_SYS.99bill.com 2.6.18-238.el5 #1 SMP Sun Dec 19 14:22:44 EST 2010 x86_64 x86_64 x86_64 GNU/Linux
[root@SOR_SYS ~]#
二。查看linux版本:
1) 登录到服务器执行 lsb_release -a ,即可列出所有版本信息,例如:
[root@SOR_SYS ~]# lsb_release -a
LSB Version: :core-4.0-amd64:core-4.0-ia32:core-4.0-noarch:graphics-4.0-amd64:graphics-4.0-ia32:graphics-4.0-noarch:printing-4.0-amd64:printing-4.0-ia32:printing-4.0-noarch
Distributor ID: RedHatEnterpriseAS
Description: Red Hat Enterprise Linux AS release 4 (Nahant Update 4)
Release: 4
Codename: NahantUpdate4
[root@SOR_SYS ~]#
注:这个命令适用于所有的linux,包括Redhat、SuSE、Debian等发行版。
2) 登录到linux执行cat /etc/issue,例如如下:
[root@SOR_SYS ~]# cat /etc/issue
Red Hat Enterprise Linux Server release 5.6 (Tikanga)
Kernel \r on an \m
[root@SOR_SYS ~]#
3) 登录到linux执行cat /etc/redhat-release ,例如如下:
[root@SOR_SYS ~]# cat /etc/redhat-release
Red Hat Enterprise Linux AS release 4 (Nahant Update 4)
[root@SOR_SYS ~]#
注:这种方式下可以直接看到具体的版本号,比如 AS4 Update 1
4)登录到linux执行rpm -q redhat-release ,例如如下:
[root@SOR_SYS ~]# rpm -q redhat-release
redhat-release-5Server-5.6.0.3
-------------------------------------------------------------------------------------------------------------------------------
一.查看Linux系统是几位的操作系统
uname -a
二,查看Linux服务器的cpu 详细情况
1.具有相同core id的CPU是同一个core 的超线程,具有相同physical id 的CPU 是同一个CPU封装的线程或核心
查看物理CPU 个数如下
#cat /proc/cpuinfo|grep "physical id "|sort|uniq|wc -l 真实机
查看个物理CPU中core 的个数(即核数)如下所示:
cat /proc/cpuinfo/grep ''cpu coress " |uniq
产看逻辑cpu 的个数
#cat /proc/cpuinfo |grep "processor"|wc -l 所有的机器
三. 查看Linux 服务器的内存使用情况
free -m
total:内存的总数
used:已经使用的内存数
free:空闲的内存数
shared :多个进程共享的内存总额,当数值是0表示当前已经废弃不用。
-buffers/cache:(已用)的内存数,即used-buffers-cached (这里used 是第一行的used,buffers和cached 也是第一行的)
+buffers/cache:(可用)的内存数,即free+buffers+cached (这里used是第一行的used,buffers和cached 也是第一样的)
在linux 系统下,只要swap 的交换空间没有使用或者说用的很少,说明我们的物理内存够用。
四查看Linux服务器的硬盘使用情况
1.查看硬盘分区信息
fdisk -l
2.查看文件系统的硬盘空间占用情况
df -h
3.查看硬盘的i/0性能
注:iostat 是含在套装sysstat 中的,yum install sysstat -y
iostat -d -x -k 1 10
iostat -x 1 5 :查看iostat 的返回结果
rrqm/s:每秒进行merge的读操作数目,即delta (rmerge)/s
wrqm/s :每秒进行merge的写操作数目,即delta (wmerge)/s
r/s:每秒完成的读i/o 设备次数,即delta(rio)/s
w/s:每秒完成的写i/o 设备次数,即delta(wio)/s
rsec/s:每秒读扇区数,即delta (rsect)/s
wsec/s:每秒写扇区数,即delta (rsect)/s
rkb/s:每秒读k字节数,即rsec/s的一半,因为每扇区大小为512字节。
wkb/s:每秒写k字节数,是wsec/s的一半
avgrp-sz:平均每次设备I/O操作的数据大小(即扇区),即delta(reset+wset)/delta(rio+wio)
avgqu-sz:平均I/O队列的长度,即delta(aveq)/s/1000 (除以1000 因为aveq的单位为毫秒)。
await :平均每次设备I/O操作的服务服务时间(单位:毫秒),即delat(ruse+wuse)/delta (rio+wio)
svctm :平均每次设备I/O操作的服务时间(单位:毫秒),即delta(use)/delta(rio+wio).
%util :一秒中有百分之多少的时间用于I/O操作,或者说一秒种有多少时间I/O队列是空的
注:
%util 接近100%,说明产生的I/0请求太多,I/O系统已经满负荷,该磁盘可能存在瓶颈
如果idle 小于70%,I/O的压力就比较大了,说明读取进程中有较多的wait.同时还可以结合vmstat 查看b
参数(等待资源的进程数)和wa参数(I/O等待所占用的CPU时间的百分比,高过30%时I/O的压力就比较高了
另外还可· ·以参考如下情况,svctm 应该小于await,因为同时等待请求的等待时间被重复计算了。一般来说,svctm
的大小和磁盘性能有关,cpu/内存的负荷也会对其有一定的影响,请求过多就会间接导致svctm增加
await 的大小一般取决于服务时间(svntm)以及I/O队列的长度和I/O 请求的发出模式,如果svntm 比较接近await
,说明I/O几乎没有等待时间;如果await 远大于说明I/O队列太长
4.产看Linux 系统中某目录的大小,这个比较常用,可以用du -sh 目录名来查看
#du -sh /root
检查是否有分区使用率(use%)过高(比如超过90%)的情况,如果发现某个分区空间接近用完,可以进入该分区
的挂载点,可以用以下命令找出占用空间最多的文件或目录,然后按照从大到小的顺序,找出系统中占用
最多空间的前10个文件或目录。
#du -cks *|sort -rn|head -n 10
5.dd 命令在linux 系统中也经常用,
用dd 命令可以把指定的输入文件拷贝到指定的输出文件中,并且在拷贝过程中可以进行格式转换。
我碰到的几个需要用到dd命令的地方如下
dd if=/dev/zero of =/swapfile bs=1024 count=65535
#mkswap swapile
swapon swapfile
方法二
新建swap
mkswap /dev/sdb2 格式化
swapon /dev/sdb2 挂载上
-----------------------------------
制作ISO 镜像
dd if=/dev/cdrom of=/root/cd1.ios
-------------------------------------------------------------
linux 系统的平均负载的概念:有的时候我们觉得系统的响应时间很慢,所以在web 或系统变慢的第一时间变慢
时的第一时间查看系统的负载,即CPU 的平均负载
uptime
w :查看系统当前有哪些用户,他们占用了哪些的终端,另外还有top ,这个命令可以反映系统负载情况。top
显示的首行和uptime的首行查看一下
原来它所表示的是过去的1分钟
--------------------------------
获得nginx 的pid
ps -aux|grep 'nginx: master'|grep -v 'grep nginx'|awk '{print $2}'
可以使用一下命令查使用内存最多的5个进程
ps -aux | sort -k4nr | head 5
或者
top (然后按下M,注意大写)
可以使用一下命令查使用CPU最多的5个进程
ps -aux | sort -k3nr | head 5
或者
top (然后按下P,注意大写)
-------------------------------------------------------------
查看是32 或者64 位的系统
ls -lF /|grep lib64
另外一种常见方法是通过file 命令
file /sbin/init
----------------------------------------------------------------------------
查看服务器使用的Linux发行版本的相关信息
Linux 发行版的名称、版本、号以及描述的信息等
lsb_release -a
如果没有lsb_release 没有这个命令可以 用yum install redhat-lsb 来安装
------------------------------------------------------------------------------------------------------------
查看系统已载入的相关模块
Linux操作系统的和核心具有模块化的作用,因此在编译核心时,务虚把所有的功能都放入核心,可以将这
些功能编译成一个个单独的模块,带需要的时候在分别载入。在配置lvs+keepalived 时,我们经常来查看lvs
模块是否已经载入。