先粘一段内容

、程序初哥一般是写死在程序中,到要改变的时候就去修改代码,然后重新编译发布。

、程序熟手则配置在文件中(JAVA一般都是properties文件),到要改变的时候只要修改配置文件,但还是必须重启系统,以便读取配置文件里最新的值。

、程序好手则会写一段代码,把配置值缓存起来,系统在获取的时候,先看看配置文件有没有改动,如有改动则重新从配置里读取,否则从缓存里读取。

、程序高手则懂得物为我所用,用JMX把需要配置的属性集中在一个类中,然后写一个MBean,再进行相关配置。另外JMX还提供了一个工具页,以方便我们对参数值进行修改。

JMX的全称为Java Management Extensions. 顾名思义,是管理Java的一种扩展。这种机制可以方便的管理正在运行中的Java程序。常用于管理线程,内存,日志Level,服务重启,系统环境等。

jmx整体架构:

1, Mbean准备

1, 先建立需要连接的接口

package com.wenbronk.le.iris.jmx;

/**
* 实现接口, 可在jconsoler中调用属性
*/
public interface HelloMBean { public String getName(); public void setName(String name); public String getAge(); public void setAge(String age); public void helloWorld(); public void helloWorld(String str); public void getTelephone(); }

2, 实体类继承

package com.wenbronk.le.iris.jmx;

import ch.qos.logback.core.joran.spi.NoAutoStart;
import lombok.AllArgsConstructor;
import lombok.NoArgsConstructor; /**
* 必须实现 Mbean, 才可以进行注册
*/
@NoArgsConstructor
@AllArgsConstructor
public class Hello implements HelloMBean { private String name;
private String age; @Override
public String getName() {
System.out.println("get name::" + name);
return name;
}
@Override
public void setName(String name) {
this.name = name;
System.out.println("set name " + name);
}
@Override
public String getAge() {
System.out.println("get age::" + age);
return age;
}
@Override
public void setAge(String age) {
this.age = age;
System.out.println("set age " + age);
}
@Override
public void helloWorld() {
System.out.println("hello world");
}
@Override
public void helloWorld(String str) {
System.out.println("hello world " + str);
}
@Override
public void getTelephone() {
System.out.println("get telephone");
}
}

2, 使用java命令行指定

3,

package com.wenbronk.le.iris.jmx.local;

import com.wenbronk.le.iris.jmx.Hello;
import org.junit.Test; import javax.management.*;
import java.lang.management.ManagementFactory; public class HelloAgent { public static void main(String[] args) throws MalformedObjectNameException, NotCompliantMBeanException, InstanceAlreadyExistsException, MBeanRegistrationException, InterruptedException { MBeanServer server = ManagementFactory.getPlatformMBeanServer(); Hello hello = new Hello();
// com.le.iris:type=ZhixinSource/QPS 域名:name=MBean名称
ObjectName helloName = new ObjectName("com.wenbronk.le.jmxBean:name=" + hello.getClass().getName()); ObjectInstance objectInstance = server.registerMBean(hello, helloName); Thread.sleep(**);
}
}

需要添加password等, 并指定权限

jmx.access

monitor readonly
admin readwrite

jmx.password

monitor com.le.big
admin com.le.big

启动参数指定:

JMX_PORT=

JAVA_OPTS="-server \
-Dcom.sun.management.jmxremote\
-Dcom.sun.management.jmxremote.authenticate=true\
-Dcom.sun.management.jmxremote.password.file=jmx.password\
-Dcom.sun.management.jmxremote.access.file=jmx.access\
-Dcom.sun.management.jmxremote.ssl=false\
-Dcom.sun.management.jmxremote.port=${JMX_PORT}\
-Dcom.sun.management.jmxremote.local.only=false\
-Djava.rmi.server.hostname=${IP}\
-Diris.hostname=${IP}\
-Xmx${MEM}m -XX:+UseG1GC -XX:MaxGCPauseMillis= -XX:ParallelGCThreads=\
" nohup java ${JAVA_OPTS} -jar ${APP_JAR_NAME} ${params} >>${APP_HOME}/nohup.log >& &

2, 使用java指定远程连接方式:

3, agentserver的编写

package com.wenbronk.le.iris.jmx.remote;

