B2B网络软件

标题: 数据库MYQ业务流程心跳程序启动 [打印本页]

作者: YYPOST群发软件    时间: 昨天 09:59
标题: 数据库MYQ业务流程心跳程序启动
数据库MYQ业务流程心跳程序启动
数据库MYQ业务流程心跳程序启动 B2B网络软件

数据库MYQ业务流程心跳程序启动 B2B网络软件

  1. // MYQ业务流程心跳程序
  2. // 模拟完整的业务操作流程,包括定时任务、数据库操作和状态监控

  3. print.log("===== MYQ业务流程心跳程序启动 =====");

  4. // 全局变量
  5. var conn = null;
  6. var pstmt = null;
  7. var heartbeatInterval = null;
  8. var isRunning = false;

  9. /**
  10. * 连接数据库
  11. */
  12. function connectDatabase() {
  13.     try {
  14.         var url = "jdbc:mysql://mysql2.sqlpub.com:3307/chaook";
  15.         var user = "chaook";
  16.         var password = "JAVsRUMHkoJ123xJ";
  17.         var params = "?useSSL=false&characterEncoding=utf8";
  18.         
  19.         print.log("正在连接数据库...");
  20.         conn = mysql.getConnection(url, user, password);
  21.         print.log("✅ 数据库连接成功");
  22.         return true;
  23.     } catch (e) {
  24.         print.log("❌ 数据库连接失败: " + e.message);
  25.         return false;
  26.     }
  27. }

  28. /**
  29. * 初始化数据库表结构
  30. */
  31. function initializeDatabase() {
  32.     try {
  33.         // 创建设备状态表
  34.         var deviceTableSql = "CREATE TABLE IF NOT EXISTS 设备状态表 (" +
  35.                             "设备ID VARCHAR(50) PRIMARY KEY," +
  36.                             "设备名称 VARCHAR(100)," +
  37.                             "在线状态 TINYINT DEFAULT 0," +  // 0-离线, 1-在线
  38.                             "最后心跳时间 DATETIME," +
  39.                             "CPU使用率 DECIMAL(5,2)," +
  40.                             "内存使用率 DECIMAL(5,2)," +
  41.                             "磁盘使用率 DECIMAL(5,2)" +
  42.                             ") ENGINE=InnoDB DEFAULT CHARSET=utf8";
  43.                            
  44.         var stmt = conn.createStatement();
  45.         stmt.executeUpdate(deviceTableSql);
  46.         stmt.close();
  47.         
  48.         // 创建操作日志表
  49.         var logTableSql = "CREATE TABLE IF NOT EXISTS 操作日志表 (" +
  50.                          "日志ID INT AUTO_INCREMENT PRIMARY KEY," +
  51.                          "设备ID VARCHAR(50)," +
  52.                          "操作类型 VARCHAR(50)," +
  53.                          "操作详情 TEXT," +
  54.                          "操作时间 DATETIME DEFAULT CURRENT_TIMESTAMP," +
  55.                          "FOREIGN KEY (设备ID) REFERENCES 设备状态表(设备ID) ON DELETE CASCADE" +
  56.                          ") ENGINE=InnoDB DEFAULT CHARSET=utf8";
  57.                         
  58.         stmt = conn.createStatement();
  59.         stmt.executeUpdate(logTableSql);
  60.         stmt.close();
  61.         
  62.         print.log("✅ 数据库表结构初始化完成");
  63.         return true;
  64.     } catch (e) {
  65.         print.log("❌ 数据库表结构初始化失败: " + e.message);
  66.         return false;
  67.     }
  68. }

  69. /**
  70. * 注册设备
  71. */
  72. function registerDevice(deviceId, deviceName) {
  73.     try {
  74.         var sql = "INSERT INTO 设备状态表 (设备ID, 设备名称, 在线状态, 最后心跳时间) VALUES (?, ?, 1, NOW()) " +
  75.                   "ON DUPLICATE KEY UPDATE 设备名称 = VALUES(设备名称), 在线状态 = 1, 最后心跳时间 = NOW()";
  76.                   
  77.         var pstmt = conn.prepareStatement(sql);
  78.         pstmt.setString(1, deviceId);
  79.         pstmt.setString(2, deviceName);
  80.         pstmt.executeUpdate();
  81.         pstmt.close();
  82.         
  83.         logOperation(deviceId, "设备注册", "设备 " + deviceName + " 已注册并上线");
  84.         print.log("✅ 设备 " + deviceName + " 注册成功");
  85.         return true;
  86.     } catch (e) {
  87.         print.log("❌ 设备注册失败: " + e.message);
  88.         return false;
  89.     }
  90. }

  91. /**
  92. * 发送心跳包
  93. */
  94. function sendHeartbeat(deviceId, cpuUsage, memoryUsage, diskUsage) {
  95.     try {
  96.         var sql = "UPDATE 设备状态表 SET 在线状态 = 1, 最后心跳时间 = NOW(), " +
  97.                   "CPU使用率 = ?, 内存使用率 = ?, 磁盘使用率 = ? WHERE 设备ID = ?";
  98.                   
  99.         var pstmt = conn.prepareStatement(sql);
  100.         pstmt.setBigDecimal(1, new java.math.BigDecimal(cpuUsage.toFixed(2)));
  101.         pstmt.setBigDecimal(2, new java.math.BigDecimal(memoryUsage.toFixed(2)));
  102.         pstmt.setBigDecimal(3, new java.math.BigDecimal(diskUsage.toFixed(2)));
  103.         pstmt.setString(4, deviceId);
  104.         pstmt.executeUpdate();
  105.         pstmt.close();
  106.         
  107.         logOperation(deviceId, "心跳包", "发送心跳包 - CPU:" + cpuUsage.toFixed(2) + "% 内存:" + memoryUsage.toFixed(2) + "% 磁盘:" + diskUsage.toFixed(2) + "%");
  108.         print.log("✅ 设备 " + deviceId + " 心跳包发送成功");
  109.         return true;
  110.     } catch (e) {
  111.         print.log("❌ 心跳包发送失败: " + e.message);
  112.         return false;
  113.     }
  114. }

  115. /**
  116. * 记录操作日志
  117. */
  118. function logOperation(deviceId, operationType, details) {
  119.     try {
  120.         var sql = "INSERT INTO 操作日志表 (设备ID, 操作类型, 操作详情) VALUES (?, ?, ?)";
  121.         var pstmt = conn.prepareStatement(sql);
  122.         pstmt.setString(1, deviceId);
  123.         pstmt.setString(2, operationType);
  124.         pstmt.setString(3, details);
  125.         pstmt.executeUpdate();
  126.         pstmt.close();
  127.         return true;
  128.     } catch (e) {
  129.         // 日志记录失败不影响主流程
  130.         print.log("⚠️ 操作日志记录失败: " + e.message);
  131.         return false;
  132.     }
  133. }

  134. /**
  135. * 检查设备状态
  136. */
  137. function checkDeviceStatus() {
  138.     try {
  139.         var sql = "SELECT 设备ID, 设备名称, 在线状态, 最后心跳时间, CPU使用率, 内存使用率, 磁盘使用率 FROM 设备状态表";
  140.         var stmt = conn.createStatement();
  141.         var rs = stmt.executeQuery(sql);
  142.         
  143.         print.log("\n=== 设备状态监控 ===");
  144.         print.log("设备ID\t\t设备名称\t\t在线状态\t最后心跳时间\t\t\tCPU%\t内存%\t磁盘%");
  145.         print.log("------------------------------------------------------------------------------------------------------------");
  146.         
  147.         var offlineDevices = [];
  148.         var highLoadDevices = [];
  149.         
  150.         while (rs.next()) {
  151.             var deviceId = rs.getString("设备ID");
  152.             var deviceName = rs.getString("设备名称");
  153.             var onlineStatus = rs.getInt("在线状态");
  154.             var lastHeartbeat = rs.getTimestamp("最后心跳时间");
  155.             var cpuUsage = rs.getBigDecimal("CPU使用率") || new java.math.BigDecimal("0");
  156.             var memoryUsage = rs.getBigDecimal("内存使用率") || new java.math.BigDecimal("0");
  157.             var diskUsage = rs.getBigDecimal("磁盘使用率") || new java.math.BigDecimal("0");
  158.             
  159.             // 格式化输出
  160.             var nameStr = deviceName + "\t\t";
  161.             if (deviceName.length >= 4) nameStr = deviceName + "\t";
  162.             
  163.             var statusStr = onlineStatus === 1 ? "在线" : "离线";
  164.             
  165.             print.log(deviceId + "\t" + nameStr + statusStr + "\t\t" + lastHeartbeat + "\t" +
  166.                      cpuUsage + "\t" + memoryUsage + "\t" + diskUsage);
  167.             
  168.             // 检查离线设备
  169.             if (onlineStatus !== 1) {
  170.                 offlineDevices.push({id: deviceId, name: deviceName});
  171.             }
  172.             
  173.             // 检查高负载设备 (CPU或内存使用率超过80%)
  174.             if (cpuUsage.compareTo(new java.math.BigDecimal("80")) > 0 ||
  175.                 memoryUsage.compareTo(new java.math.BigDecimal("80")) > 0) {
  176.                 highLoadDevices.push({id: deviceId, name: deviceName, cpu: cpuUsage, memory: memoryUsage});
  177.             }
  178.         }
  179.         
  180.         rs.close();
  181.         stmt.close();
  182.         
  183.         // 报告异常设备
  184.         if (offlineDevices.length > 0) {
  185.             print.log("\n⚠️ 发现 " + offlineDevices.length + " 台离线设备:");
  186.             for (var i = 0; i < offlineDevices.length; i++) {
  187.                 print.log("  - " + offlineDevices[i].name + " (" + offlineDevices[i].id + ")");
  188.             }
  189.         }
  190.         
  191.         if (highLoadDevices.length > 0) {
  192.             print.log("\n⚠️ 发现 " + highLoadDevices.length + " 台高负载设备:");
  193.             for (var i = 0; i < highLoadDevices.length; i++) {
  194.                 var dev = highLoadDevices[i];
  195.                 print.log("  - " + dev.name + " (" + dev.id + ") CPU:" + dev.cpu + "% 内存:" + dev.memory + "%");
  196.             }
  197.         }
  198.         
  199.         if (offlineDevices.length === 0 && highLoadDevices.length === 0) {
  200.             print.log("\n✅ 所有设备状态正常");
  201.         }
  202.         
  203.         print.log("");
  204.         return true;
  205.     } catch (e) {
  206.         print.log("❌ 设备状态检查失败: " + e.message);
  207.         return false;
  208.     }
  209. }

  210. /**
  211. * 模拟设备数据生成
  212. */
  213. function generateDeviceData() {
  214.     var devices = [
  215.         {id: "DEVICE_001", name: "Web服务器1"},
  216.         {id: "DEVICE_002", name: "数据库服务器"},
  217.         {id: "DEVICE_003", name: "应用服务器1"},
  218.         {id: "DEVICE_004", name: "缓存服务器"},
  219.         {id: "DEVICE_005", name: "负载均衡器"}
  220.     ];
  221.    
  222.     return devices;
  223. }

  224. /**
  225. * 模拟系统资源使用率
  226. */
  227. function simulateSystemMetrics() {
  228.     // 模拟CPU使用率 (0-100%)
  229.     var cpu = Math.random() * 100;
  230.    
  231.     // 模拟内存使用率 (0-100%)
  232.     var memory = Math.random() * 100;
  233.    
  234.     // 模拟磁盘使用率 (0-100%,通常较高)
  235.     var disk = 30 + Math.random() * 60;
  236.    
  237.     return {
  238.         cpu: cpu,
  239.         memory: memory,
  240.         disk: disk
  241.     };
  242. }

  243. /**
  244. * 心跳任务执行函数
  245. */
  246. function executeHeartbeatTask() {
  247.     print.log("\n⏰ 执行心跳任务 - " + new Date());
  248.    
  249.     try {
  250.         // 检查数据库连接
  251.         if (!conn || conn.isClosed()) {
  252.             print.log("⚠️ 数据库连接已断开,尝试重新连接...");
  253.             if (!connectDatabase()) {
  254.                 print.log("❌ 无法重新连接数据库,跳过本次心跳任务");
  255.                 return;
  256.             }
  257.         }
  258.         
  259.         // 获取设备列表
  260.         var devices = generateDeviceData();
  261.         
  262.         // 为每个设备发送心跳包
  263.         for (var i = 0; i < devices.length; i++) {
  264.             var device = devices[i];
  265.             var metrics = simulateSystemMetrics();
  266.             
  267.             // 注册设备(如果尚未注册)
  268.             registerDevice(device.id, device.name);
  269.             
  270.             // 发送心跳包
  271.             sendHeartbeat(device.id, metrics.cpu, metrics.memory, metrics.disk);
  272.         }
  273.         
  274.         // 检查设备状态
  275.         checkDeviceStatus();
  276.         
  277.         print.log("✅ 心跳任务执行完成\n");
  278.     } catch (e) {
  279.         print.log("❌ 心跳任务执行失败: " + e.message);
  280.     }
  281. }

  282. /**
  283. * 启动心跳服务
  284. */
  285. function startHeartbeatService(intervalSeconds) {
  286.     if (isRunning) {
  287.         print.log("⚠️ 心跳服务已经在运行中");
  288.         return false;
  289.     }
  290.    
  291.     // 连接数据库
  292.     if (!connectDatabase()) {
  293.         print.log("❌ 无法启动心跳服务:数据库连接失败");
  294.         return false;
  295.     }
  296.    
  297.     // 初始化数据库
  298.     if (!initializeDatabase()) {
  299.         print.log("❌ 无法启动心跳服务:数据库初始化失败");
  300.         return false;
  301.     }
  302.    
  303.     isRunning = true;
  304.     print.log("✅ 心跳服务启动成功,间隔: " + intervalSeconds + "秒");
  305.    
  306.     // 立即执行一次
  307.     executeHeartbeatTask();
  308.    
  309.     // 设置定时任务
  310.     heartbeatInterval = setInterval(function() {
  311.         executeHeartbeatTask();
  312.     }, intervalSeconds * 1000);
  313.    
  314.     return true;
  315. }

  316. /**
  317. * 停止心跳服务
  318. */
  319. function stopHeartbeatService() {
  320.     if (!isRunning) {
  321.         print.log("⚠️ 心跳服务未在运行");
  322.         return false;
  323.     }
  324.    
  325.     if (heartbeatInterval) {
  326.         clearInterval(heartbeatInterval);
  327.         heartbeatInterval = null;
  328.     }
  329.    
  330.     isRunning = false;
  331.     print.log("✅ 心跳服务已停止");
  332.     return true;
  333. }

  334. /**
  335. * 关闭数据库连接
  336. */
  337. function closeConnection() {
  338.     try {
  339.         if (pstmt != null) {
  340.             pstmt.close();
  341.         }
  342.         if (conn != null) {
  343.             conn.close();
  344.         }
  345.         print.log("✅ 数据库连接已关闭");
  346.     } catch (e) {
  347.         print.log("❌ 关闭连接时出错: " + e.message);
  348.     }
  349. }

  350. /**
  351. * 程序退出处理
  352. */
  353. function exitHandler() {
  354.     print.log("正在关闭心跳服务...");
  355.     stopHeartbeatService();
  356.     closeConnection();
  357.     print.log("&#128075; MYQ业务流程心跳程序已退出");
  358. }

  359. // 主程序
  360. try {
  361.     print.log("&#128640; 启动MYQ业务流程心跳程序");
  362.    
  363.     // 注册退出处理函数
  364.     java.lang.Runtime.getRuntime().addShutdownHook(new java.lang.Thread({
  365.         run: function() {
  366.             exitHandler();
  367.         }
  368.     }));
  369.    
  370.     // 启动心跳服务 (每30秒执行一次)
  371.     if (startHeartbeatService(30)) {
  372.         print.log("✅ MYQ业务流程心跳程序已启动");
  373.         print.log("&#128161; 按 Ctrl+C 停止程序");
  374.         
  375.         // 保持程序运行
  376.         while (isRunning) {
  377.             java.lang.Thread.sleep(1000);
  378.         }
  379.     } else {
  380.         print.log("❌ MYQ业务流程心跳程序启动失败");
  381.     }
  382.    
  383. } catch (e) {
  384.     print.log("❌ 程序执行过程中发生错误: " + e.message);
  385.     exitHandler();
  386. }

  387. print.log("===== MYQ业务流程心跳程序结束 =====");
复制代码








欢迎光临 B2B网络软件 (http://bbs.niubt.cn/) Powered by Discuz! X3.2