全球主机交流论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

CeraNetworksSS大流量主机交流
IP归属甄别会员请立即修改密码FDC不限流量服务器
查看: 59296|回复: 132

Linux系统监测

[复制链接]
发表于 2009-6-29 01:44:25 | 显示全部楼层 |阅读模式
额 掉C大的坑里了 无奈整理此贴
小生在此 与大家共享下
本人在网上收集来的 还有一些个人想到的 监测方法



(PS:三楼,四楼的监测我采用的是短信报警的方式)
(PS:五楼,六楼的监测我就不写发送方法了,请大家根据自己的需要来设置)
(PS:五楼,六楼的我只是给出了一个开头,因为我暂时用不上所以我没有添加应用,如果谁需要,可以自行添加预警值)


本贴附件均已上传至 Google Code  地址为 http://code.google.com/p/htooy/


  1. 下面几楼的脚本中的 " 等于  英文的引号  请自行替换
复制代码

评分

参与人数 1威望 +25 收起 理由
Godaddy + 25 精品文章

查看全部评分

 楼主| 发表于 2009-6-29 01:44:47 | 显示全部楼层
监测时所需用到得 发送信息的工具

Fetion 机器人
我用的是
http://bbs.it-adv.net/viewthread.php?tid=155
中提到的Fetion机器人(其框架对监测没什么用处可以删除)
方法上面页面也有提到
(PS:此机器人的作者说未注册的有广告,我用了一段时间,只见我飞信的心情被改过一次,再没见过其他广告)


GTalk API
用到是
http://code.google.com/p/xmpphp/
方法见 此页http://www.joecen.com/2008/05/09/google-talk-php-api-xmpphp/


MSN API
用到的是
http://code.google.com/p/phpmsnclass/
方法可以参考 张大 的文章 http://blog.s135.com/post/390/
我就不再阐述了


Mail
我懒得配置 sendmail 所以直接配了个ssmtp(我用的是Debian 我没在CentOS中测试过)
(PS:我选择的是用 ssmtp + gmail 的搭配发送邮件)


 楼主| 发表于 2009-6-29 01:45:08 | 显示全部楼层
发生系统登录事件 发送短信通知管理员

(PS:不知道有没有人和我一样闲通知登陆事件)

修改 /etc/profile
  1. vi /etc/profile
复制代码

按 Shift+G 跳至最后一行
在最后加入一下一行内容
  1. LD_LIBRARY_PATH=. /飞信机器人的路径/fetion --config=sample.conf --index=1 --to=接收用的手机号 --msg-utf8=Hi!刚才["`date +%X`"]有人登陆了系统.登陆IP是["`last | head -1 | awk '{print $3}'`"],用户名是["`last | head -1 | awk '{print $1}'`"]. 2>&1
复制代码


 楼主| 发表于 2009-6-29 01:45:39 | 显示全部楼层
固定时间监测指定TCP端口

