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

[经验分享] JMX监控weblogic

[复制链接]

尚未签到

发表于 2017-2-14 09:19:31 | 显示全部楼层 |阅读模式
今天尝试着测试一下Weblogic 11g的MDB功能,发现尽管引入了weblogic.jar,可是仍然有很多J2EE的Class找不到。我本地没有安装Weblogic,只好一个类库,一个类库的找。后来在网上发现,原来在Weblogic 10以后,应该使用wlfullclient.jar来取代weblogic.jar。可以使用下面的办法生成wlfullclient.jar。

1. Change directories to the server/lib directory.
cd WL_HOME/server/lib

2. Use the following command to create wlfullclient.jar in the server/lib directory:
java -jar wljarbuilder.jar

3. You can now copy and bundle the wlfullclient.jar with client applications.
转自:http://space.itpub.net/51146/viewspace-663826

4.classpath加入wlfullclient.jar

5.测试代码
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.MBeanAttributeInfo;
import javax.management.MBeanInfo;
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;

@SuppressWarnings("unused")
public class JmxMonitorWeblogic {

    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";
        JmxMonitorWeblogic demo = new JmxMonitorWeblogic();
        demo.initConnection(hostname, portString, username, password);

        demo.printNameAndState(demo.getServerRuntimes());
        //demo.getServletData();
        //demo.printAppNameAndState();
        //demo.printJMS();

        // //得到运行时信息
        //         MBeanInfo runMBeanInfo = connection.getMBeanInfo(ObjectName.getInstance("com.bea:Location=AdminServer,Name=consoleapp,ServerRuntime=AdminServer,Type=ServerRuntime"));
        //         MBeanAttributeInfo[] attr = runMBeanInfo.getAttributes();
        //         for(int i=0;i<attr.length;i++){
        //         if("WorkManagerRuntimes".equals(attr.getName())){
        //         demo.print("Runtime Info", attr.getName());
        //         demo.print("Runtime Desc", attr.getDescription());
        //         }
        //         }
        //
        connector.close();
    }

    /*
     * 实例化与 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();
    }

    // private void initConnectionByJDK(String hostname, String portString,
    // String username, String password) throws IOException,
    // MalformedURLException {
    // String protocol = "rmi";
    // Integer portInteger = Integer.valueOf(portString);
    // int port = portInteger.intValue();
    // String jndiroot = "/jndi/iiop://" + hostname + ":" + port +"/";
    // 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();
    // }

    /*
     * 打印一组 ServerRuntimeMBeans.此 MBean 是运行时 MBean 层次的根,此域中的每个服务器承载自己的实例.
     */
    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
     */
    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"));
                        }
                    }
                }
            }
        }
    }

    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 printJMS() throws Exception {
        ObjectName[] serverRT = getServerRuntimes();

        ObjectName JMSRT = (ObjectName) connection.getAttribute(serverRT[0], "JMSRuntime");

        ObjectName[] JMSServers = (ObjectName[]) connection.getAttribute(JMSRT, "JMSServers");
        int JMSServer_Length = (int) JMSServers.length;

        for (int x = 0; x < JMSServer_Length; x++) {
            String JMSServer_name = (String) connection.getAttribute(JMSServers[x], "Name");

            ObjectName[] JMSDests = (ObjectName[]) connection.getAttribute(JMSServers[x], "Destinations");
            int JMSdest_Length = (int) JMSDests.length;

            for (int y = 0; y < JMSdest_Length; y++) {
                String queue_name = (String) connection.getAttribute(JMSDests[y], "Name");

                long pendingmcount = (Long) connection.getAttribute(JMSDests[y], "MessagesPendingCount");
                long currentcount = (Long) connection.getAttribute(JMSDests[y], "MessagesCurrentCount");

                System.out.println(y + "|jms server name: " + JMSServer_name + "  jms name: " + queue_name
                        + "   pending: " + pendingmcount + "   current: " + currentcount);

            } //for y   

        } //for  x   

    }

    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-341860-1-1.html 上篇帖子: UNIX自动启动Weblogic 服务 下篇帖子: shell方式重启weblogic
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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