首页 > 编程语言 >NODEJS通过发送json数据查询目标服务,实现服务器状态监控,发现异常发送到微信群提醒

NODEJS通过发送json数据查询目标服务,实现服务器状态监控,发现异常发送到微信群提醒

时间:2024-05-16 21:08:41浏览次数:24  
标签:console 微信群 NODEJS ip token server json const response

root@aea87fa6e6a2:/home/node# cat login2.js


const request = require('request-promise');
const moment = require('moment');
const cron = require('node-cron');

process.env.TZ = 'Asia/Shanghai'; // 设置时区为上海时区
const rp = require('request-promise');
// 三台服务器地址、用户名和密码数组
const nTime=30;
const servers = [
    { ip: '192.168.0.4', username: '0463511', password: 'i@123456' },
    { ip: '192.168.0.95', username: '0721702', password: '123456' },
    { ip: '192.168.0.196', username: '1820318', password: '123456' }
];

// 登录链接
const loginUrl = 'http://{{server}}/api/auth/login'; // {{server}} 是占位符,将 在每次迭代中替换为服务器地址
// 数据采集链接
const dataUrl = 'http://{{server}}/api/icsp/scheduleLog/page?page=1&limit=10';

// 定时器间隔(以毫秒为单位)
const interval = 60000;

// 循环检测主函数
async function loopCheck() {
    for (const server of servers) {
        try {
            serverIP=server.ip;
            // 构建当前服务器的登录链接
            const currentLoginUrl = loginUrl.replace('{{server}}', server.ip);
            // 构建当前服务器的数据采集链接
            const currentDataUrl = dataUrl.replace('{{server}}', server.ip);

            // 发送登录请求
            const response = await request.post({
                url: currentLoginUrl,
                json: true,
                body: {
                    userName: server.username,
                    password: server.password
                }
            });

            // 登录成功则输出信息
            if (response.statusCode === 200) {
                console.log(`[${moment().format('YYYY-MM-DD HH:mm:ss')}] 登录服 务器 ${server.ip} 成功`);

                // 获取登录凭证(token)
                const token = response.data.token;

                // 使用获取的 token 发起数据采集请求
                await dataRequest(currentDataUrl, token,server.ip);
            } else {
                console.error(`[${moment().format('YYYY-MM-DD HH:mm:ss')}] 登录 服务器 ${server.ip} 失败:`, response.message);
            }
        } catch (error) {
            console.error(`[${moment().format('YYYY-MM-DD HH:mm:ss')}] 登录服务 器 ${server.ip} 失败:`, error.message);
        }
                await sleep(3000);//服务器间的检测间隔
    }

    // 检测完所有服务器后,等待一段时间后再次执行循环检测
  //  setTimeout(loopCheck, interval);  //这里是循环检测入口
}


async function loopCheck_info() {
    for (const server of servers) {
        try {
            serverIP=server.ip;
            // 构建当前服务器的登录链接
            const currentLoginUrl = loginUrl.replace('{{server}}', server.ip);
            // 构建当前服务器的数据采集链接
            const currentDataUrl = dataUrl.replace('{{server}}', server.ip);

            // 发送登录请求
            const response = await request.post({
                url: currentLoginUrl,
                json: true,
                body: {
                    userName: server.username,
                    password: server.password
                }
            });

            // 登录成功则输出信息
            if (response.statusCode === 200) {
                console.log(`[${moment().format('YYYY-MM-DD HH:mm:ss')}] 登录服 务器 ${server.ip} 成功`);

                // 获取登录凭证(token)
                const token = response.data.token;

                // 使用获取的 token 发起数据采集请求
                await dataRequest_info(currentDataUrl, token,server.ip);
            } else {
                console.error(`[${moment().format('YYYY-MM-DD HH:mm:ss')}] 登录 服务器 ${server.ip} 失败:`, response.message);
            }
        } catch (error) {
            console.error(`[${moment().format('YYYY-MM-DD HH:mm:ss')}] 登录服务 器 ${server.ip} 失败:`, error.message);
        }
                await sleep(3000);//服务器间的检测间隔
    }

    // 检测完所有服务器后,等待一段时间后再次执行循环检测
  //  setTimeout(loopCheck, interval);  //这里是循环检测入口
}




// 数据请求
async function dataRequest(dataUrl, token,serverIP) {
    // 构建请求头,包含 token
    const headers = {
        'Authorization': token,
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/118.0.0.0 Safari/537.36'
    };

    // 发送数据采集请求
    const response = await request({
        url: dataUrl,
        method: 'GET',
        headers: headers
    });

    // 解析数据
    dataParse(response);
}