此处使用的是张大写的监测程序
  1. #!/bin/sh
  2. LANG=C
  3. server_all_list=( \
  4. 127.0.0.1:80 \
  5. )
  6. date=$(date -d "today" +"%Y-%m-%d_%H:%M:%S")

  7. send_msg_to()
  8. {
  9.         if [ $2 = "0" ] || [ $2 = "2" ]; then
  10.                 LD_LIBRARY_PATH=. /飞信机器人的路径/fetion --config=sample.conf --index=1 --to=接收用的手机号 --msg-utf8=$1
  11.         fi;
  12. }
  13. server_all_len=${#server_all_list[*]}
  14. i=0
  15. while  [ $i -lt $server_all_len ]
  16. do
  17.    server_ip=$(echo ${server_all_list[$i]} | awk -F ':' '{print $1}')
  18.    server_port=$(echo ${server_all_list[$i]} | awk -F ':' '{print $2}')
  19.    server_message=" "
  20.    if curl -m 10 -G http://${server_all_list[$i]}/ > /dev/null 2>&1
  21.    then
  22.      #status:    0,http down    1,http ok    2,http down but ping ok
  23.      status=1
  24.            echo "服务器${server_ip},端口${server_port}能够正常访问!";
  25.                    server_message="服务器${server_ip},端口${server_port}能够正常访问!";
  26.    else
  27.        if curl -m 30 -G http://${server_all_list[$i]}/ > /dev/null 2>&1
  28.        then
  29.            status=1
  30.            echo "服务器${server_ip},端口${server_port}能够正常访问!"
  31.                    server_message="服务器${server_ip},端口${server_port}能够正常访问!";
  32.        else
  33.            if ping -c 1 $server_ip > /dev/null 2>&1
  34.            then
  35.                status=2
  36.                echo "服务器${server_ip},端口${server_port}无法访问,但是能够Ping通!";
  37.                            server_message="服务器${server_ip},端口${server_port}无法访问,但是能够Ping通!";
  38.            else
  39.                status=0
  40.                echo "服务器${server_ip},端口${server_port}无法访问,并且无法Ping通!";
  41.                            server_message="服务器${server_ip},端口${server_port}无法访问,并且无法Ping通!";
  42.            fi
  43.        fi
  44.    fi
  45. send_msg_to "${server_message}" "${status}";
  46.    let i++
  47. done
复制代码


 楼主| 发表于 2009-6-29 01:46:00 | 显示全部楼层
代码丢了 等我有时间再补上

 楼主| 发表于 2009-6-29 01:46:27 | 显示全部楼层
系统资源使用状况

  1. #!/bin/sh
  2. LANG=zh_cn
  3. 此处使用代码在下面给出请挑选自己需要的信息
  4. date=$(date -d "today" +"%Y-%m-%d_%H:%M:%S")
  5. ip=$(/sbin/ifconfig | grep "inet addr" | grep -v "127.0.0.1" | awk '{print $2;}' | awk -F':' '{print $2;}' | tr -s '\n' ';')
复制代码


DISK使用状况
  1. disk=$(df -h | grep "/dev/" | grep -v "tmp" | awk -F'/dev/' '{print $2}' | awk '{print "硬盘总空间为"$2"--已用"$3"--可用"$4"--已用比例"$5}')
复制代码


物理内存总大小
  1. totalmem=$(/usr/bin/free -m | grep Mem | awk '{print "物理内存共有"$2"MB"}')
复制代码


物理内存已使用
  1. usedmem=$(/usr/bin/free -m | grep Mem | awk '{print "物理内存已使用"$3"MB"}')
复制代码


物理内存空闲
  1. freemem=$(/usr/bin/free -m | grep Mem | awk '{print "物理内存空闲"$4"MB"}')
复制代码


Cache化内存
  1. cachedmem=$(/usr/bin/free -m | grep Mem | awk '{print "Cache化内存"$7"MB"}')
复制代码


Swap已使用
  1. swapmem=$(/usr/bin/free -m | grep Swap | awk '{print "Swap区共有"$2"MB--已用"$3"MB--空闲"$4"MB"}')
复制代码


负载信息
  1. load=$(/usr/bin/uptime | awk -F'load average: ' '{print $2}' | awk '{print $1$2$3}')
复制代码


网卡流量
  1. netRT=$(cat /proc/net/dev | grep "eth0:" | awk -F'eth0:' '{print $2}' | awk '{print $1"已接收的字节--"$9"已传输的字节"}')
复制代码


 楼主| 发表于 2009-6-29 01:46:46 | 显示全部楼层
发送信息的结果
(PS:所发shell本人均在Debian下测试通过,其他的Linux发行本未测试)

三楼的
Hi!刚才[00时00分00秒]有人登陆了系统.登陆IP是[127.0.0.1],用户名是[root]


四楼的(两种结果)
第一种是
服务器127.0.0.1,端口80无法访问,但是能够Ping通!


第二种是
服务器127.0.0.1,端口80无法访问,并且无法Ping通!


五楼的
(此处留空)

六楼的
硬盘 DISK
硬盘总空间为30G--已用2.9G--可用26G--已用比例11%


我VPS的 free -m 的回显信息
server:~# free -m
             total       used       free     shared    buffers     cached
Mem:           320        314          5          0         55        164
-/+ buffers/cache:         95        224
Swap:          511          0        511


时间 date
2009-06-29_00:00:00


IP地址
127.0.0.1


物理内存总大小 totalmem
物理内存共有320MB


物理内存已使用 usedmem
物理内存已使用314MB


物理内存空闲 freemem
物理内存空闲5MB


Cache化内存 cachedmem
Cache化内存164MB


Swap已使用 swapmem
Swap区共有511MB--已用0MB--空闲511MB


负载信息 load
0.00,0.00,0.00


网卡流量 netRT
415355145已接收的字节--282828691已传输的字节


 楼主| 发表于 2009-6-29 01:47:03 | 显示全部楼层
PS: 本贴附件均已上传至 Google Code  地址为 http://code.google.com/p/htooy/
--------------
PHP探针
2009-12-15:添加了网卡流量的显示(感谢GDTV的代码帮助)
2009-12-13晚:添加了php默认支持函数的相关信息
2009-12-13:完善了CPU信息,添加了一些php信息
2009-10-24:在页脚添加了代码执行时间的回显
2009-07-28:在iprober的基础上,增删了部分代码
--------------
系统信息实时查看
工具简介
本工具使用PHP语言编写,用Json+Ajax的方式,
使系统相关信息达到无刷新实时回显的目的.
这个工具可用于查看多个主机的信息.
文件结构
jquery.min.js  放置于监控端
monitor.php    放置于监控端用于查看
status.php     放置于受控段用于生成信息
下载后请依次修改
monitor.php 与 status.php
这两个文件开头部分设置区中的内容,
其中已给出注释,可根据注释进行修改.
修改完直接上传至WEB空间即可.<

Changes with 1.0                                         15 Feb 2011
      *) Feature: 资源预警-->负载信息,空间使用率,真实内存使用率,Swap内存使用率.

