服务器长ping,traceroute

服务功能描述:对IP地址进行长时间的Ping测试和Traceroute跟踪,并将日志按日进行分类管理。该服务具有后台守护进程,能够实现开机自启动

1.将ip_ping_daemon.sh ip_tracer_daemon.sh脚本放到/usr/local/bin/下

ip_ping_daemon.sh

bash 复制代码
#!/bin/bash


BASE_LOG_DIR="/var/log/ip_ping"

# === IP 列表 ===
IPS=(
"192.168.24.32"
"192.168.28.6"
"192.168.24.227"
"192.168.27.172"
"192.168.24.234"
"192.168.27.176"
"192.168.25.166"
"192.168.24.225"
"192.168.27.168"
"192.168.24.43"
"192.168.27.178"
"192.168.27.180"
"192.168.25.165"
"192.168.24.31"
"192.168.25.170"
"192.168.25.177"
"192.168.27.179"
"192.168.25.168"
"192.168.28.23"
"192.168.27.163"
"192.168.27.152"
"192.168.27.154"
"192.168.27.177"
"192.168.27.151"
"192.168.24.36"
"192.168.27.159"
"192.168.28.26"
"192.168.27.155"
)

# 最大并发数
MAX_JOBS=30


# === 单 IP ping 无限循环(含每日目录切换)===
ping_ip_loop() {
    local ip="$1"

    while true; do
        # 每一轮动态刷新日期目录(确保每天自动创建新目录)
        local TODAY=$(date '+%Y-%m-%d')
        local LOG_DIR="${BASE_LOG_DIR}/${TODAY}"
        mkdir -p "$LOG_DIR"

        local logfile="${LOG_DIR}/${ip}.log"

        echo "==========================" | tee -a "$logfile"
        echo "[$(date '+%Y-%m-%d %H:%M:%S')] Start timed ping $ip ..." | tee -a "$logfile"

        # ping 60 秒(避免无限阻塞,确保每天能自动切换目录)
        timeout 60 ping "$ip" | while IFS= read -r line; do
            echo "[$(date '+%Y-%m-%d %H:%M:%S')] $line" | tee -a "$logfile"
        done

        echo "[$(date '+%Y-%m-%d %H:%M:%S')] Ping loop for $ip ended. Restarting..." | tee -a "$logfile"

        sleep 1
    done
}


# === 并发控制 ===
current_jobs=0

for ip in "${IPS[@]}"; do
    ping_ip_loop "$ip" &
    ((current_jobs++))

    # 控制并发数量
    if (( current_jobs >= MAX_JOBS )); then
        wait -n
        ((current_jobs--))
    fi
done

wait

ip_tracer_daemon.sh

bash 复制代码
#!/bin/bash
BASE_LOG_DIR="/var/log/ip_tracer"

IPS=(
"192.168.24.32"
"192.168.28.6"
"192.168.24.227"
"192.168.27.172"
"192.168.24.234"
"192.168.27.176"
"192.168.25.166"
"192.168.24.225"
"192.168.27.168"
"192.168.24.43"
"192.168.27.178"
"192.168.27.180"
"192.168.25.165"
"192.168.24.31"
"192.168.25.170"
"192.168.25.177"
"192.168.27.179"
"192.168.25.168"
"192.168.28.23"
"192.168.27.163"
"192.168.27.152"
"192.168.27.154"
"192.168.27.177"
"192.168.27.151"
"192.168.24.36"
"192.168.27.159"
"192.168.28.26"
"192.168.27.155"
)

MAX_JOBS=30


# === 单 IP traceroute 无限守护循环(支持每日切换目录)===
trace_ip_loop() {
    local ip="$1"

    while true; do
        # 每一轮 traceroute 前动态刷新目录
        local TODAY=$(date '+%Y-%m-%d')
        local LOG_DIR="${BASE_LOG_DIR}/${TODAY}"
        mkdir -p "$LOG_DIR"

        local logfile="${LOG_DIR}/${ip}.log"

        echo "==========================" | tee -a "$logfile"
        echo "[$(date '+%Y-%m-%d %H:%M:%S')] Tracing route to $ip..." | tee -a "$logfile"

        # traceroute 本身执行一次自动结束
        traceroute -n "$ip" | while IFS= read -r line; do
            echo "[$(date '+%Y-%m-%d %H:%M:%S')] $line" | tee -a "$logfile"
        done

        echo "[$(date '+%Y-%m-%d %H:%M:%S')] Tracing $ip completed. Restarting..." | tee -a "$logfile"

        sleep 1
    done
}


# === 并发控制 ===
current_jobs=0

for ip in "${IPS[@]}"; do
    trace_ip_loop "$ip" &
    ((current_jobs++))

    if (( current_jobs >= MAX_JOBS )); then
        wait -n
        ((current_jobs--))
    fi
done

wait

2,将两个脚本设置为守护进程

vi /etc/systemd/system/ip-ping.service

bash 复制代码
[Unit]
Description=IP Ping Monitoring Daemon
After=network.target

[Service]
Type=simple
ExecStart=/usr/local/bin/ip_ping_daemon.sh
Restart=always
RestartSec=5
StandardOutput=null
StandardError=null

[Install]
WantedBy=multi-user.target

vi /etc/systemd/system/ip-tracer.service

bash 复制代码
[Unit]
Description=IP Traceroute Daemon
After=network.target

[Service]
Type=simple
ExecStart=/usr/local/bin/ip_tracer_daemon.sh
Restart=always
RestartSec=5

# 不要输出到 journal,所有内容在每个 IP 日志里
StandardOutput=null
StandardError=null

[Install]
WantedBy=multi-user.target

systemctl daemon-reload

3,启动且自启服务,进行验证

chmod +x /usr/local/bin/ip_ping_daemon.sh

chmod +x /usr/local/bin/ip_tracer_daemon.sh

systemctl start ip-ping.service &&systemctl enable ip-ping.service && systemctl status ip-ping.service

systemctl start ip-tracer.service &&systemctl enable ip-tracer.service && systemctl status ip-tracer.service

日志验证

cd /var/log/

ip_ping/ ip_tracer/ 生成这两个目录进入看即可

相关推荐
YuMiao9 小时前
gstatic连接问题导致Google Gemini / Studio页面乱码或图标缺失问题
服务器·网络协议
chlk1231 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑1 天前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件1 天前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
深紫色的三北六号2 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash2 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI2 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行3 天前
Linux和window共享文件夹
linux
Sinclair3 天前
简单几步,安卓手机秒变服务器,安装 CMS 程序
android·服务器
木心月转码ing3 天前
WSL+Cpp开发环境配置
linux