// 数据请求2
async function dataRequest_info(dataUrl, token,serverIP) {
    // 构建请求头,包含 token
    const headers = {
        'Authorization': token,
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/118.0.0.0 Safari/537.36'
    };

    // 发送数据采集请求
    const response = await request({
        url: dataUrl,
        method: 'GET',
        headers: headers
    });

    // 解析数据
    dataParse_info(response);
}




// 解析数据
async  function dataParse(response) {
    // 检查响应体是否为空
    if (!response) {
        console.error('Received empty response body.');
        return;
    }

    // 解析 JSON 数据
    const jsonData = JSON.parse(response);

    // 获取数据数组
    const rows = jsonData.data.rows;

    // 标志,表示是否找到了符合条件的条目
    let found = false;

    // 遍历数据数组,查找状态为"数据同步任务运行中"的条目
    for (const rowData of rows) {
        // 如果状态为"数据同步任务运行中",则打印对应的时间
        if (rowData.error === "数据同步任务运行中...") {
            found = true;//检测运行变量
                        //updateTime是最后更新时间,createTime是创建时间。这里用更新时间
            const createTime = moment(rowData.updateTime, 'YYYY-MM-DD HH:mm:ss').toDate();
            const currentTime = new Date();
            const minutesDifference = (currentTime.getTime() - createTime.getTime()) / (1000 * 60);

            // 如果时间差超过1小时,则打印超时信息
            if (minutesDifference > nTime) {
                console.log('脚本监测到系统超时');
                console.log('超时时间:', minutesDifference.toFixed(0), '分钟');
      await sendLogsToAPI(`${moment().format('YYYY-MM-DD HH:mm:ss')} \nAEO ${serverIP} 异常 \n状态超时: ${minutesDifference.toFixed(0)}分钟` );

            }

            console.log('时间:', rowData.updateTime);
                        await sleep(1000);
            break; // 找到符合条件的条目后直接跳出循环
        }
    }

    // 如果未找到符合条件的条目,则输出提示信息
    if (!found) {
        console.log('未找到符合条件的条目');
         await sendLogsToAPI(`${moment().format('YYYY-MM-DD HH:mm:ss')} \nAEO ${serverIP} 异常 \n进程没有运行` );
    }
}








// 解析数据
async  function dataParse_info(response) {
    // 检查响应体是否为空
    if (!response) {
        console.error('Received empty response body.');
        return;
    }

    // 解析 JSON 数据
    const jsonData = JSON.parse(response);

    // 获取数据数组
    const rows = jsonData.data.rows;

    // 标志,表示是否找到了符合条件的条目
    let found = false;

    // 遍历数据数组,查找状态为"数据同步任务运行中"的条目
    for (const rowData of rows) {
        // 如果状态为"数据同步任务运行中",则打印对应的时间
        if (rowData.error === "数据同步任务运行中...") {
            found = true;//检测运行变量
                        //updateTime是最后更新时间,createTime是创建时间。这里用更新时间
            const createTime = moment(rowData.updateTime, 'YYYY-MM-DD HH:mm:ss').toDate();
            const currentTime = new Date();
            const minutesDifference = (currentTime.getTime() - createTime.getTime()) / (1000 * 60);

            // 如果时间差超过1小时,则打印超时信息
            if (minutesDifference > nTime) {
                console.log('脚本监测到系统超时');
                console.log('超时时间:', minutesDifference.toFixed(0), '分钟');
      await sendLogsToAPI(`${moment().format('YYYY-MM-DD HH:mm:ss')} \nAEO ${serverIP} 异常 \n状态超时: ${minutesDifference.toFixed(0)}分钟`);

            }else{
                                 console.log('正常运行中');
          await sendLogsToAPI(`${moment().format('YYYY-MM-DD HH:mm:ss')} \nAEO ${serverIP} 正常 \n最后更新: ${minutesDifference.toFixed(0)}分钟前`);

            }

            console.log('时间:', rowData.updateTime);
                        await sleep(1000);
            break; // 找到符合条件的条目后直接跳出循环
        }
    }

    // 如果未找到符合条件的条目,则输出提示信息
    if (!found) {
        console.log('未找到符合条件的条目');
         await sendLogsToAPI(`${moment().format('YYYY-MM-DD HH:mm:ss')} \nAEO ${serverIP} 异常 \n进程没有运行` );
    }
}






