设为首页 收藏本站
查看: 514|回复: 0

[经验分享] 监控weblogic代码

[复制链接]

尚未签到

发表于 2017-2-14 08:35:46 | 显示全部楼层 |阅读模式
代码从别出拷来,运行了一下。可以正常运行。以后可以通过这部分代码来扩展监控。

/**
*
*/
package com.monitor.weblogic;
import java.io.IOException;
import java.net.MalformedURLException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.Hashtable;
import javax.management.MBeanServerConnection;
import javax.management.MalformedObjectNameException;
import javax.management.ObjectName;
import javax.management.remote.JMXConnector;
import javax.management.remote.JMXConnectorFactory;
import javax.management.remote.JMXServiceURL;
import javax.naming.Context;
/**
* @author Administrator
*
*/
public class MonitorWeblogic {
private static MBeanServerConnection connection;
private static JMXConnector connector;
private static final ObjectName service;
/*
* 实例化 DomainRuntimeServiceMBean 对象名,这样可以通过类使用此对象名.
*/
static {
try {
service = new ObjectName(
"com.bea:Name=DomainRuntimeService,Type=weblogic.management.mbeanservers.domainruntime.DomainRuntimeServiceMBean");
} catch (MalformedObjectNameException e) {
throw new AssertionError(e.getMessage());
}
}
public static void main(String[] args) throws Exception {
String hostname = "localhost";
String portString = "7001";
String username = "weblogic";
String password = "weblogic";
MonitorWeblogic weblogic =  new MonitorWeblogic();
weblogic.initConnection(hostname, portString, username, password);
//        weblogic.printNameAndState(weblogic.getServerRuntimes());
//        weblogic.getServletData();
weblogic.printAppNameAndState();
}
/*
* 实例化与 Domain Runtime MBean Server 的连接。
*/
private void initConnection(String hostname, String portString, String username, String password) throws IOException, MalformedURLException {
String protocol = "t3";
Integer portInteger = Integer.valueOf(portString);
int port = portInteger.intValue();
String jndiroot = "/jndi/";
String mserver = "weblogic.management.mbeanservers.domainruntime";
JMXServiceURL serviceURL = new JMXServiceURL(protocol, hostname, port, jndiroot + mserver);
Hashtable<String, String> h = new Hashtable<String, String>();
h.put(Context.SECURITY_PRINCIPAL, username);
h.put(Context.SECURITY_CREDENTIALS, password);
h.put(JMXConnectorFactory.PROTOCOL_PROVIDER_PACKAGES, "weblogic.management.remote");
connector = JMXConnectorFactory.connect(serviceURL, h);
connection = connector.getMBeanServerConnection();
}
public ObjectName[] getServerRuntimes() throws Exception {
return (ObjectName[]) connection.getAttribute(service, "ServerRuntimes");
}
/*
* 迭代 ServerRuntimeMBean,获取名称和状态
*/
public void printNameAndState(ObjectName[] p_objNames) throws Exception {
ObjectName[] serverRT = p_objNames;
System.out.println("got server runtimes");
int length = (int) serverRT.length;
for (int i = 0; i < length; i++) {
print("===================Weblogic运行信息====================", "");
//域名称
String name = (String) connection.getAttribute(serverRT, "Name");
System.out.println("Server name: " + name);
//运行状态
String state = (String) connection.getAttribute(serverRT, "State");
System.out.println("Server state: " + state);
//开始时间
Long activationTime = (Long) connection.getAttribute(serverRT, "ActivationTime");
Calendar cal = Calendar.getInstance();
Date date = cal.getTime();
date.setTime(activationTime);
SimpleDateFormat formater = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String strDateTime = formater.format(date);
System.out.println("Start running time: " + strDateTime);
//weblogic 的版本
String weblogicVersion = (String) connection.getAttribute(serverRT, "WeblogicVersion");
System.out.println("Weblogic Version: " + weblogicVersion);
//OS信息
ObjectName jvmServerRT = (ObjectName) connection.getAttribute(serverRT, "JVMRuntime");
print("=======================OS信息==========================", "");
print(" 操作系统", connection.getAttribute(jvmServerRT, "OSName").toString());
print(" 操作系统版本", connection.getAttribute(jvmServerRT, "OSVersion").toString());
print(" Java版本", connection.getAttribute(jvmServerRT, "JavaVersion").toString());
print(" Java提供商", connection.getAttribute(jvmServerRT, "JavaVMVendor").toString());
long runTime = (Long) connection.getAttribute(jvmServerRT, "Uptime") / 1000;
long day = runTime / (24 * 60 * 60);
long hour = runTime % (24 * 60 * 60) / (60 * 60);
long minute = runTime % (60 * 60) / 60;
long second = runTime % 60;
System.out.println(" 系统已经运行:" + day + "天" + hour + "小时" + minute + "分" + second + "秒");
}
}
/*
*
* 获取一组 WebApplicationComponentRuntimeMBean  取得应用相关信息比如jdbc
*/
public void getServletData() throws Exception {
print("===================ServletData信息====================", "");
ObjectName[] serverRT = getServerRuntimes();
int length = (int) serverRT.length;
for (int i = 0; i < length; i++) {
ObjectName[] appRT = (ObjectName[]) connection.getAttribute(serverRT, "ApplicationRuntimes");
int appLength = (int) appRT.length;
for (int x = 0; x < appLength; x++) {
System.out.println("Application name: " + (String) connection.getAttribute(appRT[x], "Name"));
ObjectName[] compRT = (ObjectName[]) connection.getAttribute(appRT[x], "ComponentRuntimes");
int compLength = (int) compRT.length;
for (int y = 0; y < compLength; y++) {
System.out.println("  Component name: " + (String) connection.getAttribute(compRT[y], "Name"));
String componentType = (String) connection.getAttribute(compRT[y], "Type");
System.out.println("            type: " + componentType.toString());
if (componentType.toString().equals("WebAppComponentRuntime")) {
ObjectName[] servletRTs = (ObjectName[]) connection.getAttribute(compRT[y], "Servlets");
int servletLength = (int) servletRTs.length;
for (int z = 0; z < servletLength; z++) {
System.out.println("    Servlet name: "
+ (String) connection.getAttribute(servletRTs[z], "Name"));
System.out.println("       Servlet context path: "
+ (String) connection.getAttribute(servletRTs[z], "ContextPath"));
System.out.println("       Invocation Total Count : "
+ (Object) connection.getAttribute(servletRTs[z], "InvocationTotalCount"));
}
}
}
}
}
}
/**
* 取得应用状态
* @throws Exception
*/
public void printAppNameAndState() throws Exception {
print("===================AppNameAndState====================", "");
ObjectName[] serverRT = getServerRuntimes();
for (int k = 0; k < serverRT.length; k++) {
ObjectName[] appRT = (ObjectName[]) connection.getAttribute(serverRT[k], "ApplicationRuntimes");
int length = appRT.length;
for (int i = 0; i < length; i++) {
String appName = (String) connection.getAttribute(appRT, "Name");
ObjectName[] compRT = (ObjectName[]) connection.getAttribute(appRT, "ComponentRuntimes");
for (int j = 0; j < compRT.length; j++) {
int appState = ((Integer) connection.getAttribute(compRT[j], "DeploymentState")).intValue();
String type = (String) connection.getAttribute(compRT[j], "Type");
System.out.println(k + "|" + j + "|Server name: " + appName + ".    Server type: " + type
+ "   Server state: " + appState);
}
}
}
}

public void print(String prefix, String content) {
System.out.println(prefix + ": " + content);
}
}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-341787-1-1.html 上篇帖子: WebLogic管理精华 下篇帖子: weblogic清密【原创】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表