linux服务器连接数查询
作者:互联网
linux服务器环境检查
CPU、内存使用情况
查看系统整体执行情况
- 命令执行
# 查看当前系统正在执行的进程的相关信息,包括进程ID、内存占用率、CPU占用率等
top
# 返回结果
# 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的时候就表明系统在超负荷运转了。
top - 14:06:23 up 70 days, 16:44, 2 users, load average: 1.25, 1.32, 1.35
# Tasks — 任务(进程)。系统现在共有206个进程,其中处于运行中的有1个,205个在休眠(sleep),stoped状态的有0个,zombie状态(僵尸)的有0个。
Tasks: 206 total, 1 running, 205 sleeping, 0 stopped, 0 zombie
# 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.2% si — 软中断(Software Interrupts)占用CPU的百分比
Cpu(s): 5.9%us, 3.4%sy, 0.0%ni, 90.4%id, 0.0%wa, 0.0%hi, 0.2%si, 0.0%st
# 内存状态
# 32949016k total — 物理内存总量(32GB)
# 14411180k used — 使用中的内存总量(14GB)
# 18537836k free — 空闲内存总量(18GB)
# 169884k buffers — 缓存的内存量 (169M)
Mem: 32949016k total, 14411180k used, 18537836k free, 169884k buffers
# swap交换分区信息
# 32764556k total — 交换区总量(32GB)
# 0k used — 使用的交换区总量(0K)
# 32764556k free — 空闲交换区总量(32GB)
# 3612636k cached — 缓冲的交换区总量(3.6GB)
Swap: 32764556k total, 0k used, 32764556k free, 3612636k cached
# 系统进程列表
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
28894 root 22 0 1501m 405m 10m S 52.2 1.3 2534:16 java
查看单个进程执行情况
# 查询进程id
ps -ef
# 根据如上PID查
top -p <PID>
内存使用
free -m
# total: 内存总数2586752
# used: 已经使用的内存2098752
# free: 空闲内存数488000
# shared: 当前废弃不用内存,0
# buffers: 缓冲内存数160032,正用于写入的写缓冲区
# cached: 缓存数890292,证用于读的缓冲区
total used free shared buffers cached
Mem: 2586752 2098752 488000 0 160032 890292
# - buffers/cache = used – buffers – cached = 1048428,实际上被程序上真正吃掉的内存
# + buffers/cache = free + buffers + cached = 1538324,实际还可以挪用的内存
-/+ buffers/cache: 1048428 1538324
Swap: 1060248 0 1060248
端口使用
查看端口占用
# 查看8080端口的占用情况
losof -i :8080
# 同样适用netstat实现
netstat -tlnup | grep 8080
查看端口连接情况
# 统计当前在连80端口的进程有多少
# netstat -an会打印系统当前网络链接状态,
# grep -i “80″是用来提取与80端口有关的连接的
# wc -l进行连接数统计
netstat -nat|grep -i "80"|wc -l
# 查出每个IP地址连接数
netstat -na | grep ESTABLISHED | awk '{print$5}' | awk -F : '{print$1}' |sort |uniq -c | sort -r
# 查出端口连接情况
# CLOSED:无连接是活动的或正在进行
# LISTEN:服务器在等待进入呼叫
# SYN_RECV:一个连接请求已经到达,等待确认
# SYN_SENT:应用已经开始,打开一个连接
# ESTABLISHED:正常数据传输状态
# FIN_WAIT1:应用说它已经完成
# FIN_WAIT2:另一边已同意释放
# ITMED_WAIT:等待所有分组死掉
# CLOSING:两边同时尝试关闭
# TIME_WAIT:另一边已初始化一个释放
# LAST_ACK:等待所有分组死掉
netstat -n | awk '/^tcp/ {++state[$NF]} END {for(key in state) print key,"\t",state[key]}'
更多建议:
https://www.jianshu.com/p/302bbc539d0c
标签:free,连接数,内存,linux,服务器,total,CPU,buffers,0.0% 来源: https://www.cnblogs.com/chendeming/p/16480147.html