排障利器之远程调试与监控 --jmx & remote debug
监控和调试功能是应用必备的属性之一,其手段也是多种多样。
一般地,我们可以通过:线上日志, zabbix, grafana, cat 等待系统做一问题留底,有问题及时报警,从而达到监控效果。
而对于应用的调试,我之前的文章也提到了几个工具,当然,我对于 arthas 是调试赞扬的。请参考: 线上应用调试利器 --Arthas
但有句老话: 一千个人眼里有一千个哈姆雷特!所以,你应该要知道更多的方式。
本文来看看咱们另一个调试调试与监控方式!
1. jmx 怎么样 ?
百科解释: JMX(Java Management Extensions,即Java管理扩展)是一个为应用程序、设备、系统等植入管理功能的框架。JMX可以跨越一系列异构操作系统平台、系统体系结构和网络传输协议,灵活的开发无缝集成的系统、网络和服务管理应用。
简单来说就是,通过jmx,你可以直接观察到jmx管理的东西,从而达到实时监控的效果!另外,还可以通过远程更改jmx的值,从而达到控制管理作用;
要查看监控效果,最简单的方式,是直接使用 jvisualvm 直接连接到远程进行观察,如下:

如果想要更改 jmx 的值,则还是要写点代码的,进行反射后就可以更改了!
2. jmx 如何开启?
如果你对如上的结果还比较满意,那么,你应该考虑下怎么开启jmx了!
其实很简单,一般借助框架进行操作,而应用自身则配置一个 jmx 端口就行了!
-Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.port=
这样开启后,就可以本地连接进行查看了。当然了,如上操作是危险的,请慎重!

另外,我们一般可以多安装两个插件,Mbean 和 Thread Inspector 以便在出现问题时及时查看线程信息!
jmx的输出信息,除了给我们实时监控用外,还可以借助一些第三方工具如grafana进行收集后进行持久化。可视化显示出现!(须借助 jmx_exportor, Prometheus 等工具)
jmx 还可以做什么?
对于线上应用的jvm调优,多半也是可以基于 jmx 做的~
3. remote debug 如何?
remote debug , 看起来有点高大上。至少我自己想来,这种实现方式应该是复杂的!
个人觉得有两个难点:
1. 如何连接到远程进程中debug,关键是远程是以 run 的形式进行的?
2. 远程的代码如何与本地对应?
我们在开发阶段,为什么很容易解决问题?其实,很多时候就是因为可以debug,可以直接跟踪到问题的根源。所以,你懂的,能debug就等于给了你无限的力量!
断点几乎能解决所有的问题。
但是,对于线上应用,你的断点则意味着应用失去响应,可能是事故级操作。所以,还是悠着点~
4. remote debug 如何开启?
同样,如果你觉得这对你还有点用,自然想看下如何开启了。两个步骤!
1. 远程开启调试功能!
-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=
2. ide 开户远程 debug!