import com.wenbronk.le.iris.jmx.Hello;
import com.wenbronk.le.iris.jmx.Testtt; import javax.management.MBeanServer;
import javax.management.ObjectInstance;
import javax.management.ObjectName;
import javax.management.remote.JMXConnectorServer;
import javax.management.remote.JMXConnectorServerFactory;
import javax.management.remote.JMXServiceURL;
import java.io.IOException;
import java.lang.management.ManagementFactory;
import java.net.MalformedURLException;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry; /**
* 开启后, 可通过jconsoler进行连接
*/
public class HelloAgentRemote { public static void main(String[] args) throws Exception {
MBeanServer mbs = ManagementFactory.getPlatformMBeanServer(); Hello hello = new Hello("vini", "");
    // 试了下, name 和 type没啥区别
ObjectName helloName = new ObjectName("com.wenbronk.le.jmxBean:name=" + hello.getClass().getSimpleName());
//ObjectName helloName1 = new ObjectName("com.wenbronk.le.jmxBean:type=" + hello.getClass().getSimpleName()); Testtt testtt = new Testtt();
ObjectName testtName = new ObjectName("com.wenbronk.le.jmxBean:type=" + testtt.getClass().getSimpleName());
//ObjectName testtName1 = new ObjectName("com.wenbronk.le.jmxBean:name=" + testtt.getClass().getSimpleName()); System.out.println(hello.getClass().getSimpleName());
ObjectInstance instance = mbs.registerMBean(hello, helloName);
//ObjectInstance instance3 = mbs.registerMBean(hello, helloName1);
ObjectInstance instance2 = mbs.registerMBean(testtt, testtName);
//ObjectInstance instance4 = mbs.registerMBean(testtt, testtName1); try {
// 注册一个端口并绑定
Registry registry = LocateRegistry.createRegistry();
JMXServiceURL jmxServiceURL = new JMXServiceURL("service:jmx:rmi:///jndi/rmi://localhost:9999/jmxrmi");
//service:jmx:rmi:///jndi/rmi://localhost:9999/jmxrmi
JMXConnectorServer jmxConnectorServer = JMXConnectorServerFactory.newJMXConnectorServer(jmxServiceURL, null, mbs); jmxConnectorServer.start(); }catch (Exception e) {
e.printStackTrace();
}
}
}

此时可以通过jconsoler工具进行连接了,

4, 或者自己实现客户端进行连接

package com.wenbronk.le.iris.jmx.remote;

import com.wenbronk.le.iris.jmx.HelloMBean;

import javax.management.*;
import javax.management.remote.JMXConnector;
import javax.management.remote.JMXConnectorFactory;
import javax.management.remote.JMXConnectorServerFactory;
import javax.management.remote.JMXServiceURL;
import java.io.IOException;
import java.net.MalformedURLException; /**
* 远程连接jmx
*/
public class Client { public static void main(String[] args) throws Exception {
JMXServiceURL jmxServiceURL = new JMXServiceURL("service:jmx:rmi:///jndi/rmi://localhost:9999/jmxrmi");
JMXConnector connect = JMXConnectorFactory.connect(jmxServiceURL, null); MBeanServerConnection mBeanServerConnection = connect.getMBeanServerConnection(); String[] domains = mBeanServerConnection.getDomains();
for (int i = ; i < domains.length; i++) {
String obj = domains[i];
System.out.printf("domian[%d] = %s", i, domains[i].toString());
System.out.println();
} // 注册名和之前server的一致
ObjectName objectName = new ObjectName("com.wenbronk.le.jmxBean:name=Hello");
// 获取参数
getParam(mBeanServerConnection, objectName);
System.out.println("get params======================");
// 更改参数
changeParams(mBeanServerConnection, objectName);
getParam(mBeanServerConnection, objectName);
System.out.println("set params======================"); useMethod(mBeanServerConnection, objectName);
getParam(mBeanServerConnection, objectName);
System.out.println("useMethod.========================");
} /**
* 对method的调用, 采用反射的方式进行
*/
public static void useMethod(MBeanServerConnection connection, ObjectName objectName) {
HelloMBean helloMBean = MBeanServerInvocationHandler.newProxyInstance(connection, objectName, HelloMBean.class, true);
String age = helloMBean.getAge();
String name = helloMBean.getName();
helloMBean.setAge("");
helloMBean.helloWorld("nchar");
} /**
* 可进行相关参数修改
* 通过setAttribute、getAttrubute方法来进行操作,则属性的首字母要大写
*/
public static void changeParams(MBeanServerConnection mBeanServerConnection, ObjectName objectName) throws AttributeNotFoundException, InvalidAttributeValueException, ReflectionException, IOException, InstanceNotFoundException, MBeanException {
mBeanServerConnection.setAttribute(objectName, new Attribute("Name", "hangzhou"));
mBeanServerConnection.setAttribute(objectName, new Attribute("Age", ""));
} /**
* 获取参数
*/
public static void getParam(MBeanServerConnection connection, ObjectName objectName) throws AttributeNotFoundException, MBeanException, ReflectionException, InstanceNotFoundException, IOException {
String age = (String) connection.getAttribute(objectName, "Age");
String name = (String) connection.getAttribute(objectName, "Name");
System.out.println("name " + name + " age: " + age);
}
}

https://www.cnblogs.com/dongguacai/p/5900507.html

