2 * Copyright (c) 2001-2007 Sun Microsystems, Inc. All rights reserved.
4 * The Sun Project JXTA(TM) Software License
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions are met:
9 * 1. Redistributions of source code must retain the above copyright notice,
10 * this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright notice,
13 * this list of conditions and the following disclaimer in the documentation
14 * and/or other materials provided with the distribution.
16 * 3. The end-user documentation included with the redistribution, if any, must
17 * include the following acknowledgment: "This product includes software
18 * developed by Sun Microsystems, Inc. for JXTA(TM) technology."
19 * Alternately, this acknowledgment may appear in the software itself, if
20 * and wherever such third-party acknowledgments normally appear.
22 * 4. The names "Sun", "Sun Microsystems, Inc.", "JXTA" and "Project JXTA" must
23 * not be used to endorse or promote products derived from this software
24 * without prior written permission. For written permission, please contact
25 * Project JXTA at http://www.jxta.org.
27 * 5. Products derived from this software may not be called "JXTA", nor may
28 * "JXTA" appear in their name, without prior written permission of Sun.
30 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
31 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
32 * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SUN
33 * MICROSYSTEMS OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
34 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
35 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
36 * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
37 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
38 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
39 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
41 * JXTA is a registered trademark of Sun Microsystems, Inc. in the United
42 * States and other countries.
44 * Please see the license information page at :
45 * <http://www.jxta.org/project/www/license.html> for instructions on use of
46 * the license in source files.
48 * ====================================================================
50 * This software consists of voluntary contributions made by many individuals
51 * on behalf of Project JXTA. For more information on Project JXTA, please see
52 * http://www.jxta.org.
54 * This license is based on the BSD license adopted by the Apache Foundation.
57 package net.jxta.impl.endpoint.transportMeter;
60 import net.jxta.document.Element;
61 import net.jxta.document.TextElement;
62 import net.jxta.endpoint.EndpointAddress;
63 import net.jxta.endpoint.Message;
64 import net.jxta.impl.meter.MetricUtilities;
65 import net.jxta.peer.PeerID;
66 import net.jxta.util.documentSerializable.DocumentSerializable;
67 import net.jxta.util.documentSerializable.DocumentSerializableUtilities;
68 import net.jxta.util.documentSerializable.DocumentSerializationException;
70 import java.util.Enumeration;
73 public class TransportBindingMetric implements DocumentSerializable {
74 public static final String CONNECTED = "connected";
75 public static final String CLOSED = "closed";
76 public static final String DROPPED = "dropped";
77 public static final String FAILED = "failed";
79 private PeerID peerID;
80 private EndpointAddress endpointAddress;
82 private String initiatorState = null;
83 private String acceptorState = null;
84 private long initiatorTransitionTime;
85 private long acceptorTransitionTime;
87 private int acceptorBytesReceived;
88 private int acceptorBytesSent;
89 private int acceptorConnections;
90 private int acceptorConnectionsClosed;
91 private int acceptorConnectionsDropped;
92 private int acceptorConnectionsFailed;
93 private int acceptorMessagesReceived;
94 private int acceptorMessagesSent;
95 private long acceptorReceiveFailureProcessingTime;
96 private int acceptorReceiveFailures;
97 private long acceptorReceiveProcessingTime;
98 private long acceptorSendFailureProcessingTime;
99 private int acceptorSendFailures;
100 private long acceptorSendProcessingTime;
101 private long acceptorTotalTimeConnected;
102 private long acceptorTimeToConnect;
103 private long acceptorTimeToFail;
104 private int initiatorBytesReceived;
105 private int initiatorBytesSent;
106 private long initiatorTotalTimeConnected;
107 private int initiatorConnections;
108 private int initiatorConnectionsClosed;
109 private int initiatorConnectionsDropped;
110 private int initiatorConnectionsFailed;
111 private int initiatorMessagesReceived;
112 private int initiatorMessagesSent;
113 private long initiatorReceiveFailureProcessingTime;
114 private int initiatorReceiveFailures;
115 private long initiatorReceiveProcessingTime;
116 private long initiatorSendFailureProcessingTime;
117 private int initiatorSendFailures;
118 private long initiatorSendProcessingTime;
119 private long initiatorTimeToConnect;
120 private long initiatorTimeToFail;
122 private int numPings;
123 private int numFailedPings;
124 private long pingTime;
125 private long pingFailedTime;
126 private int numPingsReceived;
128 public TransportBindingMetric(TransportBindingMeter transportBindingMeter, boolean initiatorConnected, boolean acceptorConnected) {
129 this.peerID = transportBindingMeter.getPeerID();
130 this.endpointAddress = transportBindingMeter.getEndpointAddress();
131 this.initiatorState = initiatorConnected ? CONNECTED : CLOSED;
132 this.acceptorState = acceptorConnected ? CONNECTED : CLOSED;
135 public TransportBindingMetric() {}
137 public TransportBindingMetric(TransportBindingMetric prototype) {
138 this.peerID = prototype.peerID;
139 this.endpointAddress = prototype.endpointAddress;
140 this.initiatorState = prototype.initiatorState;
141 this.acceptorState = prototype.acceptorState;
142 this.initiatorTransitionTime = prototype.initiatorTransitionTime;
143 this.acceptorTransitionTime = prototype.acceptorTransitionTime;
147 public boolean equals(Object obj) {
148 if (obj instanceof TransportBindingMetric) {
149 TransportBindingMetric other = (TransportBindingMetric) obj;
151 return endpointAddress.equals(other.endpointAddress);
158 public int hashCode() {
159 return peerID.hashCode() + endpointAddress.hashCode();
162 public PeerID getPeerID() {
166 public void setPeerID(PeerID peerID) {
167 this.peerID = peerID;
170 public EndpointAddress getEndpointAddress() {
171 return endpointAddress;
175 * State of this Initiator Binding
177 * @return TransportBindingMetric.CONNECTED, TransportBindingMetric.DISCONNECTED or TransportBindingMetric.FAILED
179 public String getInitiatorState() {
180 return initiatorState;
184 * State of this Acceptor Binding
186 * @return TransportBindingMetric.CONNECTED, TransportBindingMetric.DISCONNECTED or TransportBindingMetric.FAILED
188 public String getAcceptorState() {
189 return acceptorState;
193 * Get the time that it entered the current state
195 * @return transition time in ms since January 1, 1970, 00:00:00 GMT
197 public long getInitiatorTransitionTime() {
198 return initiatorTransitionTime;
202 * Get the time that it entered the current state
204 * @return transition time in ms since January 1, 1970, 00:00:00 GMT
206 public long getAcceptorTransitionTime() {
207 return acceptorTransitionTime;
210 public boolean isAcceptorConnected() {
211 return (acceptorState != null) && acceptorState.equals(CONNECTED);
214 public boolean isInitiatorConnected() {
215 return (initiatorState != null) && initiatorState.equals(CONNECTED);
218 public long getTimeAcceptorConnectionEstablished() {
219 return isAcceptorConnected() ? acceptorTransitionTime : 0;
222 public long getTimeInitiatorConnectionEstablished() {
223 return isInitiatorConnected() ? initiatorTransitionTime : 0;
226 public int getAcceptorBytesReceived() {
227 return acceptorBytesReceived;
230 public int getAcceptorBytesSent() {
231 return acceptorBytesSent;
234 public int getAcceptorConnections() {
235 return acceptorConnections;
238 public int getAcceptorConnectionsClosed() {
239 return acceptorConnectionsClosed;
242 public int getAcceptorConnectionsDropped() {
243 return acceptorConnectionsDropped;
246 public int getAcceptorConnectionsFailed() {
247 return acceptorConnectionsFailed;
250 public int getAcceptorMessagesReceived() {
251 return acceptorMessagesReceived;
254 public int getAcceptorMessagesSent() {
255 return acceptorMessagesSent;
258 public long getAcceptorReceiveFailureProcessingTime() {
259 return acceptorReceiveFailureProcessingTime;
262 public int getAcceptorReceiveFailures() {
263 return acceptorReceiveFailures;
266 public long getAcceptorReceiveProcessingTime() {
267 return acceptorReceiveProcessingTime;
270 public long getAcceptorSendFailureProcessingTime() {
271 return acceptorSendFailureProcessingTime;
274 public int getAcceptorSendFailures() {
275 return acceptorSendFailures;
278 public long getAcceptorSendProcessingTime() {
279 return acceptorSendProcessingTime;
282 public long getAcceptorTimeToConnect() {
283 return acceptorTimeToConnect;
286 public long getAcceptorTimeToFail() {
287 return acceptorTimeToFail;
290 public int getInitiatorBytesReceived() {
291 return initiatorBytesReceived;
294 public int getInitiatorBytesSent() {
295 return initiatorBytesSent;
298 public int getInitiatorConnections() {
299 return initiatorConnections;
302 public int getInitiatorConnectionsClosed() {
303 return initiatorConnectionsClosed;
306 public int getInitiatorConnectionsDropped() {
307 return initiatorConnectionsDropped;
310 public int getInitiatorConnectionsFailed() {
311 return initiatorConnectionsFailed;
314 public int getInitiatorMessagesReceived() {
315 return initiatorMessagesReceived;
318 public int getInitiatorMessagesSent() {
319 return initiatorMessagesSent;
322 public long getInitiatorReceiveFailureProcessingTime() {
323 return initiatorReceiveFailureProcessingTime;
326 public int getInitiatorReceiveFailures() {
327 return initiatorReceiveFailures;
330 public long getInitiatorReceiveProcessingTime() {
331 return initiatorReceiveProcessingTime;
334 public long getInitiatorSendFailureProcessingTime() {
335 return initiatorSendFailureProcessingTime;
338 public int getInitiatorSendFailures() {
339 return initiatorSendFailures;
342 public long getInitiatorSendProcessingTime() {
343 return initiatorSendProcessingTime;
346 public long getInitiatorTimeToConnect() {
347 return initiatorTimeToConnect;
350 public long getInitiatorTimeToFail() {
351 return initiatorTimeToFail;
354 public int getNumPings() {
358 public int getNumFailedPings() {
359 return numFailedPings;
362 public long getPingTime() {
366 public long getPingFailedTime() {
367 return pingFailedTime;
370 public int getNumPingsReceived() {
371 return numPingsReceived;
374 public int getBytesReceived() {
375 return acceptorBytesReceived + initiatorBytesReceived;
378 public int getBytesSent() {
379 return acceptorBytesSent + initiatorBytesSent;
382 public int getConnections() {
383 return acceptorConnections + initiatorConnections;
386 public int getConnectionsClosed() {
387 return acceptorConnectionsClosed + initiatorConnectionsClosed;
390 public int getConnectionsDropped() {
391 return acceptorConnectionsDropped + initiatorConnectionsDropped;
394 public int getConnectionsFailed() {
395 return acceptorConnectionsFailed + initiatorConnectionsFailed;
398 public int getMessagesReceived() {
399 return acceptorMessagesReceived + initiatorMessagesReceived;
402 public int getMessagesSent() {
403 return acceptorMessagesSent + initiatorMessagesSent;
406 public long getReceiveFailureProcessingTime() {
407 return acceptorReceiveFailureProcessingTime + initiatorReceiveFailureProcessingTime;
410 public int getReceiveFailures() {
411 return acceptorReceiveFailures + initiatorReceiveFailures;
414 public long getReceiveProcessingTime() {
415 return acceptorReceiveProcessingTime + initiatorReceiveProcessingTime;
418 public long getSendFailureProcessingTime() {
419 return acceptorSendFailureProcessingTime + initiatorSendFailureProcessingTime;
422 public int getSendFailures() {
423 return acceptorSendFailures + initiatorSendFailures;
426 public long getSendProcessingTime() {
427 return acceptorSendProcessingTime + initiatorSendProcessingTime;
430 public long getTotalTimeConnected() {
431 return acceptorTotalTimeConnected + initiatorTotalTimeConnected;
434 public long getTimeToConnect() {
435 return acceptorTimeToConnect + initiatorTimeToConnect;
438 public long getTimeToFail() {
439 return acceptorTimeToFail + initiatorTimeToFail;
442 public int getAveragePingTime() {
443 return (int) ((numPings != 0) ? (pingTime / numPings) : 0);
446 public int getAveragePingFailedTime() {
447 return (int) ((numFailedPings != 0) ? (pingFailedTime / numFailedPings) : 0);
450 public int getAverageAcceptorReceiveFailureProcessingTime() {
451 return (int) ((acceptorReceiveFailures != 0) ? (acceptorReceiveFailureProcessingTime / acceptorReceiveFailures) : 0);
454 public int getAverageAcceptorReceiveProcessingTime() {
455 return (int) ((acceptorMessagesReceived != 0) ? (acceptorReceiveProcessingTime / acceptorMessagesReceived) : 0);
458 public int getAverageAcceptorSendFailureProcessingTime() {
459 return (int) ((acceptorSendFailures != 0) ? (acceptorSendFailureProcessingTime / acceptorSendFailures) : 0);
462 public int getAverageAcceptorSendProcessingTime() {
463 return (int) ((acceptorMessagesSent != 0) ? (acceptorSendProcessingTime / acceptorMessagesSent) : 0);
466 public int getAverageAcceptorTimeToConnect() {
467 return (int) ((acceptorConnections != 0) ? (acceptorTimeToConnect / acceptorConnections) : 0);
470 public int getAverageAcceptorTimeToFail() {
471 return (int) ((acceptorConnectionsFailed != 0) ? (acceptorTimeToFail / acceptorConnectionsFailed) : 0);
474 public int getAverageInitiatorReceiveFailureProcessingTime() {
475 return (int) ((initiatorReceiveFailures != 0) ? (initiatorReceiveFailureProcessingTime / initiatorReceiveFailures) : 0);
478 public int getAverageInitiatorReceiveProcessingTime() {
479 return (int) ((initiatorMessagesReceived != 0) ? (initiatorReceiveProcessingTime / initiatorMessagesReceived) : 0);
482 public int getAverageInitiatorSendFailureProcessingTime() {
483 return (int) ((initiatorSendFailures != 0) ? (initiatorSendFailureProcessingTime / initiatorSendFailures) : 0);
486 public int getAverageInitiatorSendProcessingTime() {
487 return (int) ((initiatorMessagesSent != 0) ? (initiatorSendProcessingTime / initiatorMessagesSent) : 0);
490 public int getAverageInitiatorTimeToConnect() {
491 return (int) ((initiatorConnections != 0) ? (initiatorTimeToConnect / initiatorConnections) : 0);
494 public int getAverageInitiatorTimeToFail() {
495 return (int) ((initiatorConnectionsFailed != 0) ? (initiatorTimeToFail / initiatorConnectionsFailed) : 0);
498 public int getAverageReceiveFailureProcessingTime() {
499 return (int) (((initiatorReceiveFailures + acceptorReceiveFailures) != 0)
500 ? ((initiatorReceiveFailureProcessingTime + acceptorReceiveFailureProcessingTime)
501 / (initiatorReceiveFailures + acceptorReceiveFailures))
505 public int getAverageReceiveProcessingTime() {
506 return (int) (((initiatorMessagesReceived + acceptorMessagesReceived) != 0)
507 ? ((initiatorReceiveProcessingTime + acceptorReceiveProcessingTime)
508 / (initiatorMessagesReceived + acceptorMessagesReceived))
512 public int getAverageSendFailureProcessingTime() {
513 return (int) (((initiatorSendFailures + acceptorSendFailures) != 0)
514 ? ((initiatorSendFailureProcessingTime + acceptorSendFailureProcessingTime)
515 / (initiatorSendFailures + acceptorSendFailures))
519 public int getAverageSendProcessingTime() {
520 return (int) (((initiatorMessagesSent + acceptorMessagesSent) != 0)
521 ? ((initiatorSendProcessingTime + acceptorSendProcessingTime) / (initiatorMessagesSent + acceptorMessagesSent))
525 public int getAverageTimeToConnect() {
526 return (int) (((initiatorConnections + acceptorConnections) != 0)
527 ? ((initiatorTimeToConnect + acceptorTimeToConnect) / (initiatorConnections + acceptorConnections))
531 public int getAverageTimeToFail() {
532 return (int) (((initiatorConnectionsFailed + acceptorConnectionsFailed) != 0)
533 ? ((initiatorTimeToFail + acceptorTimeToFail) / (initiatorConnectionsFailed + acceptorConnectionsFailed))
538 * Get the total time this intiated connection has been connected.
540 * <B>Note:</B> This does not include the current time connected (if it is currently connected)
542 * @return time in ms (see note above)
543 * @see #getTotalTimeConnected()
545 public long getInitiatorTotalTimeConnected() {
546 return initiatorTotalTimeConnected;
550 * Get the total time this initiating connection has been connected. If it is currently
551 * connected, then the total time is adjusted to include the time since the transition time
552 * to become connected until the provided time
554 * @param adjustmentTime The time of this metric will be adjusted to
555 * @return time in ms (see note above)
556 * @see #getTotalTimeConnected()
558 public long getInitiatorTotalTimeConnected(long adjustmentTime) {
559 long result = initiatorTotalTimeConnected;
561 if (isInitiatorConnected()) {
562 result += (adjustmentTime - this.initiatorTransitionTime);
569 * Get the duration of current connection relative to local clock (from transition time)
571 * <B>Note:</B> This assumes the clocks are in sync with the reporting peer
573 * @return time in ms (see note above) or 0 if not connected
574 * @see #getTotalTimeConnected()
576 public long getInitiatorTimeConnected() {
577 return getInitiatorTimeConnected(System.currentTimeMillis());
581 * Get the duration of current connection until the specified time
583 * @param adjustmentTime The time of this metric will be computed until
584 * @return time in ms (see note above) or 0 if not connected
586 public long getInitiatorTimeConnected(long adjustmentTime) {
588 if (isInitiatorConnected()) {
589 return (adjustmentTime - this.initiatorTransitionTime);
596 * Get the total time this intiated connection has been connected.
598 * <B>Note:</B> This does not include the current time connected (if it is currently connected)
600 * @return time in ms (see note above)
601 * @see #getTotalTimeConnected()
603 public long getAcceptorTotalTimeConnected() {
604 return acceptorTotalTimeConnected;
608 * Get the total time this initiating connection has been connected. If it is currently
609 * connected, then the total time is adjusted to include the time since the transition time
610 * to become connected until the provided time
612 * @param adjustmentTime The time of this metric will be adjusted to
613 * @return time in ms (see note above)
614 * @see #getTotalTimeConnected()
616 public long getAcceptorTotalTimeConnected(long adjustmentTime) {
617 long result = acceptorTotalTimeConnected;
619 if (isAcceptorConnected()) {
620 result += (adjustmentTime - this.acceptorTransitionTime);
627 * Get the duration of current connection relative to local clock (from transition time)
629 * <B>Note:</B> This assumes the clocks are in sync with the reporting peer
631 * @return time in ms (see note above) or 0 if not connected
632 * @see #getTotalTimeConnected()
634 public long getAcceptorTimeConnected() {
635 return getAcceptorTimeConnected(System.currentTimeMillis());
639 * Get the duration of current connection until the specified time
641 * @param adjustmentTime The time of this metric will be computed until
642 * @return time in ms (see note above) or 0 if not connected
644 public long getAcceptorTimeConnected(long adjustmentTime) {
646 if (isAcceptorConnected()) {
647 return (adjustmentTime - this.acceptorTransitionTime);
653 void resetInitiatorState(String state, long transitionTime) {
654 if (isInitiatorConnected()) {
655 acceptorTotalTimeConnected += (System.currentTimeMillis() - this.initiatorTransitionTime);
658 this.initiatorState = state;
659 this.initiatorTransitionTime = transitionTime;
660 // System.out.println("initiatorState: " + initiatorState + " " + endpointAddress);
663 void resetAcceptorState(String state, long transitionTime) {
664 if (isAcceptorConnected()) {
665 initiatorTotalTimeConnected += (System.currentTimeMillis() - this.acceptorTransitionTime);
668 this.acceptorState = state;
669 this.acceptorTransitionTime = transitionTime;
670 // System.out.println("acceptorState: " + acceptorState + " " + endpointAddress);
673 void connectionEstablished(boolean initiator, long timeToConnect, long transitionTime) {
675 resetInitiatorState(CONNECTED, transitionTime);
676 initiatorConnections++;
677 initiatorTimeToConnect += timeToConnect;
679 resetAcceptorState(CONNECTED, transitionTime);
680 acceptorConnections++;
681 acceptorTimeToConnect += timeToConnect;
686 void connectionFailed(boolean initiator, long timeToConnect, long transitionTime) {
688 resetInitiatorState(FAILED, transitionTime);
689 initiatorConnectionsFailed++;
690 initiatorTimeToFail += timeToConnect;
692 resetAcceptorState(FAILED, transitionTime);
693 acceptorConnectionsFailed++;
694 acceptorTimeToFail += timeToConnect;
698 void connectionClosed(boolean initiator, long transitionTime) {
700 resetInitiatorState(CLOSED, transitionTime);
701 initiatorConnectionsClosed++;
703 resetAcceptorState(CLOSED, transitionTime);
704 acceptorConnectionsClosed++;
708 void connectionDropped(boolean initiator, long transitionTime) {
710 resetInitiatorState(DROPPED, transitionTime);
711 initiatorConnectionsDropped++;
713 resetAcceptorState(DROPPED, transitionTime);
714 acceptorConnectionsDropped++;
718 void pingReceived() {
722 void ping(long time) {
727 void pingFailed(long time) {
729 pingFailedTime += time;
732 void dataReceived(boolean initiator, int size) {
734 initiatorBytesReceived += size;
736 acceptorBytesReceived += size;
740 void messageReceived(boolean initiator, Message message, long time, long size) {
742 initiatorMessagesReceived++;
743 initiatorReceiveProcessingTime += time;
744 initiatorBytesReceived += size;
746 acceptorMessagesReceived++;
747 acceptorReceiveProcessingTime += time;
748 acceptorBytesReceived += size;
752 void receiveFailure(boolean initiator, long time, long size) {
754 initiatorReceiveFailures++;
755 initiatorReceiveFailureProcessingTime += time;
756 initiatorBytesReceived += size;
758 acceptorReceiveFailures++;
759 acceptorReceiveFailureProcessingTime += time;
760 acceptorBytesReceived += size;
764 void dataSent(boolean initiator, long size) {
766 initiatorBytesSent += size;
768 acceptorBytesSent += size;
772 void sendFailure(boolean initiator, Message message, long time, long size) {
774 initiatorSendFailures++;
775 initiatorSendFailureProcessingTime += time;
776 initiatorBytesSent += size;
778 acceptorSendFailures++;
779 acceptorSendFailureProcessingTime += time;
780 acceptorBytesSent += size;
784 void messageSent(boolean initiator, Message message, long time, long size) {
786 initiatorMessagesSent++;
787 initiatorSendProcessingTime += time;
788 initiatorBytesSent += size;
790 acceptorMessagesSent++;
791 acceptorSendProcessingTime += time;
792 acceptorBytesSent += size;
796 public void mergeMetrics(TransportBindingMetric other) {
797 peerID = other.peerID;
799 if (other.initiatorState != null) {
800 initiatorState = other.initiatorState;
803 if (other.initiatorTransitionTime != 0) {
804 initiatorTransitionTime = other.initiatorTransitionTime;
807 if (other.acceptorState != null) {
808 acceptorState = other.acceptorState;
811 if (other.initiatorTransitionTime != 0) {
812 acceptorTransitionTime = other.acceptorTransitionTime;
815 acceptorBytesReceived += other.acceptorBytesReceived;
816 acceptorBytesSent += other.acceptorBytesSent;
817 acceptorConnections += other.acceptorConnections;
818 acceptorConnectionsClosed += other.acceptorConnectionsClosed;
819 acceptorConnectionsDropped += other.acceptorConnectionsDropped;
820 acceptorConnectionsFailed += other.acceptorConnectionsFailed;
821 acceptorMessagesReceived += other.acceptorMessagesReceived;
822 acceptorMessagesSent += other.acceptorMessagesSent;
823 acceptorReceiveFailureProcessingTime += other.acceptorReceiveFailureProcessingTime;
824 acceptorReceiveFailures += other.acceptorReceiveFailures;
825 acceptorReceiveProcessingTime += other.acceptorReceiveProcessingTime;
826 acceptorSendFailureProcessingTime += other.acceptorSendFailureProcessingTime;
827 acceptorSendFailures += other.acceptorSendFailures;
828 acceptorSendProcessingTime += other.acceptorSendProcessingTime;
829 acceptorTotalTimeConnected += other.acceptorTotalTimeConnected;
830 acceptorTimeToConnect += other.acceptorTimeToConnect;
831 acceptorTimeToFail += other.acceptorTimeToFail;
832 initiatorBytesReceived += other.initiatorBytesReceived;
833 initiatorBytesSent += other.initiatorBytesSent;
834 initiatorTotalTimeConnected += other.initiatorTotalTimeConnected;
835 initiatorConnections += other.initiatorConnections;
836 initiatorConnectionsClosed += other.initiatorConnectionsClosed;
837 initiatorConnectionsDropped += other.initiatorConnectionsDropped;
838 initiatorConnectionsFailed += other.initiatorConnectionsFailed;
839 initiatorMessagesReceived += other.initiatorMessagesReceived;
840 initiatorMessagesSent += other.initiatorMessagesSent;
841 initiatorReceiveFailureProcessingTime += other.initiatorReceiveFailureProcessingTime;
842 initiatorReceiveFailures += other.initiatorReceiveFailures;
843 initiatorReceiveProcessingTime += other.initiatorReceiveProcessingTime;
844 initiatorSendFailureProcessingTime += other.initiatorSendFailureProcessingTime;
845 initiatorSendFailures += other.initiatorSendFailures;
846 initiatorSendProcessingTime += other.initiatorSendProcessingTime;
847 initiatorTimeToConnect += other.initiatorTimeToConnect;
848 initiatorTimeToFail += other.initiatorTimeToFail;
849 numPings += other.numPings;
850 numFailedPings += other.numFailedPings;
851 pingTime += other.pingTime;
852 pingFailedTime += other.pingFailedTime;
853 numPingsReceived += other.numPingsReceived;
857 public void serializeTo(Element element) throws DocumentSerializationException {
859 DocumentSerializableUtilities.addString(element, "peerID", peerID.toString());
860 DocumentSerializableUtilities.addString(element, "endpointAddress", endpointAddress.toString());
862 if (initiatorState != null) {
863 DocumentSerializableUtilities.addString(element, "initiatorState", initiatorState);
865 if (initiatorTransitionTime != 0) {
866 DocumentSerializableUtilities.addLong(element, "initiatorTransitionTime", initiatorTransitionTime);
869 if (acceptorState != null) {
870 DocumentSerializableUtilities.addString(element, "acceptorState", acceptorState);
872 if (acceptorTransitionTime != 0) {
873 DocumentSerializableUtilities.addLong(element, "acceptorTransitionTime", acceptorTransitionTime);
876 if (acceptorBytesReceived != 0) {
877 DocumentSerializableUtilities.addInt(element, "acceptorBytesReceived", acceptorBytesReceived);
880 if (acceptorBytesSent != 0) {
881 DocumentSerializableUtilities.addInt(element, "acceptorBytesSent", acceptorBytesSent);
884 if (acceptorConnections != 0) {
885 DocumentSerializableUtilities.addInt(element, "acceptorConnections", acceptorConnections);
888 if (acceptorConnectionsClosed != 0) {
889 DocumentSerializableUtilities.addInt(element, "acceptorConnectionsClosed", acceptorConnectionsClosed);
892 if (acceptorConnectionsDropped != 0) {
893 DocumentSerializableUtilities.addInt(element, "acceptorConnectionsDropped", acceptorConnectionsDropped);
896 if (acceptorConnectionsFailed != 0) {
897 DocumentSerializableUtilities.addInt(element, "acceptorConnectionsFailed", acceptorConnectionsFailed);
900 if (acceptorMessagesReceived != 0) {
901 DocumentSerializableUtilities.addInt(element, "acceptorMessagesReceived", acceptorMessagesReceived);
904 if (acceptorMessagesSent != 0) {
905 DocumentSerializableUtilities.addInt(element, "acceptorMessagesSent", acceptorMessagesSent);
908 if (acceptorReceiveFailureProcessingTime != 0) {
909 DocumentSerializableUtilities.addLong(element, "acceptorReceiveFailureProcessingTime"
911 acceptorReceiveFailureProcessingTime);
914 if (acceptorReceiveFailures != 0) {
915 DocumentSerializableUtilities.addInt(element, "acceptorReceiveFailures", acceptorReceiveFailures);
918 if (acceptorReceiveProcessingTime != 0) {
919 DocumentSerializableUtilities.addLong(element, "acceptorReceiveProcessingTime", acceptorReceiveProcessingTime);
922 if (acceptorSendFailureProcessingTime != 0) {
923 DocumentSerializableUtilities.addLong(element, "acceptorSendFailureProcessingTime", acceptorSendFailureProcessingTime);
926 if (acceptorSendFailures != 0) {
927 DocumentSerializableUtilities.addInt(element, "acceptorSendFailures", acceptorSendFailures);
930 if (acceptorSendProcessingTime != 0) {
931 DocumentSerializableUtilities.addLong(element, "acceptorSendProcessingTime", acceptorSendProcessingTime);
934 if (acceptorTotalTimeConnected != 0) {
935 DocumentSerializableUtilities.addLong(element, "acceptorTotalTimeConnected", acceptorTotalTimeConnected);
938 if (acceptorTimeToConnect != 0) {
939 DocumentSerializableUtilities.addLong(element, "acceptorTimeToConnect", acceptorTimeToConnect);
942 if (acceptorTimeToFail != 0) {
943 DocumentSerializableUtilities.addLong(element, "acceptorTimeToFail", acceptorTimeToFail);
946 if (initiatorBytesReceived != 0) {
947 DocumentSerializableUtilities.addInt(element, "initiatorBytesReceived", initiatorBytesReceived);
950 if (initiatorBytesSent != 0) {
951 DocumentSerializableUtilities.addInt(element, "initiatorBytesSent", initiatorBytesSent);
954 if (initiatorTotalTimeConnected != 0) {
955 DocumentSerializableUtilities.addLong(element, "initiatorTotalTimeConnected", initiatorTotalTimeConnected);
958 if (initiatorConnections != 0) {
959 DocumentSerializableUtilities.addInt(element, "initiatorConnections", initiatorConnections);
962 if (initiatorConnectionsClosed != 0) {
963 DocumentSerializableUtilities.addInt(element, "initiatorConnectionsClosed", initiatorConnectionsClosed);
966 if (initiatorConnectionsDropped != 0) {
967 DocumentSerializableUtilities.addInt(element, "initiatorConnectionsDropped", initiatorConnectionsDropped);
970 if (initiatorConnectionsFailed != 0) {
971 DocumentSerializableUtilities.addInt(element, "initiatorConnectionsFailed", initiatorConnectionsFailed);
974 if (initiatorMessagesReceived != 0) {
975 DocumentSerializableUtilities.addInt(element, "initiatorMessagesReceived", initiatorMessagesReceived);
978 if (initiatorMessagesSent != 0) {
979 DocumentSerializableUtilities.addInt(element, "initiatorMessagesSent", initiatorMessagesSent);
982 if (initiatorReceiveFailureProcessingTime != 0) {
983 DocumentSerializableUtilities.addLong(element, "initiatorReceiveFailureProcessingTime"
985 initiatorReceiveFailureProcessingTime);
988 if (initiatorReceiveFailures != 0) {
989 DocumentSerializableUtilities.addInt(element, "initiatorReceiveFailures", initiatorReceiveFailures);
992 if (initiatorReceiveProcessingTime != 0) {
993 DocumentSerializableUtilities.addLong(element, "initiatorReceiveProcessingTime", initiatorReceiveProcessingTime);
996 if (initiatorSendFailureProcessingTime != 0) {
997 DocumentSerializableUtilities.addLong(element, "initiatorSendFailureProcessingTime"
999 initiatorSendFailureProcessingTime);
1002 if (initiatorSendFailures != 0) {
1003 DocumentSerializableUtilities.addInt(element, "initiatorSendFailures", initiatorSendFailures);
1006 if (initiatorSendProcessingTime != 0) {
1007 DocumentSerializableUtilities.addLong(element, "initiatorSendProcessingTime", initiatorSendProcessingTime);
1010 if (initiatorTimeToConnect != 0) {
1011 DocumentSerializableUtilities.addLong(element, "initiatorTimeToConnect", initiatorTimeToConnect);
1014 if (initiatorTimeToFail != 0) {
1015 DocumentSerializableUtilities.addLong(element, "initiatorTimeToFail", initiatorTimeToFail);
1018 if (numPings != 0) {
1019 DocumentSerializableUtilities.addInt(element, "numPings", numPings);
1022 if (numFailedPings != 0) {
1023 DocumentSerializableUtilities.addInt(element, "numFailedPings", numFailedPings);
1026 if (pingTime != 0) {
1027 DocumentSerializableUtilities.addLong(element, "pingTime", pingTime);
1030 if (pingFailedTime != 0) {
1031 DocumentSerializableUtilities.addLong(element, "pingFailedTime", pingFailedTime);
1034 if (initiatorTimeToFail != 0) {
1035 DocumentSerializableUtilities.addInt(element, "numPingsReceived", numPingsReceived);
1040 public void initializeFrom(Element element) throws DocumentSerializationException {
1041 for (Enumeration e = element.getChildren(); e.hasMoreElements();) {
1042 Element childElement = (TextElement) e.nextElement();
1043 String tagName = (String) childElement.getKey();
1045 if (tagName.equals("peerID")) {
1046 String peerIdString = DocumentSerializableUtilities.getString(childElement);
1048 peerID = MetricUtilities.getPeerIdFromString(peerIdString);
1050 if (tagName.equals("endpointAddress")) {
1051 String endpointAddressString = DocumentSerializableUtilities.getString(childElement);
1053 endpointAddress = new EndpointAddress(endpointAddressString);
1054 } else if (tagName.equals("acceptorBytesReceived")) {
1055 acceptorBytesReceived = DocumentSerializableUtilities.getInt(childElement);
1056 } else if (tagName.equals("acceptorBytesSent")) {
1057 acceptorBytesSent = DocumentSerializableUtilities.getInt(childElement);
1058 } else if (tagName.equals("acceptorConnections")) {
1059 acceptorConnections = DocumentSerializableUtilities.getInt(childElement);
1060 } else if (tagName.equals("acceptorConnectionsClosed")) {
1061 acceptorConnectionsClosed = DocumentSerializableUtilities.getInt(childElement);
1062 } else if (tagName.equals("acceptorConnectionsDropped")) {
1063 acceptorConnectionsDropped = DocumentSerializableUtilities.getInt(childElement);
1064 } else if (tagName.equals("acceptorConnectionsFailed")) {
1065 acceptorConnectionsFailed = DocumentSerializableUtilities.getInt(childElement);
1066 } else if (tagName.equals("acceptorMessagesReceived")) {
1067 acceptorMessagesReceived = DocumentSerializableUtilities.getInt(childElement);
1068 } else if (tagName.equals("acceptorMessagesSent")) {
1069 acceptorMessagesSent = DocumentSerializableUtilities.getInt(childElement);
1070 } else if (tagName.equals("acceptorReceiveFailureProcessingTime")) {
1071 acceptorReceiveFailureProcessingTime = DocumentSerializableUtilities.getLong(childElement);
1072 } else if (tagName.equals("acceptorReceiveFailures")) {
1073 acceptorReceiveFailures = DocumentSerializableUtilities.getInt(childElement);
1074 } else if (tagName.equals("acceptorReceiveProcessingTime")) {
1075 acceptorReceiveProcessingTime = DocumentSerializableUtilities.getLong(childElement);
1076 } else if (tagName.equals("acceptorSendFailureProcessingTime")) {
1077 acceptorSendFailureProcessingTime = DocumentSerializableUtilities.getLong(childElement);
1078 } else if (tagName.equals("acceptorSendFailures")) {
1079 acceptorSendFailures = DocumentSerializableUtilities.getInt(childElement);
1080 } else if (tagName.equals("acceptorSendProcessingTime")) {
1081 acceptorSendProcessingTime = DocumentSerializableUtilities.getLong(childElement);
1082 } else if (tagName.equals("acceptorTotalTimeConnected")) {
1083 acceptorTotalTimeConnected = DocumentSerializableUtilities.getLong(childElement);
1084 } else if (tagName.equals("acceptorTimeToConnect")) {
1085 acceptorTimeToConnect = DocumentSerializableUtilities.getLong(childElement);
1086 } else if (tagName.equals("acceptorTimeToFail")) {
1087 acceptorTimeToFail = DocumentSerializableUtilities.getLong(childElement);
1088 } else if (tagName.equals("initiatorBytesReceived")) {
1089 initiatorBytesReceived = DocumentSerializableUtilities.getInt(childElement);
1090 } else if (tagName.equals("initiatorBytesSent")) {
1091 initiatorBytesSent = DocumentSerializableUtilities.getInt(childElement);
1092 } else if (tagName.equals("initiatorTotalTimeConnected")) {
1093 initiatorTotalTimeConnected = DocumentSerializableUtilities.getLong(childElement);
1094 } else if (tagName.equals("initiatorConnections")) {
1095 initiatorConnections = DocumentSerializableUtilities.getInt(childElement);
1096 } else if (tagName.equals("initiatorConnectionsClosed")) {
1097 initiatorConnectionsClosed = DocumentSerializableUtilities.getInt(childElement);
1098 } else if (tagName.equals("initiatorConnectionsDropped")) {
1099 initiatorConnectionsDropped = DocumentSerializableUtilities.getInt(childElement);
1100 } else if (tagName.equals("initiatorConnectionsFailed")) {
1101 initiatorConnectionsFailed = DocumentSerializableUtilities.getInt(childElement);
1102 } else if (tagName.equals("initiatorMessagesReceived")) {
1103 initiatorMessagesReceived = DocumentSerializableUtilities.getInt(childElement);
1104 } else if (tagName.equals("initiatorMessagesSent")) {
1105 initiatorMessagesSent = DocumentSerializableUtilities.getInt(childElement);
1106 } else if (tagName.equals("initiatorReceiveFailureProcessingTime")) {
1107 initiatorReceiveFailureProcessingTime = DocumentSerializableUtilities.getLong(childElement);
1108 } else if (tagName.equals("initiatorReceiveFailures")) {
1109 initiatorReceiveFailures = DocumentSerializableUtilities.getInt(childElement);
1110 } else if (tagName.equals("initiatorReceiveProcessingTime")) {
1111 initiatorReceiveProcessingTime = DocumentSerializableUtilities.getLong(childElement);
1112 } else if (tagName.equals("initiatorSendFailureProcessingTime")) {
1113 initiatorSendFailureProcessingTime = DocumentSerializableUtilities.getLong(childElement);
1114 } else if (tagName.equals("initiatorSendFailures")) {
1115 initiatorSendFailures = DocumentSerializableUtilities.getInt(childElement);
1116 } else if (tagName.equals("initiatorSendProcessingTime")) {
1117 initiatorSendProcessingTime = DocumentSerializableUtilities.getLong(childElement);
1118 } else if (tagName.equals("initiatorTimeToConnect")) {
1119 initiatorTimeToConnect = DocumentSerializableUtilities.getLong(childElement);
1120 } else if (tagName.equals("initiatorTimeToFail")) {
1121 initiatorTimeToFail = DocumentSerializableUtilities.getLong(childElement);
1122 } else if (tagName.equals("numPingsReceived")) {
1123 numPingsReceived = DocumentSerializableUtilities.getInt(childElement);
1124 } else if (tagName.equals("numPings")) {
1125 numPings = DocumentSerializableUtilities.getInt(childElement);
1126 } else if (tagName.equals("numFailedPings")) {
1127 numFailedPings = DocumentSerializableUtilities.getInt(childElement);
1128 } else if (tagName.equals("pingTime")) {
1129 pingTime = DocumentSerializableUtilities.getLong(childElement);
1130 } else if (tagName.equals("pingFailedTime")) {
1131 pingFailedTime = DocumentSerializableUtilities.getLong(childElement);