就ok 了!
接下来,就是debug时间,支持任意断点,包括启动时的断点;
另外,对于临时的代码改动,可以进行即时生效!
需要注意的是,在远程debug时,控制台的输出将是向远程输出,而非向本地输出!
老话:不要让一个bug从我们手中溜走!
排障利器之远程调试与监控 --jmx & remote debug的更多相关文章
- 系统之锹sysdig:Linux服务器监控和排障利器
当你需要追踪某个进程产生和接收的系统调用时,首先浮现在你脑海中的是什么?你可能会想到strace,那么你是对的.你会使用什么样的命令行工具来监控原始网络通信呢?如果你想到了tcpdump,你又作出了一 ...
- 使用java远程调试技术监控代码运行
JAPA介绍 JPDA(Java Platform Debugger Architecture)是 Java 平台调试体系结构的缩写,通过 JPDA 提供的 API,开发人员可以方便灵活的搭建 Jav ...
- 使用Clion优雅的完全远程自动同步和远程调试c++
摘要:在linux上用vim写C++的时候,通常用gdb进行调试,不能随心所欲的看代码和跳转代码以及加watch(也有可能是因为我还没有get正确的使用方法).为此我发现Clion可以做到自动同步本场 ...
- IDEA远程调试监控端口
大家知道,线上环境定位问题不是那么简单的,如果有非常完善的日志以及监控系统是不必担心的,但是应对这些并不完善的场景下,IDEA提供了一种远程调试的功能,remote集成了可以远程调试的功能,只需要在你 ...
- IDEA + tomcat 远程调试(JPDA)
一.修改 tomcat 配置,启动远程调试 Linux(bin\catalina.sh) # 将 localhost 改为 0.0.0.0 if [ -z "$JPDA_ADDRESS&qu ...
- Pycharm远程调试
1.在pycharm的安装目录中找到pycharm-debug.egg,将其拷贝到目标主机的/usr/lib/python2.7/dist-packages目录下: 执行: sudo easy_ins ...
- Eclipse-cdt 配合 gdbserver 进行 arm 程序远程调试 上
做嵌入式Linux开发也不用再羡慕windows程序员VS集成开发环境的强大,我们同样能够搭建出给力的IDE. 今天在这里记录一下我使用Eclipse-cdt,gdb,gdbserver搭建远程arm ...
- was系统的远程调试
1.进入websphere页面 2.servers->server types->websphere application servers->点击Additional Proper ...
- Eclipse远程调试Tomcat
1.Linux服务器中在Tomcat的catalina.sh文件添加如下内容: CATALINA_OPTS="-Xdebug -Xrunjdwp:transport=dt_socket,ad ...
随机推荐
- java基础第十七篇之网络编程和装饰者模式
1:网络概述 1.1 网络的发展Net 1964年,美国人---> 阿帕网--->以太网Internet 1.2 网络的通信协议 windows电脑,android手机,Mac平板---& ...
- arcgis api 3.x for js 解决 textSymbol 文本换行显示(附源码下载)
前言 关于本篇功能实现用到的 api 涉及类看不懂的,请参照 esri 官网的 arcgis api 3.x for js:esri 官网 api,里面详细的介绍 arcgis api 3.x 各个类 ...
- 第三方库Mantle的源码解析
Mantle是一个用于简化Cocoa或Cocoa Touch程序中model层的第三方库.通常我们的应该中都会定义大量的model来表示各种数据结构,而这些model的初始化和编码解码都需要写大量的代 ...
- Android JS打开原生应用
设置App通过网页JS,唤醒打开本地应用. 在AndroidManifest 中,在应用启动页配置下,添加android:exported="true",设置category 添加 ...
- 一行代码完成 Java的 Excel 读写--easyexcel
最近我在 Github 上查找一个可以快速开发 excel 导入导出工具,偶然发现由阿里开发 easyexcel 开源项目,尝试使用后感觉这款工具挺不错的,下面分享一下我的 easyexcel 案例使 ...
- 7.5 高级数据源---Kafka
一.Kafka简介 Kafka是一种高吞吐量的分布式发布订阅消息系统,用户通过Kafka系统可以发布大量的消息,同时也能实时订阅消费消息.Kafka可以同时满足在线实时处理和批量离线处理. 在公司的大 ...
- Jenkins+Jmeter配置(Linux环境)
1.安装jenkins. 1.1在Linux服务器上,必须先安装jdk与Tomcat, 在/opt/tools/tomcat 安装解压Tomcat 1.2.在Linux服务器上安装jmeter 在/o ...
- 【转】理解并设计rest/restful风格接口
网络应用程序,分为前端和后端两个部分.当前的发展趋势,就是前端设备层出不穷(手机.平板.桌面电脑.其他专用设备......). 因此,必须有一种统一的机制,方便不同的前端设备与后端进行通信.这导致AP ...
- verilog语法标准
initial 中语句超过一需要添加begin和end: 1995 2001 介绍了当用逗号分隔敏感列表更方便构成事件控制表达式的选择条件: 2005 2001/2005语法标准,没有类型定义的任何标 ...
- 小程序-tabBar简易版
<!-- 结构 --> <view class="wrapper"> <block wx:for="{{desc}}"> & ...