Package com.jivesoftware.util.cluster

Source Code of com.jivesoftware.util.cluster.CoherenceInfo$NodeInfo

/**
* $Revision$
* $Date$
*
* Copyright (C) 1999-2009 Jive Software. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*     http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

package com.jivesoftware.util.cluster;

import com.tangosol.coherence.component.util.SafeCluster;
import com.tangosol.net.AbstractInvocable;
import com.tangosol.net.InvocationService;

import java.io.Serializable;
import java.util.Map;

/**
* A utility class which helps to gather Coherence stats and information.
*/
public class CoherenceInfo {

    /**
     * CPU time taken in milliseconds.
     */
    public static final int STATS_CPU_TIME = 0;

    /**
     * Packets sent by publisher.
     */
    public static final int STATS_SENT = 1;

    /**
     * Packets resent by publisher.
     */
    public static final int STATS_RESENT = 2;

    /**
     * Packets sent to the reciever.
     */
    public static final int STATS_RECEIVED = 1;

    /**
     * Repeated packets sent to the receiver.
     */
    public static final int STATS_REPEATED = 2;

    /**
     * Returns a Map of CoherenceInfo.NodeInfo objects keyed by Coherence Member objects.
     * A NodeInfo object is a collection of various Node stats.
     *
     * @return a Map of NodeInfo objects.
     */
    public static Map getNodeInfo() {

        InvocationService service = com.tangosol.net.CacheFactory.getInvocationService("OpenFire Cluster Service");

        // Run cluster-wide stats query
        Map results = service.query(new AbstractInvocable() {
                public void run() {
                    // Get runtime stats - mem and time:
                    Runtime runtime = Runtime.getRuntime();
                    long free = runtime.freeMemory();
                    long total = runtime.totalMemory();
                    long max = runtime.maxMemory();
                    long time = System.currentTimeMillis();
                    // Get cluster stats. Get the cluster then get its listeners. From there,
                    // get more interestig node stats.
                    com.tangosol.coherence.component.net.Cluster cluster =
                            (com.tangosol.coherence.component.net.Cluster)
                            ((SafeCluster)com.tangosol.net.CacheFactory.ensureCluster()).getCluster();

                    //Cluster.PacketPublisher publisher = cluster.getPublisher();
                    long [] publisherStats = new long[3];
                    publisherStats[STATS_CPU_TIME] = cluster.getPublisher().getStatsCpu();
                    publisherStats[STATS_SENT] = cluster.getPublisher().getStatsSent();
                    publisherStats[STATS_RESENT] = cluster.getPublisher().getStatsResent();

                    //Cluster.PacketReceiver receiver = cluster.getReceiver();
                    long [] receiverStats = new long[3];
                    receiverStats[STATS_CPU_TIME] = -1L;//receiver.getStatsCpu();
                    receiverStats[STATS_SENT] = cluster.getReceiver().getStatsReceived();
                    receiverStats[STATS_RESENT] = cluster.getReceiver().getStatsRepeated();

                    NodeInfo nodeInfo = new NodeInfo(free, total, max, time, publisherStats,
                            receiverStats);
                    setResult(nodeInfo);
                }
            }, null);

        return results;
    }

    /**
     * Clears the cache stats.
     */
    public static void clearCacheStats() {

        InvocationService service = com.tangosol.net.CacheFactory.getInvocationService("OpenFire Cluster Service");

        service.execute(new AbstractInvocable() {
            public void run() {
                com.tangosol.coherence.component.net.Cluster cluster =
                        (com.tangosol.coherence.component.net.Cluster)
                        ((SafeCluster)com.tangosol.net.CacheFactory.ensureCluster()).getCluster();

                cluster.getPublisher().resetStats();
                cluster.getReceiver().resetStats();
            }
        }, null, null);
    }

    /**
     * Encapsulates statistics and information about a cluster node.
     */
    public static class NodeInfo implements Serializable {

        private long freeMem;
        private long totalMem;
        private long maxMem;
        private long time;
        private long [] publisherStats;
        private long [] receiverStats;

        NodeInfo(long freeMem, long totalMem, long maxMem, long time, long [] publisherStats,
                long [] receiverStats)
        {
            this.freeMem = freeMem;
            this.totalMem = totalMem;
            this.maxMem = maxMem;
            this.time = time;
            this.publisherStats = publisherStats;
            this.receiverStats = receiverStats;
        }

        /**
         * Returns the amount of free memory in the cluster node's VM (in bytes).
         *
         * @return the amount of free memory on the cluster node.
         */
        public long getFreeMem() {
            return freeMem;
        }

        /**
         * Returns the total amount of memory in the cluster node's VM (in bytes).
         *
         * @return the total amount of memory on the cluster node.
         */
        public long getTotalMem() {
            return totalMem;
        }

        /**
         * Returns the max amount of memory in the cluster node's VM (in bytes).
         *
         * @return the max amount of memory on the cluster node.
         */
        public long getMaxMem() {
            return maxMem;
        }

        /**
         * Returns the current time on the cluster node in long format. This is useful
         * monitoring information for applications that require the local times of each
         * cluster member be to roughly in-synch (on top of the standard Coherence
         * cluster time).<p>
         *
         * This value will always be somewhat inaccurate due to network delays, etc, so
         * should only be taken as an approximate value.
         *
         * @return the local time of the cluster node.
         */
        public long getTime() {
            return time;
        }

        /**
         * Returns statistics about the packet publisher on the node. The following
         * stat values are valid array indexes:<ul>
         *
         *      <li> CoherenceInfo.STATS_CPU_TIME
         *      <li> CoherenceInfo.STATS_SENT
         *      <li> CoherenceInfo.STATS_RESENT
         * </ul>
         *
         * @return packet publisher stats.
         */
        public long [] getPublisherStats() {
            return publisherStats;
        }

        /**
         * Returns statistics about the packet receiver on the node. The following
         * stat values are valid array indexes:<ul>
         *
         *      <li> Coherence.STATS_CPU_TIME
         *      <li> CoherenceInfo.STATS_RECEIVED
         *      <li> CoherenceInfo.STATS_REPEATED</ul>
         *
         * @return packet reciever stats.
         */
        public long [] getReceiverStats() {
            return receiverStats;
        }
    }
}
TOP

Related Classes of com.jivesoftware.util.cluster.CoherenceInfo$NodeInfo

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.