const sendLogsToAPI =  (logs) => {
  const resData = {
    "msgtype": "text",
    "text": {
      "content": logs,
    }
  };

  const options = {
    method: "POST",
   uri: "https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=17e3b586-20b3-eca2ffa84130",
       // uri: "https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=8ff711ab-f80b-4874-7adf0831a8bc",
    headers: {
      "content-type": "application/json",
    },
    body:JSON.stringify(resData),
  };

  try {
    const response =  rp(options);
    console.log('提示成功!');
  } catch (error) {
    console.error('请求出错:', error);
  }
};



// 休眠函数
function sleep(ms) {
    return new Promise(resolve => setTimeout(resolve, ms));
}



// 开始循环检测
//loopCheck();


// 在每分钟的第 30 秒执行目标函数
cron.schedule('35 8 * * *', () => {
    console.log('目标函数在8:35执行!');
        loopCheck_info();
    // 在这里调用你想要定时执行的函数
});

cron.schedule('*/30 9-20 * * *', () => {
    console.log('目标函数在每分钟的第 50分钟执行!');
        loopCheck();
    // 在这里调用你想要定时执行的函数
});

 

标签:console,微信群,NODEJS,ip,token,server,json,const,response
From: https://www.cnblogs.com/aldary/p/18196731

相关文章

  • labelme标注后的图片切成小图和小json
    splitMission.py和generateLabel.py两个脚本复制到4张图片和json所在的文件夹(最好是4的倍数因为默认以4个线程并行执行)中D:\pic\zhongwei\to_test\4picsplitMission.py点击查看代码importcv2importosimportbase64fromPILimportImageimportPILimportioimport......
  • nodejs学习07——API
    接口一、简介1.1接口是什么接口是前后端通信的桥梁简单理解:一个接口就是服务中的一个路由规则,根据请求响应结果接口的英文单词是API(ApplicationProgramInterface),所以有时也称之为API接口这里的接口指的是『数据接口』,与编程语言(Java,Go等)中的接口语法不同1.2......
  • 爬虫-JSON文件存储
    JSON文件存储JSON是一种轻量级的数据交换格式,它是基于ECMAScript的一个子集;JSON在Python中分别由list和dict组成;1、JSON模块的功能函数描述json.dumps()将python类型转换为字符串,返回一个str对象。实现把一个python对象编码转换成JSON字符串json.loads()把JSO......
  • nodejs 原生服务起一个httpServer
    离开express、koa、egg你还会利用原生node写后端的http服务吗?这里有一个例子,原生node起http服务。返回了静态页面文件、字符串拼接的html,json对象和优化404。做个备忘吧!import{createServer}from"http";importpathfrom'path';import{__dirname}from'./utils/i......
  • 去除两个JSON对象集合中的重复数据
    在jQuery中,要去除两个JSON对象集合中的重复数据,你通常需要比较这两个集合中对象的特定属性来决定是否重复。以下是一个基本的方法,假设我们根据每个对象的id属性来判断是否重复,并且我们将结果保存到第一个集合中,去除掉与第二个集合中重复的项://假设这是你的两个JSON对象集合var......
  • NodeJS
    1、node、npm安装及使用NPM(NodePackageManager)是随同NodeJS一起安装的包管理工具,能解决NodeJS代码部署上的很多问题,常见的使用场景有以下几种:1)允许用户从NPM服务器下载别人编写的第三方包到本地使用。2)允许用户从NPM服务器下载并安装别人编写的命令行程序到本地使用。3)允许......
  • jsonpath表达式
    例子:{"code":10000,"msg":"操作成功","traceId":"","timestamp":1715677467068,"data":[{"id":"509","na......
  • fastjson和 gson 的反序列化的一个差异
     publicclassResponse01{privateThirdDatathirdData;publicThirdDatagetThirdData(){returnthirdData;}//ThirdDataextendBaseThirdDatapublicvoidsetThirdData(BaseThirdDatathirdData){thi......
  • fastjson的使用
    Json是一种轻量级的数据交换格式,应该在一个程序员的开发生涯中是常接触的。简洁和清晰的层次结构使得JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。Fastjson是一个Java库,可用于将Java对象转换为其JSON表示形式,也可以......
  • JSON
    JSON笔记1、什么是JSON?SON(JavaScriptObjectNotation,JS对象标记)是一种轻量级的数据交换格式,目前使用特别广泛。采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生......