如何使用JMX来管理程序?
什么是JMX
JMX
,全称Java Management Extensions
,用于我们管理和监控java
应用程序。JMX
有以下用途:
- 监控应用程序的运行状态和相关统计信息。
- 修改应用程序的配置(无需重启)。
- 状态变化或出错时通知处理。
举个例子,我们可以通过jconsole
监控应用程序的堆内存使用量、线程数、类数,查看某些配置信息,甚至可以动态地修改配置。另外,有时还可以利用JMX
来进行测试。
本文将介绍以下内容:
- 什么是
JMX
; JMX
的基础架构;- 如何使用
JMX
。
JMX的基础架构
首先,看下这种图:
这里简单介绍下这三层结构:
层次 | 描述 |
---|---|
Instrumentation | 主要包括了一系列的接口定义和描述如何开发MBean 的规范。在JMX 中MBean 代表一个被管理的资源实例,通过MBean 中暴露的方法和属性,外界可以获取被管理的资源的状态和操纵MBean 的行为。 |
Agent | 用来管理相应的资源,并且为远端用户提供访问的接口。该层的核心是MBeanServer ,所有的MBean 都要向它注册,才能被管理。注册在MBeanServer 上的MBean 并不直接和远程应用程序进行通信,他们通过协议适配器(Adapter )和连接器(Connector )进行通信。 |
Distributed | 定义了一系列用来访问Agent的接口和组件,包括Adapter 和Connector 的描述。注意,Adapter 和Connector 的区别在于:Adapter 是使用某种Internet 协议来与 Agent 获得联系,Agent 端会有一个对象 (Adapter )来处理有关协议的细节。比如SNMP Adapter 和HTTP Adapter 。而Connector 则是使用类似RPC 的方式来访问Agent ,在Agent 端和客户端都必须有这样一个对象来处理相应的请求与应答。比如RMI Connector 。 |
怎么使用JMX
需求
- 测试本地连接管理
MBean
。 - 测试远程连接管理
MBean
,包括代码实现、启动参数、启动参数+配置文件等方式。 - 如何开启账号密码认证。
工程环境
JDK
:1.8.0_231
maven
:3.6.1
IDE
:eclipse 4.12
主要步骤
- 定义
MBean
接口,并编写实现类; - 注册
MBean
到MBeanServe
; - 启动程序;
- 使用
jconsole
连接管理该程序。
创建项目
项目类型Maven Project,打包方式jar
引入依赖
入门案例暂时不需要引入外部依赖。
编写MBean接口
注意,接口名格式必须为:被管理的类的类名+MBean
。
public interface UserMBean {
String getName();
void setName(String name);
Integer getAge();
void setAge(Integer age);
String getAddress();
void setAddress(String address);
String sayHello();
}
编写实现类
这里简单实现下就行。当属性被设置时,会在控制台打印相关内容。
public class User implements UserMBean {
private String name;
private Integer age;
private String address;
public String getName() {
return name;
}
public void setName(String name) {
System.err.println("set name to " + name);
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
System.err.println("set age to " + age);
this.age = age;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
System.err.println("set address to " + address);
this.address = address;
}
public String sayHello() {
return "Hello!";
}
}
本地连接
注册MBean
路径为test
目录下的cn.zzs.jmx
,类名JMXTest
。只有将MBean
注册到MBeanServer
,MBean
才能被管理。MBean
的对象名格式为:域名:type=MBean类型,name=MBean名称
。其中,域名
和MBean名称
可以随便取,对象名中除了type,我们还可以自定义其他条目,以方便管理。
注意,为了让这个程序持续工作,这里强制线程睡眠。
public static void main(String[] args) throws Exception {
// 设置MBean对象名,格式为:“域名:type=MBean类型,name=MBean名称”
String jmxName = "cn.zzs.jmx:type=user,name=user001";
// 获得MBeanServer
MBeanServer server = ManagementFactory.getPlatformMBeanServer();
// 创建ObjectName
ObjectName objectName = new ObjectName(jmxName);
// 创建并注册MBean
server.registerMBean(new User(), objectName);
Thread.sleep(60 * 60 * 1000);
}
测试
启动程序,打开jconsole
(在JDK
安装路径的bin
目录下),出现如下界面,这时可以看到我们测试的程序:
选择JMXTest
后,点击连接,这时如果弹窗“安全连接失败,是否以不安全的方式重试”,这是因为我们没有开启ssl
加密,可以不去理会它。点击不安全的连接,即可进入以下页面:
通过这个窗口我们可以查看程序的堆内存使用量、线程、类等信息,我们再点击MBean
选项卡,可以看到我们编写的MBean
,我们定义的对象名为cn.zzs.jmx:type=user,name=user001
,其中cn.zzs.jmx
作为第一级目录,type=user
作为第二级目录,name=user001
对应具体的对象,它具备属性和操作。其中,user
的setter
和getter
方法被合并在了一起。
通过这个界面,我们可以查看和设置user
的属性,或调用它的方法。例如,我先设置name的值,通过程序控制台可以看到该方法被调用了:
接着我再调用sayHello
方法:
通过以上例子,可以看到,JMX
还是非常有用的,除了查看类的属性外,我们还可以在不重启程序的情况下进行配置或执行某些方法。
以上例子中,我们只能在本地访问JMXTest
,接下来介绍如何实现远程连接。本文介绍三种方式,可根据实际场景选择:
- 代码实现;
- 启动参数配置;
- 启动参数+文件配置。
远程连接方式一(代码实现)
本例子在本地连接的基础上修改。
开启远程连接
注意,这里的localhost
最好改为你的IP
,不然可能连接不上。
public static void main(String[] args) throws Exception {
// 设置MBean对象名,格式为:“域名:type=MBean类型,name=MBean名称”
String jmxName = "cn.zzs.jmx:type=user,name=user001";
// 获得MBeanServer
MBeanServer server = ManagementFactory.getPlatformMBeanServer();
// 创建ObjectName
ObjectName objectName = new ObjectName(jmxName);
// 创建并注册MBean
server.registerMBean(new User(), objectName);
// 注册一个端口
LocateRegistry.createRegistry(9999);
// URL路径的结尾可以随意指定,但如果需要用Jconsole来进行连接,则必须使用jmxrmi
JMXServiceURL url = new JMXServiceURL("service:jmx:rmi:///jndi/rmi://localhost:9999/jmxrmi");
JMXConnectorServer jcs = JMXConnectorServerFactory.newJMXConnectorServer(url, null, server);
jcs.start();
}
测试
打开jconsole
,使用远程连接方式,输入我们设置好的ip和端口,点击连接即可:
远程连接方式二(启动参数)
本例子在本地连接的基础上修改。在程序启动时加入以下启动参数,也可以实现远程连接:
-Djava.rmi.server.hostname=<your-ip> // 你的ip
-Dcom.sun.management.jmxremote.port=9999 // 开放端口号
-Dcom.sun.management.jmxremote.local.only=false // 是否只能本地连接
-Dcom.sun.management.jmxremote.ssl=false // 是否使用ssl加密
-Dcom.sun.management.jmxremote.authenticate=false // 是否需要账号密码认证
可以看到,我们关闭了ssl
加密和账号密码认证。
远程连接方式三(启动参数+配置文件)
本例子在本地连接的基础上修改。
启动参数
在程序启动时加入以下启动参数,并结合配置文件,也可以实现远程连接:
-Dcom.sun.management.config.file=D:/growUp/git_repository/jdk-extend/02-jmx-demo/src/main/resources/config/management.properties // 配置文件路径
-Djava.rmi.server.hostname=<your-ip>
配置文件
在配置文件中配置以下参数:
# 开放端口号
com.sun.management.jmxremote.port=9999
# 是否只能本地连接
com.sun.management.jmxremote.local.only=false
# 是否使用ssl加密
com.sun.management.jmxremote.ssl=false
# 是否需要账号密码认证
com.sun.management.jmxremote.authenticate=false
关于management.propertie
的详细配置,可以在$JRE/lib/management/
目录下找到。其实,当我们在启动参数中存在以下参数时,默认会去读取$JRE/lib/management/management.properties
的配置文件。
# -Dcom.sun.management.jmxremote.port=<port-number>
# or -Dcom.sun.management.snmp.port=<port-number>
设置账户密码
实际使用中,我们更希望采用安全加密的方式来监控程序,这个时候我们可以设置ssl加密或账号密码认证。ssl加密的本文暂时不扩展,这里只介绍如何设置账号密码认证。
启动参数
和上个例子一样,需要设置如下启动参数:
-Dcom.sun.management.config.file=D:/growUp/git_repository/jdk-extend/02-jmx-demo/src/main/resources/config/management.properties
-Djava.rmi.server.hostname=<your-ip>
配置文件
配置文件中加入以下内容:
# 开放端口号
com.sun.management.jmxremote.port=9999
# 是否只能本地连接
com.sun.management.jmxremote.local.only=false
# 是否使用ssl加密
com.sun.management.jmxremote.ssl=false
# 是否需要账号密码认证
com.sun.management.jmxremote.authenticate=true
# 密码文件路径
com.sun.management.jmxremote.password.file=D:/growUp/git_repository/jdk-extend/02-jmx-demo/src/main/resources/config/jmxremote.password
# 权限文件路径
com.sun.management.jmxremote.access.file=D:/growUp/git_repository/jdk-extend/02-jmx-demo/src/main/resources/config/jmxremote.access
在此之前,我们需要配置好密码文件和权限文件:
密码文件
ZhangZiSheng001 root
权限文件
ZhangZiSheng001 readwrite
测试
打开jconsole
,选择远程连接,并输入账号密码,点击连接即可:
参考资料
本文为原创文章,转载请附上原文出处链接:https://www.cnblogs.com/ZhangZiSheng001/p/12128915.html
如何使用JMX来管理程序?的更多相关文章
- 源码详解系列(六) ------ 全面讲解druid的使用和源码
简介 druid是用于创建和管理连接,利用"池"的方式复用连接减少资源开销,和其他数据源一样,也具有连接数控制.连接可靠性测试.连接泄露控制.缓存语句等功能,另外,druid还扩展 ...
- 源码详解系列(七) ------ 全面讲解logback的使用和源码
什么是logback logback 用于日志记录,可以将日志输出到控制台.文件.数据库和邮件等,相比其它所有的日志系统,logback 更快并且更小,包含了许多独特并且有用的特性. logback ...
- 源码详解系列(八) ------ 全面讲解HikariCP的使用和源码
简介 HikariCP 是用于创建和管理连接,利用"池"的方式复用连接减少资源开销,和其他数据源一样,也具有连接数控制.连接可靠性测试.连接泄露控制.缓存语句等功能,另外,和 dr ...
- JMX整理
阅读目录 Standard MBean与MXBean的区别 实现 Notification 认证与授权 JConsole Custom Client What and Why JMX JMX的全称为J ...
- Java之JMX 详解
详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt194 一.JMX简介 JMX是一种JAVA的正式规范,它主要目的是让程序有被 ...
- [转]Java之JMX 详解
一.JMX简介 JMX是一种JAVA的正式规范,它主要目的是让程序有被管理的功能,那么怎么理解所谓的“被管理”呢?试想你开发了一个软件(如WEB网站),它是在24小时不间断运行的,那么你可能会想要“监 ...
- Java管理扩展指南之JMX技术总览
JMX(Java管理扩展)系列 JMX(Java管理扩展)系列旨在介绍包含于Java基础版本(Java SE)中的JMX技术.本系列提供了如何使用JMX重要技术特性的诸多示例. 一.JMX技术总览简要 ...
- JMX jconsole 的使用
JMX 1. JMX简单介绍 JMX的全称为Java Management Extensions. 顾名思义,是管理Java的一种扩展.这种机制可以方便的管理正在运行中的Java程序.常用于管理线程, ...
- python10作业思路及源码:类Fabric主机管理程序开发(仅供参考)
类Fabric主机管理程序开发 一,作业要求 1, 运行程序列出主机组或者主机列表(已完成) 2,选择指定主机或主机组(已完成) 3,选择主机或主机组传送文件(上传/下载)(已完成) 4,充分使用多线 ...
随机推荐
- 枚举类型的数据存入到map中
阅读更多 原文来自http://fokman.iteye.com/blog/1568905 public enum IdeasCMD { RESERVED(0), PING(1), PING_ACK( ...
- 数据库设计mysql字段不默认为NULL原因搜集
索引不会包含有NULL值的列 只要列中包含有NULL值都将不会被包含在索引中,复合索引中只要有一列含有NULL值,那么这一列对于此复合索引就是无效的.所以我们在数据库设计时不要让字段的默认值为NULL ...
- html5的开发
1.html5的开发组织者: (1)WHATWG:由Apple.Mozilla.Google.Opera等浏览器开发者组成,成立于2004年.WHATWG开发HTML和Web应用API,同时为各浏览器 ...
- sequence——强行推式子+组合意义
sequence 考虑长度<=x的方案数F(x),然后(F(x)-F(x-1))*x贡献到答案里 n平方的做法可以直接DP, 感觉有式子可言, 就推出式子:类似coat,每个长度为i的计算i次. ...
- libsvm的安装,数据格式,常见错误,grid.py参数选择,c-SVC过程,libsvm参数解释,svm训练数据,libsvm的使用详解,SVM核函数的选择
直接conda install libsvm安装的不完整,缺几个.py文件. 第一种安装方法: 下载:http://www.csie.ntu.edu.tw/~cjlin/cgi-bin/libsvm. ...
- PHP IF判断 简写
第一种:IF 条件语句 第二种:三元运算 第三种:&& .|| 组成的条件语句 第一种: IF 基础,相信绝大多数人都会: 第二种: c=a>b ? true:false / ...
- python基础十一之装饰器进阶
函数的双下划线方法 def hahahha(): """测试函数""" print('zxc') print(hahahha.__name_ ...
- React 简书
create-react-app jianshu yarn add styled-components -D 利用js写css样式 样式会更高效 https://github.com ...
- H3C RIPv2配置任务
- linux一些重要数据结构
如同你想象的, 注册设备编号仅仅是驱动代码必须进行的诸多任务中的第一个. 我们将很 快看到其他重要的驱动组件, 但首先需要涉及一个别的. 大部分的基础性的驱动操作包括 3 个重要的内核数据结构, 称为 ...