JXM 监控tomcat 7(含代码
admin bibo
jmxremote.access 文件末尾:
admin read #(这里只要有read权限就够了,不需要readwrite)
JAVA_OPTS=
-Dcom.sun.management.jmxremote.password.file=../conf/jmxremote.password
-Dcom.sun.management.jmxremote.access.file=../conf/jmxremote.access
-Dcom.sun.management.jmxremote.ssl=false
-Dcom.sun.management.jmxremote.ssl=false
-Dcom.sun.management.jmxremote.authenticate=true
-Dcom.sun.management.jmxremote.password.file=../conf/jmxremote.password
-Dcom.sun.management.jmxremote.access.file=../conf/jmxremote.access"
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.Map; import javax.management.MBeanServerConnection;
import javax.management.ObjectName;
import javax.management.remote.JMXConnector;
import javax.management.remote.JMXConnectorFactory;
import javax.management.remote.JMXServiceURL; public class TomcatMonitor {
public static String host="127.0.0.1";
public static String port="10001";
public static String user="monitor";
public static String pwd="adchina";
public static String connector="\"http-bio-8080\"";
public static String basepath="/monitordata";
public static void main(String[] args) throws IOException{
Parser(args);
String jmxUrl="service:jmx:rmi:///jndi/rmi://"+host+":"+port+"/jmxrmi";
int jvm_memory_free=0;
int jvm_memory_max=0;
int jvm_memory_total=0; int connector_max_time=0;
int connector_error_count=0;
int connector_bytes_sent=0;
int connector_processing_time=0;
int connector_request_count=0;
int connector_bytes_received=0; int connector_current_thread_count=0;
int connector_min_spare_threads=0;
int connector_max_threads=0;
int connector_max_spare_threads=0;
int connector_current_threads_busy=0;
JMXConnector jmxConnector =null;
try {
JMXServiceURL serviceURL=new JMXServiceURL(jmxUrl);
Map<String,String[]> map=new HashMap<String,String[]>();
String[] credentials = new String[] { user, pwd };
map.put("jmx.remote.credentials", credentials);
jmxConnector = JMXConnectorFactory.connect(serviceURL, map);
MBeanServerConnection mbsc = jmxConnector.getMBeanServerConnection();
ObjectName threadObjName = new ObjectName("Catalina:type=ThreadPool,name="+connector+"");
connector_current_thread_count=Integer.parseInt(mbsc.getAttribute(threadObjName, "currentThreadCount").toString());
connector_min_spare_threads=Integer.parseInt(mbsc.getAttribute(threadObjName, "minSpareThreads").toString());
connector_max_threads=Integer.parseInt(mbsc.getAttribute(threadObjName, "maxThreads").toString());
//if(mbsc.getAttribute(threadObjName, "maxSpareThreads")!=null)
// connector_max_spare_threads=Integer.parseInt(mbsc.getAttribute(threadObjName, "maxSpareThreads").toString());
connector_current_threads_busy=Integer.parseInt(mbsc.getAttribute(threadObjName, "currentThreadsBusy").toString()); ObjectName requestObjectName=new ObjectName("Catalina:type=RequestProcessor,worker=\"http-bio-8080\",name=HttpRequest1");
connector_max_time=Integer.parseInt(mbsc.getAttribute(requestObjectName, "maxTime").toString());
connector_error_count=Integer.parseInt(mbsc.getAttribute(requestObjectName, "errorCount").toString());
connector_bytes_sent=Integer.parseInt(mbsc.getAttribute(requestObjectName, "bytesSent").toString());
connector_processing_time=Integer.parseInt(mbsc.getAttribute(requestObjectName, "processingTime").toString());
connector_request_count=Integer.parseInt(mbsc.getAttribute(requestObjectName, "requestCount").toString());
connector_bytes_received=Integer.parseInt(mbsc.getAttribute(requestObjectName, "bytesReceived").toString()); String output_str="jvm_memory_free:"+jvm_memory_free+" jvm_memory_max:"+jvm_memory_max+" jvm_memory_total:"+jvm_memory_total+
" connector_max_time:"+connector_max_time+" connector_error_count:"+connector_error_count+" connector_bytes_sent:"+connector_bytes_sent+" connector_bytes_received:"+connector_bytes_received+
" connector_processing_time:"+connector_processing_time+" connector_request_count:"+connector_request_count+" connector_current_thread_count:"+connector_current_thread_count+
" connector_min_spare_threads:"+connector_min_spare_threads+" connector_max_threads:"+connector_max_threads+" connector_max_spare_threads:"+connector_max_spare_threads+
" connector_current_threads_busy:"+connector_current_threads_busy;
saveDataToFile(output_str);
} catch (Exception e) {
errorLog(e.getMessage());
}
finally
{
if(connector!=null)
{
try {
jmxConnector.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
} public static void Parser(String[] args)
{
Map<String, String> opt=new HashMap<String,String>();
for(int i=0;i<args.length;i++){
if(args[i].equals("-h")||args[i].equals("--help"))
{
System.out.println("-h,--help show this help message and exit");
System.out.println("-H HOST tomcat server host");
System.out.println("-P PORT tomcat server port");
System.out.println("-u USER jmx user");
System.out.println("-p PWD jmx password");
System.out.println("--path BASEPATH data & log file base path");
System.exit(0);
}
if(args[i].startsWith("-")&&(i+1)<args.length){
opt.put(args[i], args[i+1]);
}
}
host=opt.containsKey("-H")?opt.get("-H"):host;
port=opt.containsKey("-P")?opt.get("-P"):port;
user=opt.containsKey("-u")?opt.get("-u"):user;
pwd=opt.containsKey("-p")?opt.get("-p"):pwd;
connector=opt.containsKey("-c")?opt.get("-c"):connector;
basepath=opt.containsKey("--path")?opt.get("--path"):basepath;
} public static void saveDataToFile(String data_str) throws IOException
{
Date dt=new Date();
String date= new SimpleDateFormat("yyyy.MM.dd").format(dt);
String now=new SimpleDateFormat("HH.mm.ss").format(dt);
String path=basepath+"/Tomcat/data/"+date+"/";
File directory=new File(path);
if(!directory.exists())
directory.mkdirs();
String filePath=path+now+".csv";
File dataFile=new File(filePath);
if(!dataFile.exists())
dataFile.createNewFile();
FileOutputStream fos = new FileOutputStream(filePath,true);
fos.write(data_str.getBytes());
fos.close();
} public static void errorLog(String mes) throws IOException{
Date dt=new Date();
String date= new SimpleDateFormat("yyyy.MM.dd").format(dt);
String now=new SimpleDateFormat("HH:mm:ss").format(dt);
String path=basepath+"/Tomcat/log/";
File directory=new File(path);
if(!directory.exists())
directory.mkdirs();
String filePath=path+date+".csv";
File dataFile=new File(filePath);
if(!dataFile.exists())
dataFile.createNewFile();
FileOutputStream fos = new FileOutputStream(filePath,true);
fos.write(("["+now+"]:"+mes+"\r\n").getBytes());
fos.close();
}
}
JXM 监控tomcat 7(含代码的更多相关文章
- LoadRunner如何监控Tomcat性能
使用LoadRunner做性能测试,一般的直觉是LR只能完成脚本录制和编写模拟用户的请求行为,但是在某些情况下,要监控一些中间件或web服务器的性能时,就不能通过录制脚本来完成了,那么就需要手工来编写 ...
- Jconsole 监控tomcat
通过jconsole监控可以获取监控tomcat的相关的数据信息 如何通过代码来获取其中的线程和内存状况呢? 首先要配置好jconsole监控的相关配置,一搜基本就是那一个, 配置配不好的话接下来的工 ...
- 性能测试中用LambdaProbe监控Tomcat Tomcat和Probe的配置
转载:http://bbs.51testing.com/thread-90047-1-1.html 性能测试中用LambdaProbe监控TomcatLambdaProbe 是一款强大的免费开源工具, ...
- LR如何监控tomcat性能
使用LoadRunner做性能测试,一般的直觉是LR只能完成脚本录制和编写模拟用户的请求行为,但是在某些情况下,要监控一些中间件或web服务器的性能时,就不能通过录制脚本来完成了,那么就需要手工来编写 ...
- zabbix监控自动发现监控tomcat(V1)
背景说明: 由于zabbix监控使用自带的模版,只能监控主机上只有1个tomcat的场景适合,虽然网上很多朋友都是在每个监控项上面添加一个空格来解决问题.但是个人感觉这种方法还是蛮麻烦的,所以写一篇使 ...
- 如何监控tomcat性能
如何监控tomcat性能:[1]工具一 | 浏览:155 | 更新:2014-12-13 10:06 1 2 3 4 5 6 分步阅读 tomcat经常被用作中间件,也有直接作WEB的,自带的工具不是 ...
- 如何监控Tomcat服务器
如何监控Tomcat服务器 发表于:2009-06-25来源:作者:点击数:2651 标签:tomcatTomcat服务器 在进行 性能测试 时,一般都需要对应用服务器进行监控,监控的指标包括应用服务 ...
- 监控应用服务器使用JMX监控Tomcat (推荐)
前言:做了一个监控应用服务器的项目(支持Tocmat.WebSphere.WebLogic各版本), 过程也算是磕磕绊绊,由于网上缺少相关资料,或者深陷于知识的海洋难以寻觅到有效的资料,因而走过不少弯 ...
- 守护进程监控tomcat并自己主动重新启动
昨天的tomcat问题.一天挂了3,4回,受不了了决定写个监控tomcat进程并自己主动重新启动的脚本! 在网上查资料.主要分为两类:一类是定时重新启动tomcat,这当然不是我须要的.还有一类是监控 ...
随机推荐
- linux运维视频教程
视频教程:https://www.bilibili.com/video/av31023006/?p=2 1.文件系统 文件系统树形结构: 对于linux系统的user和application来说,并不 ...
- php7+apache2.4+mysql 环境配置(window环境)
最近,小主从事PHP开发.特将最近如何搭建php7的过程记录在此!希望有需要,可以借鉴!( 电脑必须win7 sp1以上, .netframework4 ) Windows7安装php7,Win7+p ...
- 牛客小白月赛4C——病菌感染
链接:https://www.nowcoder.com/acm/contest/134/C 来源:牛客网 #include <bits/stdc++.h> using namespace ...
- Java设计模式(6)——创建型模式之原型模式(Prototype)
一.概述 概念 // 引用自<Java与模式> UML图 第二种:登记式 二.实践 先导知识 对象的拷贝: 直接赋值:此时只是相当于a1,a2指向同一个对象,无论哪一个操作的都是同一个对象 ...
- MySQL入门第三天(上)——函数与视图
一.MySQL函数 同样的,完整的函数可以参照开源中国的手册:http://tool.oschina.net/apidocs/apidoc?api=mysql-5.1-zh 1.字符函数 CONCAT ...
- 4245: [ONTAK2015]OR-XOR
4245: [ONTAK2015]OR-XOR https://www.lydsy.com/JudgeOnline/problem.php?id=4245 /* 要求分成m份,总价值为a1|a2|a3 ...
- 基于Spring的最简单的定时任务实现与配置(二)
接上一篇,原本我以为我实现的方式很简单了,在准备写(一)的时候,就去查了查别人是怎么实现定时任务的.不查还好,这一查,发现还有更简单的.所以就会有这篇文章. 本文主要是讨论,在完成Spring 项目搭 ...
- Qt-QML-自定义个自己的文本Text
好久都没有正经的更新自己的文章了,这段时间也辞职了,听了小爱的,准备买个碗,自己当老板,下面请欣赏效果图 这个界面布局就是自己是在想不到啥了,按照常规汽车导航的布局布局了一下,主要看内容哈,看看这个文 ...
- UE4蓝图小记
http://www.element3ds.com/forum.php?mod=viewthread&tid=76930&page=1&authorid=104414 http ...
- Java and SDK 环境变量设置
File comes from http://www.cnblogs.com/shinge/p/5500002.html JAVA环境变量配置详解 JAVA环境变量JAVA_HOME.CLASSPAT ...