检测IP地址冲突的shell脚本-check_server_ip_conflict.sh
check_server_ip_conflict.sh
使用arping获取对应IP地址的MAC地址,如果和预料的不一致则报警;
#!/bin/bash
epg_addr_01="00:50:56:B7:64:2A"
epg_addr_02="00:50:56:B7:44:43"
vod_addr_01="00:50:56:B7:28:AB"
vod_addr_02="00:50:56:B7:02:6C"
epg_ip_01="10.108.144.1"
epg_ip_02="10.108.144.2"
vod_ip_01="10.108.144.3"
vod_ip_02="10.108.144.4"
epg_vip="10.108.144.5"
vod_vip="10.108.144.6"
log_check="/var/log/sunlight/check_ip_conflict.log"
log_time=$(date "+%Y/%m/%d %H:%M:%S")
log_date=$(date "+%Y%m%d")
event_check=0
function send_email()
{
echo " " >> $log_check
ping_count=$(ping -W 3 -c 1 baidu.com | grep ttl | wc -l)
if [ $ping_count -eq 1 ];then
echo "[ info ] Begin to send mail......" >> $log_check
echo "[ info ] `date "+%Y/%m/%d %H:%M:%S"` send mail content : $1" >> $log_check
if [ -f /sunlight/python/slt_send_mail.py ];then
python /sunlight/python/slt_send_mail.py "$1"
if [ $? -eq 0 ];then
echo "[ SUCCESS ] `date "+%Y/%m/%d %H:%M:%S"` send mail finished!" >> $log_check
else
echo " [ Error ] `date "+%Y/%m/%d %H:%M:%S"` send mail failed! " >> $log_check
fi
else
echo " [ Error ] `date "+%Y/%m/%d %H:%M:%S"` /sunlight/python/slt_send_mail.py does not exist! " >> $log_check
fi
else
echo " [ Error ] `date "+%Y/%m/%d %H:%M:%S"` can't connect to the Internet! " >> $log_check
fi
}
function send_email_use_epg()
{
echo " " >> $log_check
ping_count=$(ssh -o StrictHostKeyChecking=no -i /usr/local/sunlight/sshkeys/init.pk -p2222 10.108.144.1 "ping -W 3 -c 1 baidu.com | grep ttl | wc -l")
if [ $ping_count -eq 1 ];then
echo "[ info ] Begin to send mail......" >> $log_check
echo "[ info ] `date "+%Y/%m/%d %H:%M:%S"` send mail content : $1" >> $log_check
ssh -o StrictHostKeyChecking=no -i /usr/local/sunlight/sshkeys/init.pk -p2222 10.108.144.1 "python /sunlight/python/slt_send_mail.py \"$1\""
if [ $? -eq 0 ];then
echo "[ SUCCESS ] `date "+%Y/%m/%d %H:%M:%S"` send mail finished!" >> $log_check
else
echo " [ Error ] `date "+%Y/%m/%d %H:%M:%S"` send mail failed! " >> $log_check
fi
else
echo " [ Error ] `date "+%Y/%m/%d %H:%M:%S"` can't connect to the Internet! " >> $log_check
fi
}
while true
do
echo " " >> $log_check
echo "-----------------------------------------------" >> $log_check
check_epg_01_ip=$( ip addr | grep $epg_ip_01 | wc -l)
if [ $check_epg_01_ip -eq 1 ];then
peer_ip=$epg_ip_02
peer_mac=$epg_addr_02
send_warn="send_email"
else
peer_ip=$epg_ip_01
peer_mac=$epg_addr_01
send_warn="send_email_use_epg"
fi
#master and slave node need to arping peer ip;
echo "[ INFO ] `date "+%Y/%m/%d %H:%M:%S"` target IP : ${peer_ip} correct Mac : ${peer_mac}" >> $log_check
arping -w 20 -c 10 -I eth0 ${peer_ip} | ( while read line
do
if [ "${line:0:7}" == "Unicast" ];then
grep_peer_mac=$(echo $line | grep -o ${peer_mac} | wc -l)
if [ $grep_peer_mac -eq 0 ];then
event_check=1
error_mac=$(echo $line | grep -E -o "\[(.*)\]")
echo "[ Error ] `date "+%Y/%m/%d %H:%M%S"` ${peer_ip} find conflict!!!! error mac: $error_mac " >> $log_check
break
else
echo $line >> $log_check
fi
fi
done
if [ $event_check -eq 1 ];then
event_string="<p><span style='color:#FF0000'>亚特兰蒂斯报警监控</span></p>"
event_string="$event_string<hr/>"
event_string="$event_string<p>报警内容: 出现IP地址冲突!</p>"
event_string="$event_string<p>冲突IP:${peer_ip}</p>"
event_string="$event_string<p>正确的Mac地址:${peer_mac}</p>"
event_string="$event_string<p>检测到的Mac地址: $error_mac</p>"
event_string="$event_string<hr/><p>请登录检查!</p>"
eval "$send_warn \"$event_string\""
fi
)
check_vip=$( ip addr | grep $epg_vip | wc -l)
#use slave node to check all the other ip;
if [ $check_vip -ne 1 ];then
#check vod_ip_01
echo "[ INFO ] `date "+%Y/%m/%d %H:%M:%S"` target IP : ${vod_ip_01} correct Mac : ${vod_addr_01}" >> $log_check
arping -w 20 -c 10 -I eth0 ${vod_ip_01} | ( while read line
do
if [ "${line:0:7}" == "Unicast" ];then
grep_vod_01=$(echo $line | grep -o ${vod_addr_01} | wc -l)
if [ $grep_vod_01 -eq 0 ];then
event_check=1
error_mac=$(echo $line | grep -E -o "\[(.*)\]")
echo "[ Error ] `date "+%Y/%m/%d %H:%M%S"` ${vod_ip_01} find conflict!!!! error mac: $error_mac " >> $log_check
break
else
echo $line >> $log_check
fi
fi
done
if [ $event_check -eq 1 ];then
event_string="<p><span style='color:#FF0000'>亚特兰蒂斯报警监控</span></p>"
event_string="$event_string<hr/>"
event_string="$event_string<p>报警内容: 出现IP地址冲突!</p>"
event_string="$event_string<p>冲突IP:${vod_ip_01}</p>"
event_string="$event_string<p>正确的Mac地址:${vod_addr_01}</p>"
event_string="$event_string<p>检测到的Mac地址: $error_mac</p>"
event_string="$event_string<hr/><p>请登录检查!</p>"
eval "$send_warn \"$event_string\""
fi
)
#check vod_ip_02
echo "[ INFO ] `date "+%Y/%m/%d %H:%M:%S"` target IP : ${vod_ip_02} correct Mac : ${vod_addr_02}" >> $log_check
arping -w 20 -c 10 -I eth0 ${vod_ip_02} | ( while read line
do
if [ "${line:0:7}" == "Unicast" ];then
grep_vod_02=$(echo $line | grep -o ${vod_addr_02} | wc -l)
if [ $grep_vod_02 -eq 0 ];then
event_check=1
error_mac=$(echo $line | grep -E -o "\[(.*)\]")
echo "[ Error ] `date "+%Y/%m/%d %H:%M%S"` ${vod_ip_02} find conflict!!!! error mac: $error_mac " >> $log_check
break
else
echo $line >> $log_check
fi
fi
done
if [ $event_check -eq 1 ];then
event_string="<p><span style='color:#FF0000'>亚特兰蒂斯报警监控</span></p>"
event_string="$event_string<hr/>"
event_string="$event_string<p>报警内容: 出现IP地址冲突!</p>"
event_string="$event_string<p>冲突IP:${vod_ip_02}</p>"
event_string="$event_string<p>正确的Mac地址:${vod_addr_02}</p>"
event_string="$event_string<p>检测到的Mac地址: $error_mac</p>"
event_string="$event_string<hr/><p>请登录检查!</p>"
eval "$send_warn \"$event_string\""
fi
)
#check epg_vip
echo "[ INFO ] `date "+%Y/%m/%d %H:%M:%S"` target IP : ${epg_vip} correct Mac : ${epg_addr_01} || ${epg_addr_02}" >> $log_check
arping -w 20 -c 10 -I eth0 ${epg_vip} | ( while read line
do
if [ "${line:0:7}" == "Unicast" ];then
grep_epg_master=$(echo $line | grep -o ${epg_addr_01} | wc -l)
grep_epg_slave=$(echo $line | grep -o ${epg_addr_02} | wc -l)
if [[ $grep_epg_master -eq 0 && $grep_epg_slave -eq 0 ]];then
event_check=1
error_mac=$(echo $line | grep -E -o "\[(.*)\]")
echo "[ Error ] `date "+%Y/%m/%d %H:%M%S"` ${epg_vip} find conflict!!!! error mac: $error_mac " >> $log_check
break
else
echo $line >> $log_check
fi
fi
done
if [ $event_check -eq 1 ];then
event_string="<p><span style='color:#FF0000'>亚特兰蒂斯报警监控</span></p>"
event_string="$event_string<hr/>"
event_string="$event_string<p>报警内容: 出现IP地址冲突!</p>"
event_string="$event_string<p>冲突IP:${epg_vip}</p>"
event_string="$event_string<p>正确的Mac地址:${epg_addr_01} || ${epg_addr_02}</p>"
event_string="$event_string<p>检测到的Mac地址: $error_mac</p>"
event_string="$event_string<hr/><p>请登录检查!</p>"
eval "$send_warn \"$event_string\""
fi
)
#check vod_vip
echo "[ INFO ] `date "+%Y/%m/%d %H:%M:%S"` target IP : ${vod_vip} correct Mac : ${vod_addr_01} || ${vod_addr_02}" >> $log_check
arping -w 20 -c 10 -I eth0 ${vod_vip} | ( while read line
do
if [ "${line:0:7}" == "Unicast" ];then
grep_vod_master=$(echo $line | grep -o ${vod_addr_01} | wc -l)
grep_vod_slave=$(echo $line | grep -o ${vod_addr_02} | wc -l)
if [[ $grep_vod_master -eq 0 && $grep_vod_slave -eq 0 ]];then
event_check=1
error_mac=$(echo $line | grep -E -o "\[(.*)\]")
echo "[ Error ] `date "+%Y/%m/%d %H:%M%S"` ${vod_vip} find conflict!!!! error mac: $error_mac " >> $log_check
break
else
echo $line >> $log_check
fi
fi
done
if [ $event_check -eq 1 ];then
event_string="<p><span style='color:#FF0000'>亚特兰蒂斯报警监控</span></p>"
event_string="$event_string<hr/>"
event_string="$event_string<p>报警内容: 出现IP地址冲突!</p>"
event_string="$event_string<p>冲突IP:${vod_vip}</p>"
event_string="$event_string<p>正确的Mac地址:${vod_addr_01} || ${vod_addr_02}</p>"
event_string="$event_string<p>检测到的Mac地址: $error_mac</p>"
event_string="$event_string<hr/><p>请登录检查!</p>"
eval "$send_warn \"$event_string\""
fi
)
fi
sleep 600
done
检测IP地址冲突的shell脚本-check_server_ip_conflict.sh的更多相关文章
- Linux下检测IP地址冲突及解决方法
问题说明:在公司办公网内的一台物理机A上安装了linux系统(ip:192.168.9.120),在上面部署了jenkins,redmine,svn程序.由于是在办公网内,这台机器和同事电脑都是在同一 ...
- 【IP】Linux中检测IP地址冲突
在Windows系统中,如果本地网络IP地址出现冲突,会出现图标提示. 在Linux系统中,并没有提供相关的功能,如果本地网络采用静态IP地址配置,出现比较奇怪的网络连接问题,如ssh连接复位,可以考 ...
- linux,windows下检测指定的IP地址是否可用或者检测IP地址冲突的3种方式(批处理程序,python程序,linux shell 批量ping)
本文中的脚本适用范围: 1)检测某些IP地址是否被占用: 2)检测网络中某些设备是否存活: 3)在分配新的ip地址之前,批量检测环境中是否存在冲突的机器 以上检测基于ICMP Ping报文,要求所有的 ...
- 【转载】Windows检测到IP地址冲突
今天在使用电脑的过程中,突然弹出个提示,Windows检测到IP地址冲突,此网络中的另一台计算机与该计算机的IP地址相同.联系你的网络管理员解决此问题,有关详细信息,请参阅Windows系统日志.查阅 ...
- IP地址冲突
IP地址冲突问题.. IP地址冲突多数是由于同一局域网内,有2台或者多台电脑设置了同一个本地IP地址,导致局域网内部IP冲突导致,,建议尽量将本地IP地址设置为自动获取--然后查看自动获取的IP地址是 ...
- 遇到电脑IP地址冲突了怎么解决
由于路由器是自动分配IP地址的,如果多个设备设置的是IP地址自动获取,就会出现IP地址冲突的情况当局域网内有相同IP,并且该机器启动了防火墙,那就没办法自动更新到下一个IP的地址了,所以此时发生了冲突 ...
- 解决IP地址冲突
1.重新启动路由器就可以. 要是网络上的每一个设备都被分配了动态IP地址,路由器重新启动.又一次分配IP地址给网络上的每一个设备后,这个问题就有望得到解决. 可是假设是在企业内就不可能随便的重新启动公 ...
- 正则表达式检测IP地址与端口号是否合法
正则表达式检测IP地址与端口号是否合法,代码如下: 正则表达式检测IP地址 public static bool CheckAddress(string s) { bool isLegal = fal ...
- 【必看】局域网IP地址冲突罪魁祸首是谁?
开源Linux 长按二维码加关注~ 上一篇:一文详解FTP.FTPS与SFTP的原理 现如今,人们的生活处处离不开网络.企业办公信息化对网络的依赖则更大.为了提升安全管理和信息化水平,很多企业不仅建设 ...
随机推荐
- ASP.NET MVC命名空间时引起错误的解决方法
使用VS2012新建了一个Asp.net mvc5的项目,并把项目的命名空间名称更改了(Src更改为UXXXXX),然后就导致了以下错误 刚开始以后是项目的属性中的命名空间没有更改过来的问题,但我在重 ...
- cin.get()函数使用例子
#include <iostream>using namespace std; int k = 0; int main(){ char a[1000]; char c; do { cin. ...
- 【转】java提高篇(二)-----理解java的三大特性之继承
[转]java提高篇(二)-----理解java的三大特性之继承 原文地址:http://www.cnblogs.com/chenssy/p/3354884.html 在<Think in ja ...
- Win10系列:JavaScript小球运动示例
通过前面内容的学习,相信读者已经对开发基于JavaScript的Windows应用商店应用有了一定的了解,本小节通过一个小球运动的示例来介绍如何新建一个JavaScript的Windows应用商店项目 ...
- 乘法“*”和点乘“.*”&除法“/”和点除“./”区别
reference:https://blog.csdn.net/xiaotao_1/article/details/79026406 一,*和.*的联系和区别. 1,在进行数值运行和数值乘矩阵,这两 ...
- MicroBlaze核的串行接口实验:SPI UART
reference : https://blog.csdn.net/weixin_42413559/article/details/80720566 串行接口:SPI UART XPS->SDK ...
- 牛客多校第五场 F take
链接:https://www.nowcoder.com/acm/contest/143/F来源:牛客网 题目描述 Kanade has n boxes , the i-th box has p[i] ...
- .NET实现字符串base64编码
using System; using System.Text; using System.IO; using System.Security; using System.Security.Crypt ...
- 福大软工 · BETA 版冲刺前准备之拖鞋旅游队
拖鞋旅游队BETA 版冲刺前准备 前言 队名:拖鞋旅游队 组长博客:https://www.cnblogs.com/Sulumer/p/10083834.html 本次作业:https://edu.c ...
- Zookeeper与Paxos
初识Zookeeper zookeeper为分布式应用提供了高效且可靠的分布式协调服务,提供了诸如统一命名服务.配置管理和分布式锁等分布式的基础服务. 在解决分布式数据一致性方面,zk没有直接采用Pa ...