Changes with 0.9                                         12 Feb 2011
      *) Feature: IPv6连接信息-->当前TCP/UDP连接数统计,
                                 当前TCP/UDP连接状态统计,
                                 当前TCP/UDP连接IP显示.
      *) Change:  优化部分代码.

Changes with 0.8                                          8 Feb 2011
      *) Feature: IPv4连接信息-->当前TCP/UDP连接数统计,
                                 当前TCP/UDP连接状态统计,
                                 当前TCP/UDP连接IP显示.
      *) Change:  优化部分代码.

Changes with 0.7                                          6 Feb 2011
      *) Bugfix:  物理内存信息-->内存使用率.
                  Swap内存详情-->Swap内存使用率.
      *) Feature: 物理内存信息-->真实已用内存,真实内存使用率.

Changes with 0.6                                          5 Feb 2011
      *) Feature: 系统时间-->开机时间.

Changes with 0.5                                          1 Feb 2011
      *) Bugfix:  磁盘信息-->空间使用率.

Changes with 0.4                                         31 Jan 2011
      *) Bugfix:  两处php短连接格式.

Changes with 0.3                                         31 Jan 2011
      *) Feature: 网卡信息-->网卡数量,网卡流量.

Changes with 0.2                                         28 Jan 2011
      *) Feature:  磁盘信息-->剩余空间,总计空间,空间使用率.
                   内存信息-->物理内存详情-->总计内存,已用内存,缓冲区使用,空闲内存,内存使用率.
                              Swap内存详情-->总计Swap内存,已用Swap内存,空闲Swap内存,Swap内存使用率.
                   负载信息-->一分钟负载,五分钟负载,十五分钟负载,进程.
                   系统时间-->运行时间,空闲时间,服务器时间,北京时间.
                   MySQL状态-->只是简单的测试能否链接.
      *) Security: B/S 简单的安全验证.

Changes with 0.1                                         20 May 2010
      *) The first version.
         使用json+ajax实现了部分信息实时刷新,此版本为暂未完成的测试版.
--------------
系统信息查看
2009-12-08:重新添加了连接状态信息(已解决无法多行显示bug),并增加了连接IP数统计
2009-11-02:增加了Inode信息,取消了连接状态信息
下载后请修改
$net="eth1:";  //网卡编号
$disk="/dev/hda1";  //网卡编号