java-jmx使用的更多相关文章

  1. Java JMX 监管

    Java JMX 监管 JSR 规范系列目录(https://www.cnblogs.com/binarylei/p/10348178.html) JMX(Java Management Extens ...

  2. java jmx

    http://blog.csdn.net/qiao000_000/article/details/6063949 一.JMX简介 什么是JMX?在一篇网文中是这样说的:"JMX(Java M ...

  3. JAVA JMX协议监控

    JMX协议监控,可通过JMX协议远程监控,实时监控线上jvm情况,并通过平台管理界面进行 展示,可以通过监控实时获得线上服务器运行情况. 可以监控内存.实时线程.共享内存等各种信息. 获取实时线程信息 ...

  4. Java jmx的使用

    JMX Java Management Extensions,Java管理扩展.本质就是用来监控java语言开发的程序,一般常用于jconsole,java visual VM的监控,今天主要介绍ja ...

  5. java之JMX

    java之JMX 有关JMX的定义和架构就不具体解释了.见百度百科: http://baike.baidu.com/link? url=6QzGGEqphTmpft3ll5mXmDNVRdvLRZhk ...

  6. Java 监控基础 - 使用 JMX 监控和管理 Java 程序

    点赞再看,动力无限.Hello world : ) 微信搜「程序猿阿朗 」. 本文 Github.com/niumoo/JavaNotes 和 未读代码网站 已经收录,有很多知识点和系列文章. 此篇文 ...

  7. 使用jmx监控tomcat

    1.在tomcat启动过程中,开启相应的参数配置: -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=9999 -D ...

  8. JVM Monitoring: JMX or SNMP?

    JVM Monitoring: JMX or SNMP? By daniel on Feb 23, 2007 Since JavaTM SE 5.0, the JRE provides a means ...

  9. 在Docker中监控Java应用程序的5个方法

    译者注:Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化.通常情况下,监控的主要目的在于:减少宕机 ...

  10. Zabbix系列之三——部署JMX监控tomcat

    zabbix提供了一个java gateway的应用去监控jmx(Java Management Extensions,即Java管理扩展)是一个为应用程序.设备.系统等植入管理功能的框架.JMX可以 ...

随机推荐

  1. Android拖动和缩放

    拖拽和缩放 多点触控的理论学完了之后,这里开始实践.本节主要介绍使用onTouchEvent()方法处理触控事件. 拖动一个对象 如果你使用的是Android 3.0或者之后的系统,那么你可以使用内置 ...

  2. Objective-C的泛型

    WWDC2015的明星是Swift.在Swift语言到2.0以后会被开源,这其中包括了protocol扩展和一个新的错误处理API. 苹果的小baby已经长成,并且意料之中的获得了开发者的关注.但是在 ...

  3. hdu 1576 A/B 【扩展欧几里德】

    题目 A/9973=n 那么:n= A - A / 9973 * 9973   --① 设:A/B=x  则A=B*x,代入①  得  n=B*x-A/9973*9973 然后这个方程中的A/9973 ...

  4. Allegro中常见的文件格式

    allegro/APD.jrl : 记录开启 Allegro/APD 期间每一个执行动作的 command .产生在每一次新开启 Allegro/APD 的现行工作目录下 .env : 存在 pcbe ...

  5. [Phalcon-framework]2016-04-13_安装使用 Phalcon 框架

    1. 获取你的 PHP Version,操作系统是 x86 还是 64bit的,以及 Compiler 是什么 VC, 你可以直接同时 phpinfo() 函数获取到,如下截图: 2.  下载对应的 ...

  6. tensorflow 安装命令

    sudo pip install --upgrade --ignore-installed six tensorflow-0.9.0-py2-none-any.whl

  7. Python基础 --函数的参数

    定义函数的时候,我们把参数的名字和位置确定下来,函数的接口定义就完成了.对于函数的调用者来说,只需要知道如何传递正确的参数,以及函数将返回什么样的值就够了,函数内部的复杂逻辑被封装起来,调用者无需了解 ...

  8. MariaDB 数据库索引详解(9)

    MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可MariaDB的目的是完全兼容MySQL,包括API和命令行,MySQL由于现在闭源了,而能轻松成为MySQ ...

  9. 学习人工智还死拽着Python不放?大牛都在用Anaconda5.2.0

    前言 最近有很多的小白想学习人工智能,可是呢?依旧用Python在学习.我说大哥们,现在都什么年代了,还在把那个当宝一样拽着死死不放吗?懂的人都在用Anaconda5.2.0,里面的功能可强大多了,里 ...

  10. CentOS 7 下网络管理

    如果最小化安装centos7  后会发现,安装完了进去配置网络发现,ifup ,ipconfig 这些命令不见了,那是因为 7 使用了新的网络管理工具NetworkManager ,具体的命令是nmc ...