Linux机器-网卡磁盘监控
1)实时监控网卡流量的通用脚本:
|
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
[root@ceph-node1 ~]# cat /root/net_monit.sh#!/bin/bashPATH=/bin:/usr/bin:/sbin:/usr/sbin:/usr/local/bin:/usr/local/sbin;export PATHfunction traffic_monitor { OS_NAME=$(sed -n '1p' /etc/issue) eth=$1 if [ ! -d /sys/class/net/$eth ];then echo -e "Network-Interface Not Found" echo -e "You system have network-interface:\n`ls /sys/class/net`" exit 5 fi while [ "1" ] do STATUS="fine" RXpre=$(cat /proc/net/dev | grep $eth | tr : " " | awk '{print $2}') TXpre=$(cat /proc/net/dev | grep $eth | tr : " " | awk '{print $10}') sleep 1 RXnext=$(cat /proc/net/dev | grep $eth | tr : " " | awk '{print $2}') TXnext=$(cat /proc/net/dev | grep $eth | tr : " " | awk '{print $10}') clear RX=$((${RXnext}-${RXpre})) TX=$((${TXnext}-${TXpre})) if [[ $RX -lt 1024 ]];then RX="${RX}B/s" elif [[ $RX -gt 1048576 ]];then RX=$(echo $RX | awk '{print $1/1048576 "MB/s"}') $STATUS="busy" else RX=$(echo $RX | awk '{print $1/1024 "KB/s"}') fi if [[ $TX -lt 1024 ]];then TX="${TX}B/s" elif [[ $TX -gt 1048576 ]];then TX=$(echo $TX | awk '{print $1/1048576 "MB/s"}') else TX=$(echo $TX | awk '{print $1/1024 "KB/s"}') fi echo -e "===================================" echo -e "Welcome to Traffic_Monitor stage" echo -e "version 1.0" echo -e "Since 2018.7.2" echo -e "Created by wangshibo" echo -e "BLOG: http://www.cnblogs.cn/kevingrace" echo -e "===================================" echo -e "System: $OS_NAME" echo -e "Date: `date +%F`" echo -e "Time: `date +%k:%M:%S`" echo -e "Port: $1" echo -e "Status: $STATUS" echo -e " \t RX \tTX" echo "------------------------------" echo -e "$eth \t $RX $TX " echo "------------------------------" echo -e "Press 'Ctrl+C' to exit" done}if [[ -n "$1" ]];then traffic_monitor $1else echo -e "None parameter,please add system netport after run the script! \nExample: 'sh traffic_monitor eth0'"fi[root@ceph-node1 ~]# chmod 755 /root/net_monit.sh[root@ceph-node1 ~]# sh /root/net_monit.sh eth0 #eth0是网卡设备名称,如果是网卡绑定bond0,后面就跟bond0===================================Welcome to Traffic_Monitor stageversion 1.0Since 2018.7.2Created by wangshiboBLOG: http://www.cnblogs.cn/kevingrace===================================System: CentOS release 6.9 (Final)Date: 2018-07-02Time: 15:19:34Port: eth0Status: fine RX TX------------------------------eth0 417B/s 390B/s------------------------------Press 'Ctrl+C' to exit===================================Welcome to Traffic_Monitor stageversion 1.0Since 2018.7.2Created by wangshiboBLOG: http://www.cnblogs.cn/kevingrace===================================System: CentOS release 6.9 (Final)Date: 2018-07-02Time: 15:19:35Port: eth0Status: fine RX TX------------------------------eth0 1.49902KB/s 1.3252KB/s------------------------------Press 'Ctrl+C' to exit |
2)监控磁盘的监控脚本
|
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
[root@ceph-node1 ~]# cat disk_monit.sh#!/bin/bash#filename:Monitor_DiskMonitor_Disk(){mkdir -p /mnt/Monitor_Diskfdisk -l|grep "Disk /dev/" | awk '{print $2,$3$4}'|tr -d ',:'>/mnt/Monitor_Disk/device_list.logN=1;ECHO 90while read device_linedoDevice=`echo $device_line|awk '{print $1}'`Sum=`echo $device_line|awk '{print $2}'`df -h |grep "$Device"|sort>/mnt/Monitor_Disk/${N}_partitions.logechoecho "** 第$N块硬盘($Device):${Sum} **"| grep -E "$Device|$Sum|$N" --color=yesecho "------------------------------------"echo -e "linux分区 挂载目录 总大小 已用 剩余 已用百分比 文件系统 ID system \块大小 预留空间 ">/mnt/Monitor_Disk/${N}_Over.logecho -e "========= ======== ===== === === ========== ======= == ====== \====== ======== ">>/mnt/Monitor_Disk/${N}_Over.logNum_Partition=`cat /mnt/Monitor_Disk/${N}_partitions.log|wc -l`n=0while read partition_linedo Partition_Name=`echo $partition_line|awk '{print $1}'` Mount_Dir=`echo $partition_line|awk '{print $6}'` Partition_Sum=`echo $partition_line|awk '{print $2}'` Partition_Used=`echo $partition_line|awk '{print $3}'` Partition_Leave=`echo $partition_line| awk '{print $4}'` Partition_Percent=`echo $partition_line|awk '{print $5}'` Partition_Type=`mount|grep $Partition_Name|awk '{print $5$6}'` Partition_Id=`fdisk -l | grep $Partition_Name|tr -d '\*'|awk '{print $5}'` Partition_System=`fdisk -l | grep $Partition_Name|tr -d '\*'|awk '{print $6}'` Part_Block_Size_B=`tune2fs -l $Partition_Name|grep "Block size"|awk '{print $3}'` Part_Lift_For_Root_Blocks=`tune2fs -l $Partition_Name|grep "Reserved block count:"|\ awk '{print $4}'` Part_Block_Size=`echo $Part_Block_Size_B/1024|bc` Part_Lift_For_Root=`echo ${Part_Lift_For_Root_Blocks}*${Part_Block_Size}/1024|bc` echo -e "$Partition_Name $Mount_Dir $Partition_Sum $Partition_Used $Partition_Leave \$Partition_Percent $Partition_Type $Partition_Id $Partition_System \${Part_Block_Size}K ${Part_Lift_For_Root}M">>/mnt/Monitor_Disk/${N}_Over.log let n++ [ $n -eq $Num_Partition ]&&(cat /mnt/Monitor_Disk/${N}_Over.log|column -t;echo)done</mnt/Monitor_Disk/${N}_partitions.loglet N++done</mnt/Monitor_Disk/device_list.logECHO 90rm -fr /mnt/Monitor_Disk}ECHO(){for ((i=1;i<=$1;i++))doecho -n "#"[ $i -eq $1 ]&&(echo;echo)done}Monitor_Disk[root@ceph-node1 ~]# chmod 755 disk_monit.sh[root@ceph-node1 ~]# sh disk_monit.sh##########################################################################################** 第1块硬盘(/dev/sdb):577.4GB **------------------------------------linux分区 挂载目录 总大小 已用 剩余 已用百分比 文件系统 ID system 块大小 预留空间========= ======== ===== === === ========== ======= == ====== ====== ========/dev/sdb1 /data 530G 42G 461G 9% ext4(rw) 83 Linux 4K 27532M** 第2块硬盘(/dev/sda):322.1GB **------------------------------------linux分区 挂载目录 总大小 已用 剩余 已用百分比 文件系统 ID system 块大小 预留空间========= ======== ===== === === ========== ======= == ====== ====== ========/dev/sda1 /boot 283M 76M 193M 29% ext4(rw) 83 Linux 1K 15M/dev/sda3 / 265G 3.1G 248G 2% ext4(rw) 83 Linux 4K 13744M########################################################################################## |
Linux机器-网卡磁盘监控的更多相关文章
- 监控linux服务器网卡流量
监控linux服务器网卡流量 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 欢迎加入:高级运维工程师之路 598432640 前言:众所周知,我们安装zabbix服务器 ...
- PHP获取网卡的MAC地址原码;目前支持WIN/LINUX系统 获取机器网卡的物理(MAC)地址
声明转换于其它博客当中的. <?php /** 获取网卡的MAC地址原码:目前支持WIN/LINUX系统 获取机器网卡的物理(MAC)地址 **/ class GetMacAddr{ var $ ...
- cacti监控linux和windows磁盘IO
cacti监控linux和windows磁盘IO 标签:cacti linux磁盘IO windows磁盘IO 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则 ...
- Linux简单Shell脚本监控MySQL、Apache Web和磁盘空间
Linux简单Shell脚本监控MySQL.Apache Web和磁盘空间 1. 目的或任务 当MySQL数据库.Apache Web服务器停止运行时,重新启动运行,并发送邮件通知: 当服务器磁盘的空 ...
- 【转载】Linux系统与性能监控
原文地址:http://kerrigan.sinaapp.com/post-7.html Linux System and Performance Monitoring http://www.hous ...
- Linux系统与性能监控
原文地址:http://kerrigan.sinaapp.com/post-7.html Linux System and Performance Monitoring http://www.hous ...
- Linux 服务器运行健康状况监控利器 Spotlight on Unix 的安装与使用
1.本文背景 1.1.Linux 服务器情况 # cat /etc/issueRed Hat Enterprise Linux Server release 6.1 (Santiago)Kernel ...
- Linux系统和性能监控之CPU篇
Linux系统和性能监控之CPU篇 性能优化就是找到系统处理中的瓶颈以及去除这些的过程.本文由sanotes.net站长tonnyom在2009年8月翻译自Linux System and Perfo ...
- Linux双网卡绑定bond详解--单网卡绑定多个IP
Linux双网卡绑定bond详解 1 什么是bond 网卡bond是通过多张网卡绑定为一个逻辑网卡,实现本地网卡的冗余,带宽扩容和负载均衡,在生产场景中是一种常用的技术.Kernels 2.4.12及 ...
随机推荐
- Python代码结构——顺序、分支、循环
## 顺序结构 - 按照从上到下的顺序,一条语句一条语句的执行,是最基本的结构 ## 分支结构 if condition: statement statement ... elif condition ...
- tomcat 无论如何都无法创建新的Servers
1.退出eclipse 2.到[工程目录下 workspace ]/.metadata/.plugins/org.eclipse.core.runtime 3.把org.eclipse.wst.ser ...
- 笔记-爬虫-scrapy-srcapy-redis组件
笔记-爬虫-scrapy-srcapy-redis组件 1. 简介 scrapy是一个爬虫框架,但不支持分布式,scrapy-redis是为了更方便的实现scrapy分布式爬虫的组件. 可以 ...
- tar命令,vi编辑器
一.将用户信息数据库文件和组信息数据库文件纵向合并为一个文件/1.txt(覆盖): [root@localhost /]# cat /etc/passwd /etc/group > 1.txt ...
- Android 数据库中的数据给到ListView
前言:因为之前学的都是用一个自己定义的类,完成将某一个bean中的数据直接获取,而实际中通常是通过数据库来得到的,总之,最终就是要得到数据.提一下最重要的东西,我把它叫做代理,如同一个校园代理,没有他 ...
- 2,Python常用库之二:Pandas
Pandas是用于数据操纵和分析,建立在Numpy之上的.Pandas为Python带来了两种新的数据结构:Pandas Series和Pandas DataFrame,借助这两种数据结构,我们能够轻 ...
- 4.bootstrap的form表单的form-group和form-control的区别与联系
1. form-group一般用于div form-control一般用于置于div中的标签元素,为了让控件在各种表单风格中样式不出错,需要添加类名“form-control”,如: <form ...
- iOS算法笔记-快速排序-OC实现
快速排序(Quicksort)是对冒泡排序的一种改进. 快速排序由C. A. R. Hoare在1962年提出.它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另 ...
- python学习笔记十七:base64及md5编码
一.Python Base64编码 Python中进行Base64编码和解码要用base64模块,代码示例: #-*- coding: utf-8 -*- import base64 str = 'c ...
- Canvas 图形组合方式
/** * 图形组合 */ function initDemo5() { var canvas = document.getElementById("demo5"); if (!c ...