2009-08-29:可查看当前系统的常用综合信息,主要针对手机
下载后请修改$net="eth0:";  //网卡编号
--------------
Linux版在线CMD
2009-12-12:Linux版的在线CMD,可以执行linux下的基本命令,如果权限够可以执行几乎所有命令,并会自动生成日志
(PS:PHP必须支持system函数)
不过需要注意不要执行像 ping 127.0.0.1 这样的不会自动停止的命令,那样将会造成进程永远存在和页面无反应,如需执行可以执行 ping -c 4 127.0.0.1 这样的命令,请一定注意...
--------------
php版端口在线检测
2009-12-20:php版的端口在线检测工具,这里就不多做介绍了,需要的人一看就明白
代码非我原创,不过原作者不详,我只是在源代码的基础上进行了更改
--------------
简单主机工具
2009-07-28:本工具纯属个人无聊时所写 功能非常不完善 停更


--------------
PHP探针   index.zip (7.41 KB, 下载次数: 539)

评分

参与人数 1威望 +5 收起 理由
dianso + 5 sysinfo(2011-01-28) 这个太好用了,感谢 ...

查看全部评分

发表于 2009-6-29 01:58:52 | 显示全部楼层
做个标记,明天早上早起来看,
 楼主| 发表于 2009-6-29 02:02:57 | 显示全部楼层
我都还在编辑呢 你就来看 晕 我下次 早上4点在发帖 我看你还是不是 第一名 嘿嘿
OK了 完工 洗澡 呼呼 去啦 嘿嘿



------------------------------------------------------------------
以下内容为转载,如有不妥请及时联系马上删除
Shell 相关
测试运算
数值测试运算
-eq 判断两个数字是否相等,相等返回“0”,不相等返回“1”
-ge 判断第一个数字是否大于等于第二个数字,大于等于返回0,小于返回“1”
-gt 判断第一个数字是否大于第二个数字,大于返回“0”,不大于返回“1”
-le 判断第一个数字是否小于等于第二个数字,小于等于返回“0”,大于返回“1”
-lt 判断第一个数字是否小于第二个数字,小于返回“0”,不小于返回“1”
-ne 判断两个数不相等,不相等返回“0” ,相等返回“1”
字符串运算测试
string1 = string2   如果两个字符串相等则返回true, 否则返回false。
string1 != string2  如果两个字符串不相等则返回true, 否则返回false。
string1 > string2   如果string 1 大于 string2, 则返回true ,否则返回false。
string1 < string2   如果string 1小于string 2 , 则返回true,否则返回false。
-n string:  如果字符中长度大于0,则返回true , 否则返回false; 通常可以省略-n  
-z string:  如果字符串的长度等于0,则返回true, 否则返回false。

文件测试运算
-d filename  判断filename 是否为目录,是则返回0,否则返回1
-f filename  判断filename 是否为文件,是则返回0,否则返回1
-r filename  判断filename 是否可读, 是则返回0,否则返回1
-w filename  判断filename 是否可写, 是则返回0,否则返回1
-x filename  判断filename 是否可执行, 是则返回0,否则返回1
-L filename  判断filename 是否是一个符号链接文件, 是则返回0,否则返回1
-s filename  判断filename 的长度是否大于0, 是则返回0,否则返回1
-u filename  判断filename 是否有suid位设置, 是则返回0,否则返回1

-e        文件存在
-a        文件存在
        这个选项的效果与-e相同.但是它已经被弃用了,并且不鼓励使用
-f        file是一个regular文件(不是目录或者设备文件)
-s        文件长度不为0
-d        文件是个目录
-b        文件是个块设备(软盘,cdrom等等)
-c        文件是个字符设备(键盘,modem,声卡等等)
-p        文件是个管道
-h        文件是个符号链接
-L        文件是个符号链接
-S        文件是个socket
-t        关联到一个终端设备的文件描述符
        这个选项一般都用来检测是否在一个给定脚本中的stdin[-t0]或[-t1]是一个终端
