Commit be7b6729 authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

More clustering work.

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/trunk@9228 b35dd754-fafc-0310-a699-88a17e54d16e
parent 0d96ef97
......@@ -2474,3 +2474,7 @@ system.clustering.overview.clients=Clients
system.clustering.overview.incoming_servers=Incoming Servers
system.clustering.overview.outgoing_servers=Outgoing Servers
system.clustering.overview.memory=Memory
system.clustering.not-available=Clustering not available
system.clustering.not-installed=Clustering support was not found on the system. Install Openfire Enterprise to enable it.
system.clustering.not-valid-license=Openfire Enterprise license is not valid for clustering. You need to update your license to enable clustering.
system.clustering.starting=Clustering is being started. It may take up to 30 seconds to complete. Click {0}here{1} to refresh.
......@@ -2221,4 +2221,8 @@ system.clustering.overview.label=Vision del Cluster
system.clustering.overview.memory=Memmoria
system.clustering.overview.node=Nodos
system.clustering.overview.outgoing_servers=Servidores Salientes
system.clustering.title=Clustering
\ No newline at end of file
system.clustering.title=Clustering
system.clustering.not-available=Clustering no esta disponible
system.clustering.not-installed=No se ha encontrado soporte para clustering en el sistema. Instale Openfire Corporativo para habilitarlo.
system.clustering.not-valid-license=La licencia de Openfire Corporativo no incluye clustering. Necesita actualizar su licencia para habilitar clustering.
system.clustering.starting=Clustering esta arrancando. Puede tardar hasta 30 segundos para completar. Haga clic {0}aqui{1} para refrescar.
......@@ -321,6 +321,27 @@ public class ClusterManager {
return JiveGlobals.getXMLProperty(CLUSTER_PROPERTY_NAME, false);
}
/**
* Returns true if clustering is installed and can be used by
* this JVM to join a cluster.
*
* @return true if clustering is installed and can be used by
* this JVM to join a cluster.
*/
public static boolean isClusteringAvailable() {
return CacheFactory.isClusteringAvailable();
}
/**
* Returns true is clustering is currently being started. Once the cluster
* is started or failed to be started this value will be false.
*
* @return true is clustering is currently being started.
*/
public static boolean isClusteringStarting() {
return CacheFactory.isClusteringStarting();
}
/**
* Returns true if this JVM is part of a cluster. The cluster may have many nodes
* or this JVM could be the only node.
......
......@@ -41,6 +41,7 @@ public class CacheFactory {
public static String CLUSTERED_CACHE_PROPERTY_NAME = "cache.clustering.clustered.class";
private static boolean clusteringStarted = false;
private static boolean clusteringStarting = false;
/**
* Storage for all caches that get created.
......@@ -110,6 +111,33 @@ public class CacheFactory {
return cache;
}
/**
* Returns true if clustering is installed and can be used by
* this JVM to join a cluster.
*
* @return true if clustering is installed and can be used by
* this JVM to join a cluster.
*/
public static boolean isClusteringAvailable() {
try {
Class.forName(clusteredCacheFactoryClass, true,
getClusteredCacheStrategyClassLoader("enterprise"));
} catch (ClassNotFoundException e) {
return false;
}
return true;
}
/**
* Returns true is clustering is currently being started. Once the cluster
* is started or failed to be started this value will be false.
*
* @return true is clustering is currently being started.
*/
public static boolean isClusteringStarting() {
return clusteringStarting;
}
/**
* Returns true if this node is currently a member of a cluster. The last step of application
* initialization is to join a cluster, so this method returns false during most of application startup.
......@@ -170,13 +198,23 @@ public class CacheFactory {
}
/**
* Returns the maximum number of cluster members allowed. A value of 0 will
* Returns the maximum number of cluster members allowed. A value of 0 or 1 will
* be returned when clustering is not allowed.
*
* @return the maximum number of cluster members allowed or 0 if clustering is not allowed.
* @return the maximum number of cluster members allowed or 0 or 1 if clustering is not allowed.
*/
public static int getMaxClusterNodes() {
return cacheFactoryStrategy.getMaxClusterNodes();
if (isClusteringAvailable()) {
try {
CacheFactoryStrategy cacheFactory = (CacheFactoryStrategy) Class.forName(
clusteredCacheFactoryClass, true,
getClusteredCacheStrategyClassLoader("enterprise")).newInstance();
return cacheFactory.getMaxClusterNodes();
} catch (Exception e) {
Log.error("Error instantiating clustered cache factory", e);
}
}
return 0;
}
/**
* Invokes a task on other cluster members in an asynchronous fashion. The task will not be
......@@ -259,6 +297,7 @@ public class CacheFactory {
public static void startClustering() {
clusteringStarted = false;
clusteringStarting = true;
try {
cacheFactoryStrategy = (CacheFactoryStrategy) Class.forName(clusteredCacheFactoryClass, true,
getClusteredCacheStrategyClassLoader("enterprise"))
......@@ -331,6 +370,7 @@ public class CacheFactory {
statsThread.start();
}
}
clusteringStarting = false;
}
public static void stopClustering() {
......
......@@ -26,6 +26,7 @@
<%@ page import="java.util.Collection" %>
<%@ page import="java.util.Date" %>
<%@ page import="java.util.Map" %>
<%@ page import="org.jivesoftware.util.Log" %>
<html>
<head>
......@@ -48,19 +49,26 @@
if (!clusteringEnabled) {
ClusterManager.setClusteringEnabled(false);
updateSucess = true;
}
else {
ClusterManager.setClusteringEnabled(true);
updateSucess = ClusterManager.isClusteringStarted();
} else {
if (ClusterManager.isClusteringAvailable()) {
ClusterManager.setClusteringEnabled(true);
updateSucess = ClusterManager.isClusteringStarted();
} else {
Log.error("Failed to enable clustering. Clustering is not installed.");
}
}
}
clusteringEnabled = ClusterManager.isClusteringStarted();
boolean clusteringAvailable = ClusterManager.isClusteringAvailable();
boolean clusteringStarting = ClusterManager.isClusteringStarting();
int maxClusterNodes = ClusterManager.getMaxClusterNodes();
clusteringEnabled = ClusterManager.isClusteringStarted() || ClusterManager.isClusteringStarting();
Collection<ClusterNodeInfo> clusterNodesInfo = ClusterManager.getNodesInfo();
// Get some basic statistics from the cluster nodes
// TODO Set a timeout so the page can load fast even if a node is taking too long to answer
Collection<Object> statistics = CacheFactory.doSynchronousClusterTask(new GetBasicStatistics(), true);
Collection<Object> statistics =
CacheFactory.doSynchronousClusterTask(new GetBasicStatistics(), true);
// Calculate percentages
int clients = 0;
int incoming = 0;
......@@ -125,12 +133,28 @@
</div>
<br>
<% }
}
%>
<%
// TODO Check that clustering is available. Give a new error message if not.
} else if (!clusteringAvailable) {
%>
<div class="warning">
<table cellpadding="0" cellspacing="0" border="0" >
<tbody>
<tr>
<td class="jive-icon-label">
<b><fmt:message key="system.clustering.not-available" /></b><br/><br/>
</td>
</tr>
<td valign="top" align="left" colspan="2">
<% if (maxClusterNodes == 0) { %>
<span><fmt:message key="system.clustering.not-installed"/></span>
<% } else { %>
<span><fmt:message key="system.clustering.not-valid-license"/></span>
<% } %>
</td>
</tbody>
</table>
</div>
<br>
<% } %>
<!-- BEGIN 'Clustering Enabled' -->
<form action="system-clustering.jsp" method="post">
......@@ -143,7 +167,7 @@
<tr>
<td width="1%" valign="top" nowrap>
<input type="radio" name="clusteringEnabled" value="false" id="rb01"
<%= (!clusteringEnabled ? "checked" : "") %>>
<%= (!clusteringEnabled ? "checked" : "") %> <%= (!clusteringAvailable || clusteringStarting ? "disabled" : "") %>>
</td>
<td width="99%">
<label for="rb01">
......@@ -154,7 +178,7 @@
<tr>
<td width="1%" valign="top" nowrap>
<input type="radio" name="clusteringEnabled" value="true" id="rb02"
<%= (clusteringEnabled ? "checked" : "") %>>
<%= (clusteringEnabled ? "checked" : "") %> <%= (!clusteringAvailable || clusteringStarting ? "disabled" : "") %>>
</td>
<td width="99%">
<label for="rb02">
......@@ -165,8 +189,10 @@
</tbody>
</table>
<br/>
<input type="submit" name="update" value="<fmt:message key="global.save_settings" />">
</div>
<% if (clusteringAvailable && !clusteringStarting) { %>
<input type="submit" name="update" value="<fmt:message key="global.save_settings" />">
<% } %>
</div>
</form>
<!-- END 'Clustering Enabled' -->
<br>
......@@ -177,7 +203,7 @@
<p>
<fmt:message key="system.clustering.overview.info">
<fmt:param value="<%= clusterNodesInfo.size() %>" />
<fmt:param value="<%= ClusterManager.getMaxClusterNodes() %>" />
<fmt:param value="<%= maxClusterNodes %>" />
<fmt:param value="<%= "<span style='background-color:#ffc;'>" %>" />
<fmt:param value="<%= "</span>" %>" />
</fmt:message>
......@@ -208,26 +234,29 @@
</tr>
</thead>
<tbody>
<% for (ClusterNodeInfo nodeInfo : clusterNodesInfo) {
boolean isLocalMember = XMPPServer.getInstance().getNodeID().equals(nodeInfo.getNodeID());
String nodeID = new String(nodeInfo.getNodeID().toByteArray());
<% if (!clusterNodesInfo.isEmpty()) {
for (ClusterNodeInfo nodeInfo : clusterNodesInfo) {
boolean isLocalMember =
XMPPServer.getInstance().getNodeID().equals(nodeInfo.getNodeID());
int nodeID = nodeInfo.getNodeID().hashCode();
Map<String, Object> nodeStats = null;
for (Object stat : statistics) {
Map<String, Object> statsMap = (Map<String, Object>) stat;
if (Arrays.equals((byte[]) statsMap.get(GetBasicStatistics.NODE), nodeInfo.getNodeID().toByteArray())) {
if (Arrays.equals((byte[]) statsMap.get(GetBasicStatistics.NODE),
nodeInfo.getNodeID().toByteArray())) {
nodeStats = statsMap;
break;
}
}
%>
<tr valign="top" class="<%= (isLocalMember ? "local" : "") %>" valign="middle">
<tr class="<%= (isLocalMember ? "local" : "") %>" valign="middle">
<td align="center" width="1%">
<a href="system-clustering-node.jsp?UID=<%= nodeID%>"
<a href="plugins/enterprise/system-clustering-node.jsp?UID=<%= nodeID %>"
title="Click for more details"
><img src="images/server-network-24x24.gif" width="24" height="24" border="0" alt=""></a>
</td>
<td class="jive-description" nowrap width="1%" valign="middle">
<a href="system-clustering.jsp?UID=<%= nodeID %>">
<a href="plugins/enterprise/system-clustering-node.jsp?UID=<%= nodeID %>">
<% if (isLocalMember) { %>
<b><%= nodeInfo.getHostName() %></b>
<% } else { %>
......@@ -297,6 +326,16 @@
</td>
<td width="20%">&nbsp;</td>
</tr>
<% }
} else if (clusteringStarting) { %>
<tr valign="middle" align="middle" class="local">
<td colspan=8>
<fmt:message key="system.clustering.starting">
<fmt:param value="<%= "<a href='system-clustering.jsp'>" %>" />
<fmt:param value="<%= "</a>" %>" />
</fmt:message>
</td>
</tr>
<% } %>
</tbody>
</table>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment