如何给程序添加监控?

11 篇文章 0 订阅
5 篇文章 0 订阅

监控程序

监控内容:
在程序里面写一个get方法,返回当前版本、服务器和端口号、运行时长,目前程序在做的事情数据、MySQL连接是否正常。

代码示范:

//Controller层
@GetMapping(value="/getHeartbeat",produces="application/json;charset=utf-8")
    @ApiOperation(value="获取程序的心跳", notes="获取程序的心跳")
    public AjaxResult getHeartbeat(){
        try {
            return xxxService.getHeartbeat();
        } catch (Exception e) {
            e.printStackTrace();
            return AjaxResult.error();
        }
    }
//xxxServiceImpl

    public  String vers="v1202";
    @Value("${server.port}")
    public  String serverPort;
    
 @Override
    public AjaxResult getHeartbeat() {
        HashMap<String, Object> map = new HashMap<>();
        map.put("vers",vers);
        map.put("tmct","xxx:"+serverPort);
        SimpleDateFormat format2= new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String date = format2.format(new Date());
        String s = dateDiff(getServerStartTime(), date);
        map.put("runing",s);
        //业务数据
        map.put("run_ok/no",数据大小或值);
        map.put("mysql",MysqlListenerUtil.mysqlMonitor());
        return AjaxResult.success(map);
    }


    /*
     * 	获取程序启动时间
     */
    public String getServerStartTime(){
        long time = ManagementFactory.getRuntimeMXBean().getStartTime();
        SimpleDateFormat format2= new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String date = format2.format(new Date(time));
        return date;
    }

    /**
     *
     * @param startTime
     * @param endTime
     * @return 运行时间 天,时,分,秒
     */
    public String dateDiff(String startTime, String endTime) {
        // 按照传入的格式生成一个simpledateformate对象
        SimpleDateFormat sd = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        long nd = 1000 * 24 * 60 * 60;// 一天的毫秒数
        long nh = 1000 * 60 * 60;// 一小时的毫秒数
        long nm = 1000 * 60;// 一分钟的毫秒数
        long ns = 1000;// 一秒钟的毫秒数
        long diff;
        long day = 0;
        long hour = 0;
        long min = 0;
        long sec = 0;
        String result = "0";
        // 获得两个时间的毫秒时间差异
        try {
            diff = sd.parse(endTime).getTime() - sd.parse(startTime).getTime();
            day = diff / nd;// 计算差多少天
            hour = diff % nd / nh + day * 24;// 计算差多少小时
            min = diff % nd % nh / nm + day * 24 * 60;// 计算差多少分钟
            sec = diff % nd % nh % nm / ns;// 计算差多少秒
        } catch (ParseException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        String str  = day+"d."+(hour - day * 24)+"h."+(min - day * 24 * 60) +"m."+sec+"s";
        log.info("时间相差:" + day + "天" + (hour - day * 24) + "小时"
                + (min - day * 24 * 60) + "分钟" + sec + "秒。");
        return str;
    }

//mysql监控类
public class MysqlListenerUtil {

    public static boolean mysqlMonitor() {
        //数据库加载器
        String driverName="com.mysql.cj.jdbc.Driver";
        //端口号以及数据库名称
        String url="jdbc:mysql://localhost:3306/xxxxx?useUnicode=true&characterEncoding=UTF-8&useSSL=false";
        //用户名
        String userName="root";
        //用户密码
        String userPwd="root";
        //数据库连接成功
        boolean isSuccess = false;
        try {
            Class.forName(driverName);
            Connection dbConn = DriverManager.getConnection(url,userName,userPwd);
            isSuccess = true;
            System.out.println("连接数据库成功"+dbConn);
        }catch (Exception e) {
            if(e.toString().contains("Too many connections")){
                String msg = "Too many connections";
                System.out.println("数据库连接失败:"+msg);
            }

        }
        return isSuccess;
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你可以使用进度条库,比如tqdm(Python库),来为程序进程添加进度图。这个库可以很容易地添加进度条到循环中,让你实时了解程序的进度。 以下是一个简单的 Python 示例代码,使用 tqdm 库来添加进度条: ```python from tqdm import tqdm import time for i in tqdm(range(100)): time.sleep(0.1) ``` 运行这个程序将会在控制台中显示一个进度条,显示程序的进度,每次迭代之后会更新进度条。你可以根据需要自定义进度条的外观和更新频率。 ### 回答2: 要给程序进程添加进度图,可以通过以下几个步骤来实现。 首先,需要确定进度的单位和范围。根据程序的特点和需要,可以选择时间、任务数量、数据处理量等作为进度的单位,然后确定进度的总量,将其转换为百分比。 接下来,需要在程序中设置进度的更新点。通常情况下,进度应该在程序运行的不同阶段或重要操作之后进行更新,以保证进度图的准确性。 然后,根据所选择的单位和范围,计算出当前的进度。可以通过记录完成的任务数量、处理的数据量等来实时更新进度。需要注意的是,进度的计算要尽量准确,不能过早或过晚进行更新,以免给用户造成困惑或不可预测的情况。 最后,将进度以图形的形式展示给用户。可以使用进度条、饼图等图形来表示进度的完成情况。可以通过在控制台输出相应的字符,或者使用图形界面库来实现进度图的绘制。 除了以上的基本步骤,还可以考虑增加一些附加功能,例如设置进度的颜色、添加进度的描述信息等,以增强用户的可视化体验。 总之,要给程序进程添加进度图,需要确定进度的单位和范围,设置进度的更新点,计算并更新进度,最后以图形的形式展示给用户。 ### 回答3: 要给程序进程添加进度图,可以通过以下方法实现: 1. 使用进度条控件:通过在程序界面中添加一个进度条控件来显示程序的进度。可以根据程序的完成情况调整进度条的进度,使其实时显示程序的进度状态。 2. 打印进度信息:在程序执行过程中,可以通过打印进度信息来显示程序的进度。可以在程序中设置打印语句,输出包括进度百分比、当前正在执行的任务等信息,以便用户了解程序的执行进度。 3. 使用日志文件:可以将程序的执行过程记录到一个日志文件中,并在其中添加进度信息。通过查看日志文件,用户可以了解程序的执行进度和每个阶段的耗时情况。 4. 使用进度监控工具:有一些专门用于监控程序进度的工具,可以在程序执行期间实时监测程序的进度,并以可视化的方式展示。这些工具通常提供面板化界面,可以显示程序的整体进度、当前正在执行的任务等信息。 5. 借助第三方库:某些编程语言和框架提供了用于显示进度的库函数,可以直接调用这些函数来添加进度图。例如,在Python中,可以使用tqdm库来显示程序的进度条。 总之,给程序进程添加进度图可以通过上述方法实现,具体选择哪种方式取决于程序的特点、用户的需求以及可用的资源和工具。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值