-r        文件具有读权限(对于用户运行这个test)
-w        文件具有写权限(对于用户运行这个test)
-x        文件具有执行权限(对于用户运行这个test)
-g        set-group-id(sgid)标志到文件或目录上
        如果一个目录具有sgid标志,那么一个被创建在这个目录里的文件,这个目录属于创建
        这个目录的用户组,并不一定与创建这个文件的用户的组相同.对于workgroup的目录
        共享来说,这非常有用.见<<UNIX环境高级编程中文版>>第58页.
-u        set-user-id(suid)标志到文件上
        如果运行一个具有root权限的文件,那么运行进程将取得root权限,即使你是一个普通
        用户.[1]这对于需要存取系统硬件的执行操作(比如pppd和cdrecord)非常有用.如果
        没有suid标志的话,那么普通用户(没有root权限)将无法运行这种程序.
        见<<UNIX环境高级编程中文版>>第58页.
           -rwsr-xr-t    1 root       178236 Oct  2  2000 /usr/sbin/pppd
        对于设置了suid的文件,在它的权限标志中有"s".
-k        设置粘贴位,见<<UNIX环境高级编程中文版>>第65页.
        对于"sticky bit",save-text-mode标志是一个文件权限的特殊类型.如果设置了这
        个标志,那么这个文件将被保存在交换区,为了达到快速存取的目的.如果设置在目录
        中,它将限制写权限.对于设置了sticky bit位的文件或目录,权限标志中有"t".
           drwxrwxrwt    7 root         1024 May 19 21:26 tmp/
        如果一个用户并不时具有stick bit位的目录的拥有者,但是具有写权限,那么用户只
        能在这个目录下删除自己所拥有的文件.这将防止用户在一个公开的目录中不慎覆盖
        或者删除别人的文件,比如/tmp(当然root或者是目录的所有者可以随便删除或重命名
        其中的文件).
-O        你是文件的所有者.
-G        文件的group-id和你的相同.
-N        从文件最后被阅读到现在,是否被修改.


复合测试运算
逻辑操作包括与、或,分别用“-a” 和 “-o”来表示。

流程控制语句
1、顺序执行语句:只要把语句按照逻辑顺序写好,Shell脚本解释器就会顺序地执行这些语句。
2、条件选择语句
if then  语句
if 条件表达式
then
   语句1
fi

if 条件表达式; then
   语句1
fi


if then  else 语句
if 条件表达式; then
   语句1
else
   语句2
fi


if 语句的嵌套语法是:
if  条件表达式1; then
语句1
else
  if 条件表达式2; then
     语句2
  else
     语句3
  fi
fi


if elif 语句

if [ $SYSTEM = "Linux" ] ; then
  echo "Linux"
elif [ $SYSTEM = "FreeBSD" ] ; then
  echo "FreeBSD"
elif [ $SYSTEM = "Solaris" ] ; then
  echo "Solaris"
else
  echo "What?"
fi

USER=`who |awk '{ print $1 }'`
if [ $USER = "root" ] ; then
  echo "root"
elif [ $USER = "cacti" ] ; then
  echo "cacti"
elif [ $USER = "nagios" ] ; then
  echo "nagios"
elif [ $USER = "mysql" ] ; then
fi


case 语句 就是一个变量的值与期望的值进行匹配
case $1 in
匹配值1)
   语句1
   语句2
   …………
   …………
   ;;
匹配值2)
   语句3
   语句
   …………
   …………
   ;;
匹配值3)
   语句5
   语句6
   …………
   …………
   ;;
esac



Shell 脚本中的循环语句包括:for 循环、while循环、until循环
for i  in k  g h
do
echo ok

done

while ls > /dev/null
do
echo ok
done

until aa > /dev/null
do
echo ok
done


函数
hello () {
echo ok
}

function hello () {
echo hello
}

[ 本帖最后由 zyypp 于 2010-2-18 00:00 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|全球主机交流论坛

GMT+8, 2019-3-24 10:55 , Processed in 0.113352 second(s), 13 queries , MemCache On.

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表